You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
161 lines
8.5 KiB
161 lines
8.5 KiB
<!DOCTYPE html> |
|
<html lang="en"> |
|
<head> |
|
<meta http-equiv="X-UA-Compatible" content="IE=edge"> |
|
<meta http-equiv="content-type" content="text/html; charset=utf-8"> |
|
|
|
<!-- Enable responsiveness on mobile devices--> |
|
<!-- viewport-fit=cover is to support iPhone X rounded corners and notch in landscape--> |
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1, viewport-fit=cover"> |
|
|
|
<title>Julio Biason .Me 4.3</title> |
|
|
|
<!-- CSS --> |
|
<link rel="stylesheet" href="https://blog.juliobiason.me/print.css" media="print"> |
|
<link rel="stylesheet" href="https://blog.juliobiason.me/poole.css"> |
|
<link rel="stylesheet" href="https://blog.juliobiason.me/hyde.css"> |
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=PT+Sans:400,400italic,700|Abril+Fatface"> |
|
|
|
|
|
|
|
|
|
|
|
</head> |
|
|
|
<body class=" "> |
|
|
|
<div class="sidebar"> |
|
<div class="container sidebar-sticky"> |
|
<div class="sidebar-about"> |
|
|
|
<a href="https://blog.juliobiason.me"><h1>Julio Biason .Me 4.3</h1></a> |
|
|
|
<p class="lead">Old school dev living in a 2.0 dev world</p> |
|
|
|
|
|
</div> |
|
|
|
<ul class="sidebar-nav"> |
|
|
|
|
|
<li class="sidebar-nav-item"><a href="/">English</a></li> |
|
|
|
<li class="sidebar-nav-item"><a href="/pt">Português</a></li> |
|
|
|
<li class="sidebar-nav-item"><a href="/tags">Tags (EN)</a></li> |
|
|
|
<li class="sidebar-nav-item"><a href="/pt/tags">Tags (PT)</a></li> |
|
|
|
|
|
</ul> |
|
</div> |
|
</div> |
|
|
|
|
|
<div class="content container"> |
|
|
|
<div class="post"> |
|
<h1 class="post-title">14.09. Plugins - CtrlP and CtrlPFunky</h1> |
|
<span class="post-date"> |
|
2015-12-22 |
|
|
|
</span> |
|
<p>Essa é a parte em que você vai ter a impressão de estar programando em Perl, |
|
porque qualquer caractere é válido.</p> |
|
<span id="continue-reading"></span> |
|
<p>O nono e penúltimo plugin (na verdade os nonos e penúltimos plugins) discutido |
|
é o <a href="https://github.com/kien/ctrlp.vim">CtrlP</a> e seu plugin (sim, um plugin do |
|
plugin<sup class="footnote-reference"><a href="#1">1</a></sup>) <a href="https://github.com/tacahiroy/ctrlp-funky">CtrlPFunky</a></p> |
|
<p>Para instalar os dois, com Vundle:</p> |
|
<pre data-lang="viml" style="background-color:#2b303b;color:#c0c5ce;" class="language-viml "><code class="language-viml" data-lang="viml"><span>Plugin </span><span style="color:#a3be8c;">"kien/ctrlp.vim" |
|
</span><span>Plugin </span><span style="color:#a3be8c;">"tacahiroy/ctrlp-funky" |
|
</span></code></pre> |
|
<p>CtrlP é um plugin que facilita encontrar e abrir arquivos, com procura fuzzy. |
|
E, por procura fuzzy eu quero dizer que ele encontra qualquer arquivo que tenha |
|
as letras digitadas na ordem que você digitou.</p> |
|
<p><img src="https://blog.juliobiason.me/books/uma-licao-de-vim/14-09-ctrlp/ctrlp.png" alt="" /></p> |
|
<p>Para acionar o CtrlP, você deve digitar, logicamente, <code>[Ctrl]p</code>. Ao fazer isso, |
|
uma janela parecida com a Quickfix irá aparecer, mostrando alguns arquivos e um |
|
prompt para que você digite o que quer encontrar. No exemplo acima, como que |
|
digitei "vim", ele encontrou todos os arquivos a partir do diretório atual que |
|
começavam com "v", tinham um "i" no meio e terminavam com "m" (seria |
|
basicamente o mesmo que pegar a lista de arquivos a partir do diretório atual e |
|
seus sub-diretórios e procurar pela regex "v.*i.*m".)</p> |
|
<p>Uma vez que você encontre o arquivo desejado na lista (ela não tem rolagem, |
|
então se você ainda não estiver vendo o arquivo, continue adicionando |
|
caracteres para que o arquivo desejado apareça na lista -- uma vez lá, você pode |
|
selecioná-lo com as setas), você pode:</p> |
|
<ul> |
|
<li>Pressionar <code>[Enter]</code> para abrir o arquivo na janela atual.</li> |
|
<li>Pressionar <code>[Ctrl]t</code> para abrir o arquivo em outra aba.</li> |
|
<li>Pressionar <code>[Ctrl]s</code> para fazer um split horizontal e abrir o arquivo no novo |
|
split.</li> |
|
<li>Pressionar <code>[Ctrl]v</code> para fazer um split vertical e abrir o arquivo no novo |
|
split.</li> |
|
</ul> |
|
<p>Um problema que você talvez encontre é que o CtrlP costuma listar tudo que se |
|
encaixar na expressão utilizada, inclusive arquivos binário, objetos |
|
intermediários, etc. Para remover estes arquivos da listagem, você pode usar |
|
<code>:set wildignore</code>, que também afeta a lista de arquivos que o VIM mostra quando |
|
você estiver usando os comandos normais de abertura de arquivo (<code>:e</code>, <code>:tabe</code>, |
|
etc).</p> |
|
<p>Como a configuração do wildignore é uma lista, você pode adicionar ou remover |
|
usando += e -=. Por exemplo, para ignorar os arquivos de objetos compilados do |
|
Python e o diretório que o setup.py constuma usar para construir o pacote de |
|
distribuição do módulo, você teria:</p> |
|
<pre data-lang="viml" style="background-color:#2b303b;color:#c0c5ce;" class="language-viml "><code class="language-viml" data-lang="viml"><span style="color:#96b5b4;">set</span><span> wildignore+=</span><span style="color:#b48ead;">*.</span><span>pyc |
|
</span><span style="color:#96b5b4;">set</span><span> wildignore+=</span><span style="color:#b48ead;">*</span><span style="color:#96b5b4;">/build/</span><span style="color:#b48ead;">* |
|
</span></code></pre> |
|
<p>ou ainda, para economizar uma linha:</p> |
|
<pre data-lang="viml" style="background-color:#2b303b;color:#c0c5ce;" class="language-viml "><code class="language-viml" data-lang="viml"><span style="color:#96b5b4;">set</span><span> wildignore+=</span><span style="color:#b48ead;">*.</span><span>pyc,</span><span style="color:#b48ead;">*</span><span style="color:#96b5b4;">/build/</span><span style="color:#b48ead;">* |
|
</span></code></pre> |
|
<p>CtrlP tem um plugin, chamado CtrlPFunky. O que ele faz é basicamente o mesmo |
|
que o CtrlP, mas procurando funções, não arquivos.</p> |
|
<p>Para ativar o CtrlPFunky, você precisa primeiro adicionar o mesmo como uma |
|
extensão do CtrlP (e, só pra avisar, isso é específico do CtrlP, não algo que |
|
funciona com todo e qualquer plugin):</p> |
|
<pre data-lang="viml" style="background-color:#2b303b;color:#c0c5ce;" class="language-viml "><code class="language-viml" data-lang="viml"><span style="color:#96b5b4;">let </span><span style="color:#bf616a;">g:ctrlp_extensions</span><span> = [</span><span style="color:#a3be8c;">'funky'</span><span>] |
|
</span></code></pre> |
|
<p>Uma vez instalado, você pode usar <code>:CtrlPFunky</code> para mostrar a lista de funções |
|
no fonte (e a procura continua igual). O problema com CtrlPFunky é que, assim |
|
como todas as demais coisas que vínhamos vendo, ele se basea no tipo de arquivo |
|
atual (<code>:set ft</code>) e para arquivos em que o conteúdo e uma mistura de várias |
|
linguagens (p.ex., arquivo template com a linguagem de template, HTML, CSS e |
|
JavaScript), a listagem de funções pode não ser o que você está esperando (ou |
|
sequer vai funcionar).</p> |
|
<p>Para facilitar a sua vida, você pode fazer um mapeamento do comando para um |
|
atalho de teclado. Por exemplo, eu coloquei <code>[Ctrl]o</code> para chamar o CtrlPFunky |
|
com</p> |
|
<pre data-lang="viml" style="background-color:#2b303b;color:#c0c5ce;" class="language-viml "><code class="language-viml" data-lang="viml"><span style="color:#96b5b4;">nnoremap </span><span><C-O> :CtrlPFunky<CR> |
|
</span></code></pre> |
|
<p><sup class="footnote-reference"><a href="#1">1</a></sup> "Plugin-ception" har har har<sup class="footnote-reference"><a href="#2">2</a></sup>.</p> |
|
<p><sup class="footnote-reference"><a href="#2">2</a></sup> Eu não consigo entender porque as pessoas utilizando tanto o "ception" |
|
quando encontram um meta desta jeito. Um "inception" é a inserção de uma |
|
idéia de forma que a pessoa pense que a idéia é dela, não uma |
|
"<a href="http://pt.wikipedia.org/wiki/Matrioska">Matrioska</a>".</p> |
|
<div> |
|
|
|
<div style="float:left"> |
|
<< <a href="./14-08-snipmate">Plugins - SnipMate</a> |
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
<div style="float:right"> |
|
<a href="./14-10-multiple-cursors">Plugins - Vim-Multiple-Cursors</a> >> |
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
</div> |
|
|
|
</body> |
|
|
|
</html>
|
|
|