blog/content/software/nvim-fr.md

318 lines
16 KiB
Markdown
Raw Normal View History

2023-05-13 12:48:47 +00:00
---
Title: Quelques pointeurs pour ViM
Date: 2023-05-13 11:00
2023-05-13 15:59:37 +00:00
Modified: 2023-05-13 18:00
2023-05-13 12:48:47 +00:00
Lang: fr
Author: Fabrice
Category: programmes
Tags: vim, neovim
Slug: nvim
Header_Cover: ../images/covers/hand-fan.jpg
2023-05-13 15:59:37 +00:00
Summary: Des informations que jaurais bien aimé connaître plus tôt dans (neo)vim.
2023-05-13 12:48:47 +00:00
---
[neovim](https://neovim.org/) est un éditeur de texte modal, héritier direct de
[vim](https://www.vim.org) lui-même issu de
[vi](https://ex-vi.sourceforge.net/).
Cette famille déditeurs est assez répandue, et au moment de rechercher un
éditeur de texte, on peut se retrouver face à des choix comme
[ViM vs Emacs](https://fr.wikipedia.org/wiki/Guerre_d%27%C3%A9diteurs).
Trolls mis à part, il savère que jutilise vim/neovim comme éditeur de texte au
quotidien pour éditer du code, [écrire certains
e-mails]({filename}../tips/emails-md-fr.md), prendre des notes, écrire ce blog…
2023-05-13 15:59:37 +00:00
Cependant, si vous êtes un vimiste convaincu ou simplement intéressés par la
2023-05-13 12:48:47 +00:00
question et avez essayé, vous vous serez sans doute rendu compte que la courbe
2023-05-13 15:59:37 +00:00
dapprentissage nest pas des plus douce, et quil est parfois compliqué de
trouver linformation que lon cherche… notamment si on ignore quelle existe.
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
À ce sujet, je ne peux que recommander les rencontres avec dautres usagers,
2023-05-13 12:48:47 +00:00
comme par exemple aux [tuppervim](https://tuppervim.org).
2023-05-13 15:59:37 +00:00
Ces rencontres sont loccasion de partager et de découvrir des informations
2023-05-13 12:48:47 +00:00
autour de ViM afin de les intégrer __progressivement__ à son flot de travail.
2023-05-13 15:59:37 +00:00
Malheureusement, cette solution nest pas forcément des plus pratiques pour
2023-05-13 12:48:47 +00:00
tous: les rencontres ont lieues à Paris/Lyon/Grenoble, ce qui les rendent
2023-05-13 15:59:37 +00:00
difficile daccès pour le sud-ouest de la France… voire pour les personnes en
2023-05-13 12:48:47 +00:00
dehors de la France métropolitaine.
2023-05-13 15:59:37 +00:00
Ainsi, même si comme la [documentation ViM](https://www.vim.org/docs.php) qui
regroupe toutes les informations dont on pourrait avoir besoin, il existe des
[archives des rencontres précédentes](https://tuppervim.org/archives.html).
On se perd cependant très vite au milieu de cette jungle de conseils.
Ces archives sont plutôt pratiques pour les personnes ayant déjà assisté à une
des réunions et qui cherche à retrouver un point particulier.
2023-05-13 12:48:47 +00:00
Ainsi je vais essayer de compiler quelques astuces et conseils que je pense être
2023-05-13 15:59:37 +00:00
intéressants et que jaurais bien aimé découvrir plus tôt par moments…
2023-05-13 12:48:47 +00:00
Pour rappeler quelques principes de base du [cheminement vers la
2023-05-13 15:59:37 +00:00
sagesse](https://fabi1cazenave.github.io/slides/2017-vim-ducklings/0-survive.html):
nessayez pas de tout intégrer dun coup: cest un coup à se décourager.
2023-05-13 12:48:47 +00:00
Dautant plus que vim est avant tout un couteau-suisse, ainsi on ne va pas
2023-05-13 15:59:37 +00:00
utiliser la lime à ongle pour couper du fromage : ça peut fonctionner mais cest
pas très pratique.
2023-05-13 12:48:47 +00:00
Toutes les commandes et techniques ne se valent donc pas suivant lusage de ViM
que lon a.
2023-05-13 15:59:37 +00:00
Ce billet nest donc pas un cours pour apprendre à utiliser vim, mais simplement
2023-05-13 12:48:47 +00:00
quelques astuces pour des personnes qui utilisent vim régulièrement sans pour
autant vouloir devenir des _vim-wizards_ et qui pourraient ignorer certains
conseils qui améliorent la qualité de vie sans relever de l'ésotérisme.
2023-05-13 15:59:37 +00:00
Je ne vais dailleurs pas aborder le point des modules en détails et essayer de
rester le plus agnostique possible.
2023-05-13 12:48:47 +00:00
Néanmoins, comme ce billet ne sadresse pas nécessairement à des personnes qui
découvriraient Vim, si je me mets à jargonner de manière incompréhensible et que
vous trouvez cela dérangeant dans la lecture, merci de me le signaler (par mail,
2023-05-13 15:59:37 +00:00
irc, autre).
2023-05-13 12:48:47 +00:00
# Parler à son éditeur
2023-05-13 15:59:37 +00:00
Lorsque jai découvert vim, comme indiqué dans la première phrase de ce billet,
ce qui ma marqué est le mot « **modal** ».
2023-05-13 12:48:47 +00:00
Je pensais quil sagissait de la partie importante dans la description de vim,
2023-05-13 15:59:37 +00:00
et que c'était ce qui le différenciait demacs ou autre.
En effet, lors de lapprentissage de vim, la première réaction naturelle est de
se dire que pouvoir passer dun mode à lautre en une seule touche permet
2023-05-13 12:48:47 +00:00
d'éviter des acrobaties digitales pour appuyer sur trois touches à la fois, qui
ne sont pas toujours bien placées.
2023-05-13 15:59:37 +00:00
Cependant, selon moi, ce qui fait la force de ViM, ce nest pas seulement cette
2023-05-13 12:48:47 +00:00
distinction entre modes qui permet de faire de la sélection visuelle, ou de
2023-05-13 15:59:37 +00:00
naviguer entre ses différents fichiers pour aller exactement où lon souhaite
aller en trois entrées clavier, mais cest la _langue_ de vim.
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
Ainsi, lors de lapprentissage, il est important de comprendre ce quil se
2023-05-13 12:48:47 +00:00
passe.
2023-05-13 15:59:37 +00:00
De la même manière quil ne faut pas copier/coller des lignes de commandes quon
2023-05-13 12:48:47 +00:00
ne comprend pas dans sont terminal, il est impératif de ne pas simplement
2023-05-13 15:59:37 +00:00
apprendre des séquences de commandes dans vim sans comprendre ce quon est en
2023-05-13 12:48:47 +00:00
train de communiquer à son éditeur.
2023-05-13 15:59:37 +00:00
Pour citer une erreur de jeunesse, lorsque jai appris à utiliser vim, jai lu
2023-05-13 12:48:47 +00:00
quelque part sur internet que `gqap` en mode normal permettait de reformater un
bloc de texte.
Je ne comprenais pas exactement ce que «bloc» signifiait, mais ça fonctionnait
globalement, et les modificateurs de répétition (par exemple `3gqap`) ont le
comportement attendu.
2023-05-13 15:59:37 +00:00
Cependant, ce défaut dabstraction fait dune part que jai appris plus de
2023-05-13 12:48:47 +00:00
commandes par cœur que nécessaire, par exemple `dap` et `yap` construites sur le
même principe, là où simplement savoir ce que signifie la commande aurait été un
gain de place en mémoire, et fait gagner en flexibilité.
Pour cela il existe pas mal de tutoriels:
* [Learn Vim For the Last Time: A Tutorial and Primer](https://danielmiessler.com/study/vim/#language)
* [Learning Vim in 2014: Vim as Language](https://benmccormick.org/2014/07/02/062700.html)
2023-05-13 15:59:37 +00:00
Mais pour faire simple, et ce que jaurais bien aimé quon me dise à mes débuts
2023-05-13 12:48:47 +00:00
(mais bon, après faut lire de la documentation rébarbative en anglais, et
c'était pas très facile pour moi à lépoque), cest quune commande vim est en
fait… une phrase.
On demande une action (par exemple `=` qui signifie «indenter»), on donne un
champ daction (`ap` qui signifie «autour du paragraphe», où un paragraphe est
défini comme un bloc séparé par au moins deux retours chariots avant et après).
2023-05-13 15:59:37 +00:00
Et là encore ce champ daction peut être modifié, ainsi le `a` de `ap` signifie
2023-05-13 12:48:47 +00:00
_around_ (autour), et peut-être remplacé par `i` pour `inside`.
Pour les paragraphes, cela signifie prendre en compte ou non les lignes vides
autour de ce dernier, mais pour des parenthèses, cela peut-être plus
intéressant.
2023-05-13 15:59:37 +00:00
Ainsi `ri(` permet de réécrire le contenu dune parenthèse, ce qui peut être
utiles pour remplacer les arguments dune fonction, là où `ra(` va aussi effacer
2023-05-13 12:48:47 +00:00
les parenthèses lors de la réécriture.
Si vous n'êtes pas certain de ce que vous faites, il peut être intéressant de se
2023-05-13 15:59:37 +00:00
placer en mode visuel (`v`) pour voir et assimiler ce quil se passe.
Cest un peu comme mettre des sous-titres pour être sûr de comprendre ce qu'il
se dit.
2023-05-13 12:48:47 +00:00
# Le mode visuel
2023-05-13 15:59:37 +00:00
Parlons de ce mode visuel dailleurs.
2023-05-13 12:48:47 +00:00
Comme beaucoup dutilisateur Linux, jai été formaté pour trouver que tout ce
2023-05-13 15:59:37 +00:00
qui se fait simplement en ligne de commande est beaucoup plus pur/élégant que de
devoir faire treize clics pour arriver au même résultat.
2023-05-13 12:48:47 +00:00
Or comme tout dogmatisme, il révèle parfois ses limites et pousse à
lobstination là où ça na pas forcément lieu dêtre.
Une des conséquences perverse de cette préconception est davoir ignoré le mode
visuel, ou alors essayer de trouver de manière de men passer par moments alors
2023-05-13 15:59:37 +00:00
quil permet de faire les choses avec un retour visuel qui permet de limiter les
2023-05-13 12:48:47 +00:00
erreurs.
Et de manière similaire à la frappe au clavier, la précision est plus importante
que la vitesse: on perd beaucoup plus de temps et dénergie à corriger une
2023-05-13 15:59:37 +00:00
faute que davoir pris quelques instants de plus pour garantir le résultat… sans
2023-05-13 12:48:47 +00:00
parler de la frustration induite.
## Changer la position du curseur visuel
Il peut arriver de sélectionner un paragraphe, avec `vip` par exemple, et de se
rendre compte quon aurait bien aussi pris la ligne précédente, qui peut-être un
titre par exemple.
Or, `vip` va placer le curseur permettant d'éditer la zone de sélection
visuelle (par exemple avec `}` pour sélectionner en plus le paragraphe suivant)
à la fin de la sélection.
Pour alterner la position du curseur du début à la fin, il suffit dune simple
pression sur la touche `o`.
## Incrémenter une colonne de nombres
2023-05-13 15:59:37 +00:00
Si lon souhaite créer une colonne de nombres (par exemple pour une énumération)
comme ceci:
2023-05-13 12:48:47 +00:00
```
1
2
3
4
5
6
7
8
9
10
```
Une technique consiste à insérer 10 fois 0: `10i0<Enter><Esc>`, supprimer la
ligne surnuméraire `dd`, rentrer en mode visuel `v`, sélectionner le bloc (sil
2023-05-13 15:59:37 +00:00
est précédé dune ligne vide ou dun début de fichier): `ip`, et incrémenter de
2023-05-13 12:48:47 +00:00
manière globale `g<Ctrl+a>`.
## Utiliser le mode visuel pour limiter certaines actions
2023-05-13 15:59:37 +00:00
On est parfois tenté de lancer de gros remplacements par expressions régulières
sur son fichier, mais on est pas toujours sûr de ce quon fait.
Lorsquon se met en mode ligne de commande sous vim pour effectuer un
2023-05-13 12:48:47 +00:00
[remplacement](https://www.gnu.org/software/sed/manual/sed.html) par exemple,
cela va commencer la ligne par `'<,'>`, qui indique que laction se déroulera
entre les marques `<` et `>` qui représentent le début et la fin de la sélection
visuelle.
2023-05-13 15:59:37 +00:00
Cest ainsi possible de faire des tests pour vérifier si lexpression régulière
fait bien ce qui est attendu delle sur un petit exemple avant de passer à
2023-05-13 12:48:47 +00:00
l'échelle.
Bien entendu, je ne recommande pas cette méthode, principalement parce
quaujourdhui il existe dautres méthodes pour faire du remplacement de masse.
2023-05-13 15:59:37 +00:00
Par exemple, une des raisons qui peut pousser à cela, est le renommage dune
2023-05-13 12:48:47 +00:00
variable dans un programme.
Désormais, il est possible de faire appel au « _language-server protocol_ » (LSP) pour
faire cela:
* [<tt>vim.lsp.buf.rename()</tt>](https://neovim.io/doc/user/lsp.html#vim.lsp.buf.rename())
# Ranger sa configuration
Un autre point que je trouve important et que jai découvert un peu tard est la
structure des dossier `.config/{n,}vim/`.
2023-05-13 15:59:37 +00:00
Jai en effet passé mes premières années avec un seul `.vimrc` avant de
létendre avec dautres fichiers que je changeais (`source`) par la suite.
2023-05-13 12:48:47 +00:00
Or, le dossier `$VIMHOME` est rangé de manière sémantique:
* [Vim Directory Structure](http://www.panozzaj.com/blog/2011/09/09/vim-directory-structure/)
* [Plugin Layout in the Dark Ages](https://learnvimscriptthehardway.stevelosh.com/chapters/42.html)
2023-05-13 15:59:37 +00:00
Nutilisant pas toute la structure, je vais me concentrer ici sur mon usage:
2023-05-13 12:48:47 +00:00
les dossiers `ftplugin` et `plugin`.
Pour faire simple, le contenu de `plugin/*.{vim,lua}` sera automatiquement
chargé au démarrage, et le contenu de `ftplugin/$FT.{vim,lua}` sera chargé
lorsque vous ouvrez un fichier reconnu comme `$FT` par son
[type de fichier](https://vimdoc.sourceforge.net/htmldoc/filetype.html).
Ainsi, en ayant un fichier `ftplugin/pandoc.lua` avec le paramétrage de
2023-05-13 15:59:37 +00:00
[vim-pandoc-syntax](https://github.com/vim-pandoc/vim-pandoc-syntax) et mes
[raccourcis pour pandoc]({filename}../tips/emails-md-fr.md) pour écrire
ce billet.
Par la suite, il est plus facile de l'éditer et de retrouver la signification
des différentes lignes grâce au système de fichier.
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
De manière similaire, je sais que `plugin/bepo.lua` décrit mon réarrangement
partiel des raccourcis Vim pour le [bépo](https://bepo.fr/).
2023-05-13 12:48:47 +00:00
# La navigation
2023-05-13 15:59:37 +00:00
Un autre point important, est la navigation dans vos projets.
En effet, à partir dun moment, avoir un seul fichier pour tout devient
irréaliste quel que soit le projet, et il convient de savoir naviguer rapidement
entre différents emplacements dans le fichier.
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
Par soucis de généralité, je vais, dans la suite, ignorer les actions de
navigations spécifiques à certains plugins comme LSP.
2023-05-13 12:48:47 +00:00
## Sauter de fichier en fichier
2023-05-13 15:59:37 +00:00
Pour prendre un exemple de ma vie courante, jutilise souvent LaTeX pour générer
des documents.
Lorsque ces documents commencent à prendre de la place (par exemple un
[manuscrit de thèse](https://git.epheme.re/fmouhart/Manuscrit)) et quils sont
séparés en plusieurs fichiers, on inclut les sous-fichiers à laide de la macro
`\include{filename}`.
2023-05-13 12:48:47 +00:00
Pour aller directement à au fichier `filename.tex`, il suffit de placer le
2023-05-13 15:59:37 +00:00
curseur au dessus et dutiliser la commande `gf` (_go file_ pour le mnémonique,
même si en terme de langue vim cest pas exactement ça, cest une approximation
2023-05-13 12:48:47 +00:00
suffisante).
Bien entendu cette commande peut sétendre :
[`<ctrl-w>gf`](https://vimdoc.sourceforge.net/htmldoc/windows.html#CTRL-W_gf)
2023-05-13 15:59:37 +00:00
permet de louvrir dans un [nouvel
2023-05-13 12:48:47 +00:00
onglet](https://vim.fandom.com/wiki/Using_tab_pages).
Et cela fonctionne aussi pour les en-têtes en C par exemple ou dans nimporte
quel situation où un chemin vers un fichier existe dans le fichier ouvert.
## Lhistorique de navigation
Si vous avez effectué la commande précédente (`gf`), pour revenir sur vos pas,
il existe la commande `<Ctrl-o>` qui permet de revenir en arrière dans
2023-05-13 15:59:37 +00:00
l[historique de
2023-05-13 12:48:47 +00:00
sauts](https://vimdoc.sourceforge.net/htmldoc/motion.html#jumplist), que vous
2023-05-13 15:59:37 +00:00
pouvez visualiser à laide de la commande `jumps`.
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
Vous pouvez aussi revenir en avant à laide de la commande `<Ctrl-i>`.
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
Cest aussi pratique pour revenir plus haut après un grand déplacement (par
2023-05-13 12:48:47 +00:00
exemple une recherche avec `/`).
## Repliements
Je ne vais pas rentrer dans les détails des repliements sous vim, surtout que
2023-05-13 15:59:37 +00:00
cest parfois les _plugin_s qui le gèrent, mais apprendre à les ouvrir et les
fermer est potentiellement utile alors je pose ça là:
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
* `zo`/`zc`: ouvrir/fermer dun niveau le repli sous le curseur.
2023-05-13 12:48:47 +00:00
* `zO`/`zC`: ouvrir/fermer complètement le repli sous le curseur.
2023-05-13 15:59:37 +00:00
* `zm`/`zr`: ouvrir/fermer dun niveau tous les replis.
2023-05-13 12:48:47 +00:00
* `zM`/`zR`: ouvrir/fermer complètement tous les replis.
2023-05-13 15:59:37 +00:00
Plus de ressources:
2023-05-13 12:48:47 +00:00
* [Learn Vim the smart way: Folds](https://github.com/iggredible/Learn-Vim/blob/master/ch17_fold.md)
# Le reste en vrac
2023-05-13 15:59:37 +00:00
Quelques autres astuces plus ou moins utiles en vrac qui utilisent ou non des
concepts présentés précédemment:
2023-05-13 12:48:47 +00:00
2023-05-13 15:59:37 +00:00
* `%r)<Ctrl-o>r(`: en se plaçant sur le premier élément dune paire (par exemple
2023-05-13 12:48:47 +00:00
des crochets), permet de les remplacer par des parenthèses. La commande va à
la paire associée avec `%`, remplace par une parenthèse fermante avec `r)`,
revient en arrière avec `<Ctrl-o>` (donc au crochet ouvrant) et remplace par
une parenthèse ouvrante via `r(`.
2023-05-13 15:59:37 +00:00
* `@:`/`@@`: je nai rien dit sur les macros parce que si cest puissant, cest
2023-05-13 12:48:47 +00:00
aussi un moyen simple de faire des erreurs, mais une utilisation un peu
détourné des macros est de remarquer que `@:` permet de relancer la commande
précédente (par exemple un `make`), et ainsi `@@` qui relance la macro
précédente, permet de réeffectuer cette commande à moindre coût.
* `<Ctrl-x><Ctrl-f>`: complète un nom de fichier. Je voulais en dire plus sur la
complétion, mais pour le moment, ma configuration est un peu chaotique à ce
2023-05-13 15:59:37 +00:00
niveau et jai trois plugins qui se battent pour la même fonctionnalité, je
2023-05-13 12:48:47 +00:00
me suis donc passé de cette section pour le moment.
* `:r !<commande système>`: par exemple `:r !date` permet décrire la date
actuelle sur la ligne suivante. De façon plus générale, cela permet décrire
la sortie standard dun programme installé sur votre système.
2023-05-13 13:00:55 +00:00
* Activer
2023-05-13 13:01:32 +00:00
[`undodir`](https://vimdoc.sourceforge.net/htmldoc/options.html#'undodir') et
2023-05-13 13:00:55 +00:00
[`undofile`](https://vimdoc.sourceforge.net/htmldoc/options.html#'undofile')
pour avoir un historique de modification (`u`/`<Ctrl-r>`) par fichier et non
par session. Cela peut être pratique pour pouvoir annuler une modification
sur un fichier de configuration quand on se rend compte trois jours après que
cela ne nous convient pas par exemple.