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
162 lines
8.5 KiB
11 months ago
|
<!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>
|