The source content for blog.juliobiason.me
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.

162 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:&#x2F;&#x2F;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="&#x2F;">English</a></li>
<li class="sidebar-nav-item"><a href="&#x2F;pt">Português</a></li>
<li class="sidebar-nav-item"><a href="&#x2F;tags">Tags (EN)</a></li>
<li class="sidebar-nav-item"><a href="&#x2F;pt&#x2F;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;">&quot;kien/ctrlp.vim&quot;
</span><span>Plugin </span><span style="color:#a3be8c;">&quot;tacahiroy/ctrlp-funky&quot;
</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 &quot;vim&quot;, ele encontrou todos os arquivos a partir do diretório atual que
começavam com &quot;v&quot;, tinham um &quot;i&quot; no meio e terminavam com &quot;m&quot; (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 &quot;v.*i.*m&quot;.)</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;">&#39;funky&#39;</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>&lt;C-O&gt; :CtrlPFunky&lt;CR&gt;
</span></code></pre>
<p><sup class="footnote-reference"><a href="#1">1</a></sup> &quot;Plugin-ception&quot; 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 &quot;ception&quot;
quando encontram um meta desta jeito. Um &quot;inception&quot; é a inserção de uma
idéia de forma que a pessoa pense que a idéia é dela, não uma
&quot;<a href="http://pt.wikipedia.org/wiki/Matrioska">Matrioska</a>&quot;.</p>
<div>
<div style="float:left">
&lt;&lt; <a href=".&#x2F;14-08-snipmate">Plugins - SnipMate</a>
</div>
&nbsp;
<div style="float:right">
<a href=".&#x2F;14-10-multiple-cursors">Plugins - Vim-Multiple-Cursors</a> &gt;&gt;
</div>
</div>
</div>
</div>
</body>
</html>