Terminando capitulo 21, por favor revisar
This commit is contained in:
parent
51b9185edf
commit
38c0c39e2c
1 changed files with 118 additions and 114 deletions
232
ch21_vimrc.md
232
ch21_vimrc.md
|
@ -19,53 +19,55 @@ Cuando inicias Vim, se van a verificar estos 6 lugares en ese orden, buscando el
|
||||||
|
|
||||||
Primero Vim va a buscar `$VIMINIT`. Si no hay nada ahí, Vim va a buscar `$HOME/.vimrc`. Si no hay nada ahí, Vim va a buscar `$HOME/.vim/vimrc`. Si Vim lo encuentra va a dejar de buscar y usar `$HOME/.vim/vimrc`.
|
Primero Vim va a buscar `$VIMINIT`. Si no hay nada ahí, Vim va a buscar `$HOME/.vimrc`. Si no hay nada ahí, Vim va a buscar `$HOME/.vim/vimrc`. Si Vim lo encuentra va a dejar de buscar y usar `$HOME/.vim/vimrc`.
|
||||||
|
|
||||||
The first location, `$VIMINIT`, is an environment variable. By default it is undefined. If you want to use `~/dotfiles/testvimrc` as your `$VIMINIT` value, you can create an environment variable containing the path of that vimrc. After you run `export VIMINIT='let $MYVIMRC="$HOME/dotfiles/testvimrc" | source $MYVIMRC'`, Vim will now use `~/dotfiles/testvimrc` as your vimrc file.
|
La primer ubicacion, `$VIMINIT`, es una variable de entorno. No esta definido de manera predeterminada. Se puede usar `~/dotfiles/testvimrc` como variable `$VIMINIT` , puede crearse una variable de entorno con la ubicación de este archivo. Después de ejecutar `export VIMINIT='let $MYVIMRC="$HOME/dotfiles/testvimrc" | source $MYVIMRC'`, Vim va a usar el archivo `~/dotfiles/testvimrc` como su archivo vimrc.
|
||||||
|
|
||||||
The second location, `$HOME/.vimrc`, is the conventional path for many Vim users. `$HOME` in many cases is your root directory (`~`). If you have a `~/.vimrc` file, Vim will use this as your vimrc file.
|
La segunda ubicacion, `$HOME/.vimrc`, es el path usado por muchos usuarios de Vim de manera convencional. `$HOME` es en muchos casos el directorio del usuario (`~`). Si existe `~/.vimrc`, Vim va a usar esta como su archivo vimrc.
|
||||||
|
|
||||||
The third, `$HOME/.vim/vimrc`, is located inside the `~/.vim` directory. You might have the `~/.vim` directory already for your plugins, custom scripts, or View files. Note that there is no dot in vimrc file name (`$HOME/.vim/.vimrc` won't work, but `$HOME/.vim/vimrc` will).
|
El tercer lugar es para `$HOME/.vim/vimrc`, esta alojado dentro del directorio `~/.vim`. You might have the `~/.vim` directory already for your plugins, custom scripts, or View files. Note that there is no dot in vimrc file name (`$HOME/.vim/.vimrc` won't work, but `$HOME/.vim/vimrc` will).
|
||||||
|
|
||||||
The fourth, `$EXINIT` works similar to `$VIMINIT`.
|
El cuarto, `$EXINIT` funciona de manera similar a `$VIMINIT`.
|
||||||
|
|
||||||
The fifth, `$HOME/.exrc` works similar to `$HOME/.vimrc`.
|
El quinto, `$HOME/.exrc` trabaja como `$HOME/.vimrc`.
|
||||||
|
|
||||||
The sixth, `$VIMRUNTIME/defaults.vim` is the default vimrc that comes with your Vim build. In my case, I have Vim 8.2 installed using Homebrew, so my path is (`/usr/local/share/vim/vim82`). If Vim does not find any of the previous six vimrc files, it will use this file.
|
El sexto, `$VIMRUNTIME/defaults.vim` es el predeterminado al compilar Vim. En mi caso, tengo instalado Vim 8.2 usando Homebrew (en MAC), entonces el path es (`/usr/local/share/vim/vim82`). Si Vim, en ninguna de las 5 ubicaciones encuentra el archivo vimrc, entonces usará este archivo.
|
||||||
|
|
||||||
For the remaining of this chapter, I am assuming that the vimrc uses the `~/.vimrc` path.
|
Para lo que resta de este capitulo, estamos asumiendo que Vim utiliza el archivo en el path `~/.vimrc`.
|
||||||
|
|
||||||
## What To Put In My Vimrc?
|
## ¿ Que poner en mi Vimrc ?
|
||||||
|
|
||||||
A question I asked when I started was, "What should I put in my vimrc?"
|
La pregunta que me hice cuando me inicie fue: "¿Que debo poner en mi archivo vimrc?"
|
||||||
|
|
||||||
The answer is, "anything you want". The temptation to copy-paste other people's vimrc is real, but you should resist it. If you insist to use someone else's vimrc, make sure that you know what it does, why and how s/he uses it, and most importantly, if it is relevant to you. Just because someone uses it doesn't mean you'll use it too.
|
La respuesta es, "cualquier cosa que quieras". La tentacion de copiar y pegar el vimrc de otras personas es real, pero debes evitar esto. Si insistes en usar el vimrc de alguien más, revisá que sabes lo que esto hace, porqué y cómo él/ella usa esto, y lo más importante, si es relevante para tí. Solo porque alguien mas lo use no quiere decirque tu tambien lo vas a usar.
|
||||||
|
|
||||||
## Basic Vimrc Content
|
|
||||||
|
|
||||||
In the nutshell, a vimrc is a collection of:
|
## Contenido Básico de Vimrc
|
||||||
|
|
||||||
|
En resumen, un archivo vimrc es una colección de:
|
||||||
- Plugins
|
- Plugins
|
||||||
- Settings
|
- Configuraciones
|
||||||
- Custom Functions
|
- Funciones Personalizadas
|
||||||
- Custom Commands
|
- Comandos Personalizados
|
||||||
- Mappings
|
- Mapeos
|
||||||
|
|
||||||
There are other things not mentioned above, but in general, this covers most use cases.
|
Hay otras cosas que no fueron mencionadas, pero en general, esto cubre la mayoría de los casos.
|
||||||
|
|
||||||
### Plugins
|
### Complementos (Plugins)
|
||||||
|
|
||||||
In the previous chapters, I have mentioned different plugins, like [fzf.vim](https://github.com/junegunn/fzf.vim), [vim-mundo](https://github.com/simnalamburt/vim-mundo), and [vim-fugitive](https://github.com/tpope/vim-fugitive).
|
En los capítulos anteriores, mencionamos diferentes complementos, como ser [fzf.vim](https://github.com/junegunn/fzf.vim), [vim-mundo](https://github.com/simnalamburt/vim-mundo) y [vim-fugitive](https://github.com/tpope/vim-fugitive).
|
||||||
|
|
||||||
Ten years ago, managing plugins was a nightmare. However, with the rise of modern plugin managers, installing plugins can now be done in seconds. I am currently using [vim-plug](https://github.com/junegunn/vim-plug) as my plugin manager, so I will use it in this section. The concept should be similar with other popular plugin managers. I would strongly recommend you to check out different ones, such as:
|
Hace 10 años, manejar los complementos era una pesadilla. Sin embargo, con la llegada de modernos gestores de complementos, instalarlos hoy se puede hacer en segundos. Actualmente utilizo [vim-plug](https://github.com/junegunn/vim-plug) como mi gestor de complementos, por esto lo usaré en esta sección. El concepto es similar al de otros gestores de complementos populares. La recomendación es que revises los disponibles, como ser:
|
||||||
- [vundle.vim](https://github.com/VundleVim/Vundle.vim)
|
- [vundle.vim](https://github.com/VundleVim/Vundle.vim)
|
||||||
- [vim-pathogen](https://github.com/tpope/vim-pathogen)
|
- [vim-pathogen](https://github.com/tpope/vim-pathogen)
|
||||||
- [dein.vim](https://github.com/Shougo/dein.vim)
|
- [dein.vim](https://github.com/Shougo/dein.vim)
|
||||||
|
|
||||||
There are more plugin managers than the ones listed above, feel free to look around. To install vim-plug, if you have a Unix machine, run:
|
Hay mas gestores que los listados arriba, sientase libre de buscarlos. Para instalar vim-plug, si utiliza Unix, ejecute:
|
||||||
|
|
||||||
|
|
||||||
```
|
```
|
||||||
curl -fLo ~/.vim/autoload/plug.vim --create-dirs https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
|
curl -fLo ~/.vim/autoload/plug.vim --create-dirs https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
|
||||||
```
|
```
|
||||||
|
|
||||||
To add new plugins, drop your plugin names (`Plug 'github-username/repository-name'`) between the `call plug#begin()` and the `call plug#end()` lines. So if you want to install `emmet-vim` and `nerdtree`, put the following snippet down in your vimrc:
|
Para agregar nuevos complementos, escriba el nombre del mismo (`Plug 'github-username/repository-name'`) entre las lineas `call plug#begin()` y `call plug#end()`. Por ejemplo, si quiere instalar `emmet-vim` y `nerdtree`, agregue las siguientes lineas en su archivo ~/.vimrc:
|
||||||
|
|
||||||
```
|
```
|
||||||
call plug#begin('~/.vim/plugged')
|
call plug#begin('~/.vim/plugged')
|
||||||
|
@ -74,23 +76,23 @@ call plug#begin('~/.vim/plugged')
|
||||||
call plug#end()
|
call plug#end()
|
||||||
```
|
```
|
||||||
|
|
||||||
Save the changes, source it (`:source %`), and run `:PlugInstall` to install them.
|
Guarde los cambios, relea el archivo de configuracion con el comando (`:source %`) y ejecuter `:PlugInstall` para instalar ambos.
|
||||||
|
|
||||||
In the future if you need to remove unused plugins, you just need to remove the plugin names from the `call` block, save and source, and run the `:PlugClean` command to remove it from your machine.
|
En el futuro, si necesita remover los complementos que no utiliza, solo necesita remover el complemento del bloque escrito anteriormente, guardar, releer el archivo de configuracion ( con `:source %} ) y ejecutar el comando `PlugClean` para eliminarlo de su PC.
|
||||||
|
|
||||||
Vim 8 has its own built-in package managers. You can check out `:h packages` for more information. In the next chapter, I will show you how to use it.
|
Vim 8 tiene su propio gestor de paquetes. Puedes consultar la ayuda con `:h packages` para mas información. En el próximo capítulo, vamos a mostrar como usarlo.
|
||||||
|
|
||||||
### Settings
|
### Configuraciones
|
||||||
|
|
||||||
It is common to see a lot of `set` options in any vimrc. If you run the set command from the command-line mode, it is not permanent. You will lose it when you close Vim. For example, instead of running `:set relativenumber number` from the Command-line mode each time you run Vim, you could just put these inside vimrc:
|
Es comun ver muchas opciones que empiezan con `set` en cualquier vimrc. Si ejecutas la linea en el modo linea de comandos, esta configuración no será permanente. Se perderán las mismas al cerrar Vim. Por ejemplo, en vez de ejecutar `:set relativenumber number` desde el modo linea de comandos cada vez que inicias Vim, se puede agregar dentro del archivo .vimrc:
|
||||||
|
|
||||||
```
|
```
|
||||||
set relativenumber number
|
set relativenumber number
|
||||||
```
|
```
|
||||||
|
|
||||||
Some settings require you to pass it a value, like `set tabstop=2`. Check out the help page for each setting to learn what kind of values it accepts.
|
Algunas veces es requerido pasar algún valor, como ser `set tabstop=2`. Revise la página de ayuda para cada configuración para aprender que tipo de valores acepta.
|
||||||
|
|
||||||
You can also use a `let` instead of `set` (make sure to prepend it with `&`). With `let`, you can use an expression as a value. For example, to set the `'dictionary'` option to a path only if the path exists:
|
Tambien se puede usar `let` en cambio de `set` (verifique anteponer el mismo con `&`). Con `let`, se puede usar espresiones como un valor. Por ejemplo, para configurar la opción `'dictionary'` a un directorio solo si ese directorio existe:
|
||||||
|
|
||||||
```
|
```
|
||||||
let s:english_dict = "/usr/share/dict/words"
|
let s:english_dict = "/usr/share/dict/words"
|
||||||
|
@ -100,27 +102,27 @@ if filereadable(s:english_dict)
|
||||||
endif
|
endif
|
||||||
```
|
```
|
||||||
|
|
||||||
You will learn about Vimscript assignments and conditionals in later chapters.
|
Va a aprender sobre hacer scripts con Vim para asignar valores y condicionales en los próximos capítulos.
|
||||||
|
|
||||||
For a list of all possible options in Vim, check out `:h E355`.
|
Para una lista de todas las posibles opciones de Vim, consulte `:h E355`.
|
||||||
|
|
||||||
### Custom Functions
|
### Funciones Personalizadas
|
||||||
|
|
||||||
Vimrc is a good place for custom functions. You will learn how to write your own Vimscript functions in a later chapter.
|
Vimrc es un buen lugar para las funciones personalizadas. Va a aprender como escribir sus propias funciones de vim en los capítulos posteriores.
|
||||||
|
|
||||||
### Custom Commands
|
### Comandos Personalizados
|
||||||
|
|
||||||
You can create a custom Command-line command with `command`.
|
Se pueden crear un comando personalizado para la linea de comandos con `command`.
|
||||||
|
|
||||||
To create a basic command `GimmeDate` to display today's date:
|
Para crear el comando `GimmeDate` para mostrar el día actual:
|
||||||
|
|
||||||
```
|
```
|
||||||
:command! GimmeDate echo call("strftime", ["%F"])
|
:command! GimmeDate echo call("strftime", ["%F"])
|
||||||
```
|
```
|
||||||
|
|
||||||
When you run `:GimmeDate`, Vim will display a date like "2021-01-1".
|
Cuando ejecuta `:GimmeDate`, Vim va a mostrar la fecha como "2021-01-1".
|
||||||
|
|
||||||
To create a basic command with an input, you can use `<args>`. If you want to pass to `GimmeDate` a specific time/date format:
|
Para crear un comando que recibe argumentos, se puede usar `<args>`. Si se le quiere pasar un formato específico a `GimmeDate`:
|
||||||
|
|
||||||
```
|
```
|
||||||
:command! GimmeDate echo call("strftime", [<args>])
|
:command! GimmeDate echo call("strftime", [<args>])
|
||||||
|
@ -132,51 +134,51 @@ To create a basic command with an input, you can use `<args>`. If you want to pa
|
||||||
" 11:30
|
" 11:30
|
||||||
```
|
```
|
||||||
|
|
||||||
If you want to restrict the number of arguments, you can pass it `-nargs` flag. Use `-nargs=0` to pass no argument, `-nargs=1` to pass one argument, `-nargs=+` to pass at least one argument, `-nargs=*` to pass any number of arguments, and `-nargs=?` to pass 0 or one arguments. If you want to pass nth argument, use `-nargs=n` (where `n` is any integer).
|
Si se quiere restringir el número de argumentos, se puede pasar el flag `-nargs`. Use `-nargs=0` para que no se puedan pasar argumentos, `-nargs=1` para pasar un argumento, `-nargs=+` para pasar por lo menos un argumento, `-nargs=*` para pasar cualquier cantidad de argumentos, y `-nargs=?` para pasar 0 ó un argumento. Si quiere pasar n argumentos, use `-nargs=n` (donde `n` es un entero).
|
||||||
|
|
||||||
`<args>` has two variants: `<f-args>` and `<q-args>`. The former is used to pass arguments to Vimscript functions. The latter is used to automatically convert user input to strings.
|
`<args>` tiene dos variantes: `<f-args>` y `<q-args>`. El primero es para pasar argumentos a una función VimScript. El ultimo es usado para convertir la entrada del usuario en strings.
|
||||||
|
|
||||||
Using `args`:
|
Usando `argumentos`:
|
||||||
|
|
||||||
```
|
```
|
||||||
:command! -nargs=1 Hello echo "Hello " . <args>
|
:command! -nargs=1 Hola echo "Hola " . <args>
|
||||||
:Hello "Iggy"
|
:Hola "Iggy"
|
||||||
" returns 'Hello Iggy'
|
" devuelve 'Hola Iggy'
|
||||||
|
|
||||||
:Hello Iggy
|
:Hola Iggy
|
||||||
" Undefined variable error
|
" Da un error de que la variable no ha sido definida.
|
||||||
```
|
```
|
||||||
|
|
||||||
Using `q-args`:
|
Usando `q-args`:
|
||||||
|
|
||||||
```
|
```
|
||||||
:command! -nargs=1 Hello echo "Hello " . <q-args>
|
:command! -nargs=1 Hola echo "Hola " . <q-args>
|
||||||
:Hello Iggy
|
:Hola Iggy
|
||||||
" returns 'Hello Iggy'
|
" Devuelve 'Hola Iggy'
|
||||||
```
|
```
|
||||||
|
|
||||||
Using `f-args`:
|
Usando `f-args`:
|
||||||
|
|
||||||
```
|
```
|
||||||
:function! PrintHello(person1, person2)
|
:function! PrintHola(persona1, persona2)
|
||||||
: echo "Hello " . a:person1 . " and " . a:person2
|
: echo "Hola " . a:persona1 . " y " . a:persona2
|
||||||
:endfunction
|
:endfunction
|
||||||
|
|
||||||
:command! -nargs=* Hello call PrintHello(<f-args>)
|
:command! -nargs=* Hola call PrintHola(<f-args>)
|
||||||
|
|
||||||
:Hello Iggy1 Iggy2
|
:Hello Iggy1 Iggy2
|
||||||
" returns "Hello Iggy1 and Iggy2"
|
" Devuelve "Hola Iggy1 and Iggy2"
|
||||||
```
|
```
|
||||||
|
|
||||||
The functions above will make a lot more sense once you get to the Vimscript functions chapter.
|
La función de arriba va a tener mucho mas sentido una vez que llegues al capítulo de las funciones Vimscripts.
|
||||||
|
|
||||||
To learn more about command and args, check out `:h command` and `:args`.
|
Para aprender más acerca de los comandos y argumentos, consulte `:h command` y `:args`.
|
||||||
|
|
||||||
### Maps
|
### Mapeos
|
||||||
|
|
||||||
If you find yourself repeatedly performing the same complex task, it is a good indicator that you should create a mapping for that task.
|
Si te vez a ti mismo haciendo de manera repetitiva la misma tarea compleja, este es un buen indicador para querer crear un mapeo para esta tarea.
|
||||||
|
|
||||||
For example, I have these two mappings in my vimrc:
|
Por ejemplo, tenemos estos dos mapeos en el archivo vimrc:
|
||||||
|
|
||||||
```
|
```
|
||||||
nnoremap <silent> <C-f> :GFiles<CR>
|
nnoremap <silent> <C-f> :GFiles<CR>
|
||||||
|
@ -184,70 +186,71 @@ nnoremap <silent> <C-f> :GFiles<CR>
|
||||||
nnoremap <Leader>tn :call ToggleNumber()<CR>
|
nnoremap <Leader>tn :call ToggleNumber()<CR>
|
||||||
```
|
```
|
||||||
|
|
||||||
On the first one, I map `Ctrl-F` to [fzf.vim](https://github.com/junegunn/fzf.vim) plugin's `:Gfiles` command (quickly search for Git files). On the second one, I map `<Leader>tn` to call a custom function `ToggleNumber` (toggles `norelativenumber` and `relativenumber` options). The `Ctrl-F` mapping overwrites Vim's native page scroll. Your mapping will overwrite Vim controls if they collide. Because I almost never used that feature, I decided that it is safe to overwrite it.
|
En el primero, se mapea la combinacion de teclas `Ctrl-F` para el plugin [fzf.vim](https://github.com/junegunn/fzf.vim) al comando `:Gfiles` (que busca rapidamente por archivos en un repositorio git). En el segundo, se mapea la combinación `<Leader>tn` para llamar a la función personalizada `ToggleNumber` (que cambia entre si las opciones `norelativenumber` y `relativenumber`). La combinación `Ctrl-F` mapea y sobreescribe la función nativa de Vim para moverse en la pantall. El mapeo va a sobreescribir los controles de Vim si entran en conflicto. En mi caso, como nunca uso esta característica, he decidido que es conveniente sobreescribirla.
|
||||||
|
|
||||||
By the way, I personally like to use `<Space>` as the leader key instead of Vim's default. To change your leader key, add this in your vimrc:
|
Por otro lado, a mi personalmente me gusta usar la tecla espaciadora que se escribe como `<Space>` como mi tecla para llamar a estos mapeos, conocida como "leader key" en inglés, para usarla, agregar esto en el archivo vimrc:
|
||||||
|
|
||||||
```
|
```
|
||||||
let mapleader = "\<space>"
|
let mapleader = "\<space>"
|
||||||
```
|
```
|
||||||
|
|
||||||
The `nnoremap` command used above can be broken down into three parts:
|
El comando `nnoremap` command usado anteriormente puede descomponerse en tres partes:
|
||||||
- `map` is the map command.
|
- `map` es el nombre del comando para mapear.
|
||||||
- `n` represents the normal mode.
|
- `n` representa el modo normal.
|
||||||
- `nore` means non-recursive.
|
- `nore` quiere decir no-recursivo.
|
||||||
|
|
||||||
At minimum, you could have used `nmap` instead of `nnoremap` (`nmap <silent> <C-f> :Gfiles<CR>`). However, it is a good practice to use the non-recursive variant to avoid potential infinite loop.
|
Como mínimo, se podría haber usado `nmap` en vez de `nnoremap` (`nmap <silent> <C-f> :Gfiles<CR>`). Igualmente, es una buena práctica el usar la variante que no es recursiva para prevenir potenciales loops infinitos al ejecutar el comando.
|
||||||
|
|
||||||
Here's what could happen if you don't map non-recursively. Suppose you want to add a mapping to `B` to add a semi-colon at the end of the line, then go back one WORD (recall that `B` n Vim is a normal-mode navigation key to go backward one WORD).
|
Esto es lo que podria haber pasado si no se usa el mapeo no recursivo. Supongamos que se quiere agregar el mapeo `B` para agregar el punto y coma (;) al final de la linea, luego, volver una palabra hacia atrás (rellamamos a `B`que en el modo normal vuelve para atrás una palabra tal como necesitamos).
|
||||||
|
|
||||||
```
|
```
|
||||||
nmap B A;<esc>B
|
nmap B A;<esc>B
|
||||||
```
|
```
|
||||||
|
|
||||||
When you press `B`... oh no! Vim adds `;` uncontrollably (interrupt it with `Ctrl-C`). Why did that happen? Because in the mapping `A;<esc>B`, the `B` does not refer to Vim's native `B` function (go back one WORD), but it refers to the mapped function. What you have is actually this:
|
Cuando se presiona `B` ... ouch! Vim agrega de manera descontrolada `;` (se puede interrumpir presionando `Ctrl-C`). ¿Porque pasó esto? Porque en el mapeo `A;<esc>B`, la letra `B` no hace referencia a la función nativa de Vim que es volver una palabra hacia atrás, porque se esta refiriendo a la función mapeada que actualmente es:
|
||||||
|
|
||||||
```
|
```
|
||||||
A;<esc>A;<esc>A;<esc>A;esc>...
|
A;<esc>A;<esc>A;<esc>A;esc>...
|
||||||
```
|
```
|
||||||
|
|
||||||
To solve this problem, you need to add a non-recursive map:
|
Para resolver este problema, se tiene que agregar la opción para que no sea recursivo:
|
||||||
|
|
||||||
```
|
```
|
||||||
nnoremap B A;<esc>B
|
nnoremap B A;<esc>B
|
||||||
```
|
```
|
||||||
|
|
||||||
Now try calling `B` again. This time it successfully adds a `;` at the end of the line and go back one WORD. The `B` in this mapping represents Vim's original `B` functionality.
|
Ahora, intente llamar a `B`. Esta vez si va a agregar al final de la linea `;` y volver una palabra antes. El `B` en este mapeo representa al mapeo original de Vim al llamar a la función `B`.
|
||||||
|
|
||||||
|
Vim tiene diferentes mapeos para diferentes modos. Si quiere crear un mapeo para el modo de insersión para salir del mismo cuando presiona `jk`:
|
||||||
|
|
||||||
Vim has different maps for different modes. If you want to create a map for insert mode to exit insert mode when you press `jk`:
|
|
||||||
|
|
||||||
```
|
```
|
||||||
inoremap jk <esc>
|
inoremap jk <esc>
|
||||||
```
|
```
|
||||||
|
|
||||||
The other map modes are: `map` (Normal, Visual, Select, and Operator-pending), `vmap` (Visual and Select), `smap` (Select), `xmap` (Visual), `omap` (Operator-pending), `map!` (Insert and Command-line), `lmap` (Insert, Command-line, Lang-arg), `cmap` (Command-line), and `tmap` (terminal-job). I won't cover them in detail. To learn more, check out `:h map.txt`.
|
Los otros modos son: `map` (Normal, Visual, Select, and Operator-pending), `vmap` (Visual y Select), `smap` (Select), `xmap` (Visual), `omap` (Operator-pending), `map!` (Insert y Command-line), `lmap` (Insert, Command-line, Lang-arg), `cmap` (Command-line), and `tmap` (terminal-job). No vamos a cubrirlos en detalle. Para aprender más de ellos ejecute `:h map.txt`.
|
||||||
|
|
||||||
Create a map that's most intuitive, consistent, and easy-to-remember.
|
Cree un mapeo que sea lo más intuitivo, consistente y fácil de recordar.
|
||||||
|
|
||||||
## Organizing Vimrc
|
## Organizando Vimrc
|
||||||
|
|
||||||
Over time, your vimrc will grow large and become convoluted. There are two ways to keep your vimrc to look clean:
|
A travéz del tiempo, tu vimrc va a crecer y se va a volver confuso. Hay varias maneras de mantener tu vimrc y que se vea limpio:
|
||||||
- Split your vimrc into several files.
|
- Separar el archivo vimrc en varios archivos.
|
||||||
- Fold your vimrc file.
|
- Plegando tu archivo vimrc.
|
||||||
|
|
||||||
### Splitting Your Vimrc
|
### Separando tu vimrc
|
||||||
|
|
||||||
You can split your vimrc to multiple files using Vim's `source` command. This command reads command-line commands from the given file argument.
|
Puedes separar tu vimrc en multiples archivos usando el comando de Vim `source`. Este comando lee los comandos que hay en el archivo utilizado como argumento.
|
||||||
|
|
||||||
Let's create a file inside the `~/.vim` directory and name it `/settings` (`~/.vim/settings`). The name itself is arbitrary and you can name it whatever you like.
|
Vamos a crear dentro del la carpeta `~/.vim`y vamos a llamarla `/settings` (`~/.vim/settings`). El nombre en sí es arbitrario y lo puedes llamar como quieras.
|
||||||
|
|
||||||
You are going to split it into four components:
|
Lo vamos a separar en 4 componentes:
|
||||||
- Third-party plugins (`~/.vim/settings/plugins.vim`).
|
- Componentes de terceros (plugins) (`~/.vim/settings/plugins.vim`).
|
||||||
- General settings (`~/.vim/settings/configs.vim`).
|
- Configuraciones Generales (`~/.vim/settings/configs.vim`).
|
||||||
- Custom functions (`~/.vim/settings/functions.vim`).
|
- Funciones Personalizadas (`~/.vim/settings/functions.vim`).
|
||||||
- Key mappings (`~/.vim/settings/mappings.vim`) .
|
- Mapeos de teclado (`~/.vim/settings/mappings.vim`) .
|
||||||
|
|
||||||
Inside `~/.vimrc`:
|
Dentro del archivo `~/.vimrc`:
|
||||||
|
|
||||||
```
|
```
|
||||||
source $HOME/.vim/settings/plugins.vim
|
source $HOME/.vim/settings/plugins.vim
|
||||||
|
@ -256,7 +259,7 @@ source $HOME/.vim/settings/functions.vim
|
||||||
source $HOME/.vim/settings/mappings.vim
|
source $HOME/.vim/settings/mappings.vim
|
||||||
```
|
```
|
||||||
|
|
||||||
Inside `~/.vim/settings/plugins.vim`:
|
Dentro del archivo `~/.vim/settings/plugins.vim`:
|
||||||
|
|
||||||
```
|
```
|
||||||
call plug#begin('~/.vim/plugged')
|
call plug#begin('~/.vim/plugged')
|
||||||
|
@ -265,7 +268,7 @@ call plug#begin('~/.vim/plugged')
|
||||||
call plug#end()
|
call plug#end()
|
||||||
```
|
```
|
||||||
|
|
||||||
Inside `~/.vim/settings/configs.vim`:
|
Dentro del archivo `~/.vim/settings/configs.vim`:
|
||||||
|
|
||||||
```
|
```
|
||||||
set nocompatible
|
set nocompatible
|
||||||
|
@ -273,7 +276,7 @@ set relativenumber
|
||||||
set number
|
set number
|
||||||
```
|
```
|
||||||
|
|
||||||
Inside `~/.vim/settings/functions.vim`:
|
Dentro del archivo `~/.vim/settings/functions.vim`:
|
||||||
|
|
||||||
```
|
```
|
||||||
function! ToggleNumber()
|
function! ToggleNumber()
|
||||||
|
@ -285,7 +288,7 @@ function! ToggleNumber()
|
||||||
endfunc
|
endfunc
|
||||||
```
|
```
|
||||||
|
|
||||||
Inside `~/.vim/settings/mappings.vim`:
|
Dentro del archivo `~/.vim/settings/mappings.vim`:
|
||||||
|
|
||||||
```
|
```
|
||||||
inoremap jk <esc>
|
inoremap jk <esc>
|
||||||
|
@ -293,13 +296,13 @@ nnoremap <silent> <C-f> :GFiles<CR>
|
||||||
nnoremap <Leader>tn :call ToggleNumber()<CR>
|
nnoremap <Leader>tn :call ToggleNumber()<CR>
|
||||||
```
|
```
|
||||||
|
|
||||||
Your vimrc should works as usual, but now it is only four lines long!
|
Tu archivo vimrc va a lucir como siempre, ¡pero ahora solo tiene 4 lineas de largo!
|
||||||
|
|
||||||
With this setup, you easily know where to go. If you need to add more mappings, add them to the `/mappings.vim` file. In the future, you can always add more directories as your vimrc grows. For example, if you need to create a setting for your colorschemes, you can add a `~/.vim/settings/themes.vim`.
|
Con esta configuración, facilmente ahora vez a donde hay que ir. Si necesita agregar mapeos, agregarlos en el archivo `/mappings.vim`. En el futuro, siempre se peude agregar mas directorios mientras el archivo vimrc crece. Por ejemplo si se necesita crear una configuracion para el color del tema, se puede agregar al archivo `~/.vim/settings/themes.vim`.
|
||||||
|
|
||||||
### Keeping One Vimrc File
|
### Manteniendo un solo archivo Vimrc
|
||||||
|
|
||||||
If you prefer to keep one vimrc file to keep it portable, you can use the marker folds to keep it organized. Add this at the top of your vimrc:
|
Si la preferencia es tener un solo archivo vimrc para que sea portable, se puede usar el plegado para mantener todo organizado. Agregue esto al inicio de su archivo vimrc:
|
||||||
|
|
||||||
```
|
```
|
||||||
" setup folds {{{
|
" setup folds {{{
|
||||||
|
@ -310,32 +313,32 @@ augroup END
|
||||||
" }}}
|
" }}}
|
||||||
```
|
```
|
||||||
|
|
||||||
Vim can detect what kind of filetype the current buffer has (`:set filetype?`). If it is a `vim` filetype, you can use a marker fold method. Recall that a marker fold uses `{{{` and `}}}` to indicate the starting and ending folds.
|
Vim puede detectar que tipo de archivo hay en el buffer actual (con `:set filetype?` puede comprobarlo). Si este es un archivo del tipo `vim`, se puede usar el método de plegado. El metodo de plegado utiliza `{{{` y `}}}` para indicar el inicio y el final de un grupo que se esta plegando.
|
||||||
|
|
||||||
Add `{{{` and `}}}` folds to the rest of your vimrc (don't forget to comment them with `"`):
|
Agregue `{{{` y `}}}` para plegar al resto de su vimrc (no se olvide de comentar estas lineas con `"`):
|
||||||
|
|
||||||
```
|
```
|
||||||
" setup folds {{{
|
" Configuracion de Plegado {{{
|
||||||
augroup filetype_vim
|
augroup filetype_vim
|
||||||
autocmd!
|
autocmd!
|
||||||
autocmd FileType vim setlocal foldmethod=marker
|
autocmd FileType vim setlocal foldmethod=marker
|
||||||
augroup END
|
augroup END
|
||||||
" }}}
|
" }}}
|
||||||
|
|
||||||
" plugins {{{
|
" Complementos {{{
|
||||||
call plug#begin('~/.vim/plugged')
|
call plug#begin('~/.vim/plugged')
|
||||||
Plug 'mattn/emmet-vim'
|
Plug 'mattn/emmet-vim'
|
||||||
Plug 'preservim/nerdtree'
|
Plug 'preservim/nerdtree'
|
||||||
call plug#end()
|
call plug#end()
|
||||||
" }}}
|
" }}}
|
||||||
|
|
||||||
" configs {{{
|
" Configuraciones {{{
|
||||||
set nocompatible
|
set nocompatible
|
||||||
set relativenumber
|
set relativenumber
|
||||||
set number
|
set number
|
||||||
" }}}
|
" }}}
|
||||||
|
|
||||||
" functions {{{
|
" Funciones {{{
|
||||||
function! ToggleNumber()
|
function! ToggleNumber()
|
||||||
if(&relativenumber == 1)
|
if(&relativenumber == 1)
|
||||||
set norelativenumber
|
set norelativenumber
|
||||||
|
@ -345,7 +348,7 @@ function! ToggleNumber()
|
||||||
endfunc
|
endfunc
|
||||||
" }}}
|
" }}}
|
||||||
|
|
||||||
" mappings {{{
|
" Mapeos {{{
|
||||||
inoremap jk <esc>
|
inoremap jk <esc>
|
||||||
nnoremap <silent> <C-f> :GFiles<CR>
|
nnoremap <silent> <C-f> :GFiles<CR>
|
||||||
nnoremap <Leader>tn :call ToggleNumber()<CR>
|
nnoremap <Leader>tn :call ToggleNumber()<CR>
|
||||||
|
@ -355,43 +358,44 @@ nnoremap <Leader>tn :call ToggleNumber()<CR>
|
||||||
Your vimrc should look like this:
|
Your vimrc should look like this:
|
||||||
|
|
||||||
```
|
```
|
||||||
+-- 6 lines: setup folds -----
|
+-- 6 lines: Configuracion de Plegado -----
|
||||||
|
|
||||||
+-- 6 lines: plugins ---------
|
+-- 6 lines: Complementos ---------
|
||||||
|
|
||||||
+-- 5 lines: configs ---------
|
+-- 5 lines: Configuraciones ---------
|
||||||
|
|
||||||
+-- 9 ilnes: functions -------
|
+-- 9 ilnes: Funciones -------
|
||||||
|
|
||||||
+-- 5 lines: mappings --------
|
+-- 5 lines: Mapeos --------
|
||||||
```
|
```
|
||||||
|
|
||||||
## Running Vim With Or Without Vimrc And Plugins
|
## Correr Vim con o sin Vimrc y Complementos
|
||||||
|
|
||||||
If you need to run Vim without both vimrc and plugins, run:
|
Si necesita correr Vim sin vimrc y los complementos, ejecute:
|
||||||
|
|
||||||
```
|
```
|
||||||
vim -u NONE
|
vim -u NONE
|
||||||
```
|
```
|
||||||
|
|
||||||
If you need to launch Vim without vimrc but with plugins, run:
|
Si necesita iniciar Vim sin vimrc pero si con complementos, ejecute:
|
||||||
|
|
||||||
```
|
```
|
||||||
vim -u NORC
|
vim -u NORC
|
||||||
```
|
```
|
||||||
|
|
||||||
If you need to run Vim with vimrc but without plugins, run:
|
Si quiere correr Vim con vimrc pero sin complementos:
|
||||||
|
|
||||||
```
|
```
|
||||||
vim --noplugin
|
vim --noplugin
|
||||||
```
|
```
|
||||||
|
|
||||||
If you need to run Vim with a *different* vimrc, say `~/.vimrc-backup`, run:
|
Si lo que necesita es correr vim con un vimrc *diferente*, digamos `~/.vimrc-backup`, ejecute:
|
||||||
|
|
||||||
```
|
```
|
||||||
vim -u ~/.vimrc-backup
|
vim -u ~/.vimrc-backup
|
||||||
```
|
```
|
||||||
|
|
||||||
## Configure Vimrc The Smart Way
|
## Configure Vimrc - La Manera Inteligente
|
||||||
|
|
||||||
Vimrc is an important component of Vim customization. A good way to start building your vimrc is by reading other people's vimrcs and gradually build it over time. The best vimrc is not the one that developer X uses, but the one that is tailored exactly to fit your thinking framework and editing style.
|
|
||||||
|
Vimrc es un componente importante de la configuración de Vim. Una buena manera de empezar a crear su vimrc es leyendo los vimrcs de otras personas y de manera gradual ir creando el suyo a travéz del tiempo. El mejor vimrc no es el que usa el desarrollador X, es el que esta configurado de la manera que mejor encaja a su pensamiento y a su forma personal de editar.
|
||||||
|
|
Loading…
Reference in a new issue