{{tag>éditeur_de_texte console programmation IDE}}
----
====== Vi IMproved ======
Vim est un [[éditeur de texte]] pour le [[:terminal]] sous [[:gnu|GNU]]/[[:linux|Linux]]. Il a une stabilité exemplaire et ne cesse d'être amélioré. Malgré son austérité, c'est un outil très puissant qui n'a rien à envier aux éditeurs graphiques comme [[:GEdit]], [[:Kate]] ou [[:Mousepad]]. Il est très apprécié des développeurs pour toutes ses fonctions qui en font un très bon IDE (coloration syntaxique de 200 langages, complétion automatique, comparaison de fichiers, recherche évoluée, ...) et est extensible par des scripts.
Contrairement à la plupart des éditeurs, Vim est un éditeur modal((**éditeur modal**: possède différents modes de fonctionnement **commande**, **insertion**)). Selon le mode où vous vous trouvez, les touches auront des actions différentes.
Vim est un "charity-ware" : vous êtes encouragés à faire une donation aux
orphelins d'Ouganda (voyez : ":help uganda").
===== Installation ======
Par défaut, votre système a une version basique de vim, procurée par le paquet **vim-tiny**, mais n'offrant pas toutes les possibilités de cet éditeur.
Commencez par [[:tutoriel:comment_installer_un_paquet|installer le paquet]] **[[apt>vim|vim]]** ou **[[apt>vim-gnome|vim-gnome]]**. Cette version //vim-gnome// a l'avantage de disposer des options pour utiliser le presse-papier (( reportez-vous à l'article [[https://vim-fr.org/index.php/Les_presse-papiers]] pour plus de détails sur les presse-papiers de vim))\\
Si vous souhaitez une interface graphique pour utiliser Vim, reportez-vous à la page **[[:gvim]]**.
//vim-gnome// n'est plus disponible dans les dépôts standard à partir de [[:Jammy]], une alternative peut être [[:neovim]]
===== Utilisation ======
==== Tutoriel ====
L'installation de vim fournit un programme spécifique pour l'apprentissage de vim. Il faut compter environ 30 minutes pour faire le tour de ce tutoriel, mais cela est très utile pour vous familiariser avec les commandes les plus courantes de **vim**.
Pour le lancer il vous suffit d'aller dans un [[:terminal]] et de taper :
vimtutor
(ou pour la version graphique, lancez l'application **gvimtutor** avec la combinaison de touches **ALT + F2** ou dans le terminal)
==== Principe de base ====
Pour [[:tutoriel:comment_modifier_un_fichier|créer ou modifier un fichier]] avec vim il suffit de taper :
vim /chemin/texte
Si le fichier n'existe pas il sera créé à l'enregistrement.
Le fichier s'affiche. Vous êtes dans le **mode commande**((**éditeur modal**: possède différents modes de fonctionnement **commande**, **insertion**)), c'est à dire que vous pouvez déplacer le curseur comme vous le souhaitez avec les touches h,j,k,l ou avec les flèches ←↓↑→ et entrer des commandes pour agir sur le texte. Si vous tapez un nombre avant une commande, elle se répètera d'autant.
Pour accéder au **mode insertion**((**éditeur modal**: possède différents modes de fonctionnement **commande**, **insertion**)) afin de modifier ou d'insérer du texte, il suffit d'appuyer sur « **i** » dans le mode commande. Appuyer sur la touche « **Échap** » pour en sortir et repasser en mode commande.
=== Commandes de base: ===
^ Exemples ^ Action ^
| **i** | Passer dans le **mode insertion** |
| **A** | Ajouter en fin de ligne |
| **:q** | Quitter|
| **:q!** | Quitter sans enregistrer |
| **:w** | Enregistrer le fichier |
| **:wq** | Enregistrer et quitter |
| **:x** | Enregistrer (seulement en cas de modification) et quitter |
| **:set paste** | Passer en mode "collage" |
=== Commandes d'édition: ===
^ Exemples ^ Action ^
| **u** | Annuler la dernière opération |
| **-r** | Rétablir la dernière opération annulée |
| **.** | Répéter la dernière opération d'édition |
| **yy** | Copier la ligne (4**yy** = 4 lignes) |
| **dd** | Couper la ligne (4**dd** = 4 lignes) |
| **p** | Coller après (**P** = insérer avant) |
| **x** | Effacer le caractère |
| **dw** | Effacer le texte jusqu'à la fin du mot |
| **diw** | Effacer le mot sous le curseur |
=== Recherche / remplacement: ===
^ Exemples ^ Action ^
| **/** | Rechercher du texte |
| **n** | Rechercher l'occurence suivante |
| **N** | Rechercher l'occurence précédente |
| **cw** | Remplacer le texte jusqu'à la fin du mot |
| **ciw** | Remplacer le mot |
| **C** | Remplacer jusqu'en fin de ligne |
| **.** | Répéter la dernière opération d'édition |
| **:%s/A/B/g** | Remplacer tous (g) les A par des B |
=== Fenêtrage: ===
^ Exemples ^ Action ^
| **-s** | Diviser horizontalement |
| **-v** | Diviser verticalement |
| **-w** | Passer à la fenêtre suivante |
| **-n** | Ouvrir un fichier vierge dans une nouvelle fenêtre |
| **: tabnew //nom_fichier// ** | Ouvrir le fichier //nom_fichier// dans un onglet |
| **-q** | Fermer la fenêtre |
=== Programmation en C ===
Vim est interfaçable avec CScope, ce qui permet à l'aide d'une simple touche
lors de l'édition d'un fichier source écrit en C:
* d'afficher la définition d'une fonction,
* de trouver les fonction appelées par cette fonction,
* de trouver les fonctions appelant cette fonction
* de trouver/remplacer une chaine de caractères ou un expression régulière
* de trouver les fichiers incluant le header file indiqué sous le curseur
==== Comparaison de fichiers ====
Vous pouvez comparer le contenu de deux fichiers en lançant :
vimdiff fichier1 fichier2
vimdiff peut être remplacé par vim -d\\
Si vous êtes déjà dans vim en édition sur le fichier1:
:vert diffsplit fichier2
si vous ne spécifiez pas //vert//, le "split" sera horizontal (beaucoup moins pratique).\\
Ajoutez
set diffopt=vertical
dans votre fichier //vimrc// pour que ce soit par défaut.
==== Édition hexadécimale ====
vim peut servir d'[[wpfr>éditeur hexadécimal]] (voir aussi hexedit) : après avoir ouvert votre fichier en mode binaire (vim -b), tapez
:%!xxd
pour revenir en édition normale :%!xxd -r
comme pour les autres utilisations (recherche, remplace...), vous pouvez remplacer % par un n° de ligne ou un intervalle
!! Attention à bien éditer et sauvegarder en mode binaire sinon vous risquez de corrompre le fichier avec des auto tab et des conversions de retour à la ligne. vim -b pour lancer en mode binaire, ou :set binary pour activer le mode une fois vim lancé.
==== Correcteur(s) orthographique(s) ====
Si vim est devenu votre éditeur quotidien et que vous y rédigez vos textes en markdown par exemple ou des pages html…, il peut être utile (indispensable !-) de faire appel à un correcteur orthographique.\\
Pour cela :
# pour l'activer :
:set spell
# pour le désactiver :
:set nospell
# qui va sans doute surligner beaucoup de mot… car la correction est évidemment par défaut en anglais,
# pour passer en français :
:setlocal spell spelllang=fr
# le dictionnaire français n'étant pas chargé par défaut, vim va vous proposer de le charger, répondre (Y) pour lancer le télé-chargement
^ Commande ^ Description ^
| z= | sur un mot souligné affiche une liste de corrections possibles |
| zg | rajoute un mot dans le dictionnaire |
| zug | pour annuler l’ajout au dictionnaire |
| ]s | pour aller au prochain mot mal orthographié |
| [s | pour le précédent |
source et compléments : [[https://www.saintcarre.fr/saintcarre/2018/08/correcteur-orthographe-vim.html|le blog de St-Carré]]
==== Terminal ====
Avec la version 8.1, il est possible d'ouvrir une fenêtre //terminal//
:terminal
(le mot abrégé //term// convient), si vous préférez en vertical : :vert term
Pour sortir:
ou «exit»
==== Macro ====
Il est possible d'enregistrer des macros associées à une lettre.\\
Pour démarrer l'enregistrement de la macro, on tape **qx** pour enregistrer la macro dans un registre **x**\\
On saisit ensuite la(les) commande(s) à enregistrer, par exemple un rechercher/remplacer qu'on veut exécuter dans plusieurs fichiers (action qu'on peut aussi faire avec la commande //sed// en [[CLI]])\\
On finit l'enregistrement en tapant **q**\\
Pour lancer une macro, il suffit de taper le caractère //@// suivi de la lettre correspondant au registre, //x// dans notre exemple : **@x**\\
source ((https://vim.fandom.com/wiki/Recording_keys_for_repeated_jobs))
Si vous ne l'utilisez pas et que ça vous gêne, vous pouvez désactiver le raccourci dans votre vimrc en y ajoutant ((https://stackoverflow.com/a/28501574/6614155)) :
map q
===== Configuration =====
Pour modifier le comportement de vim, il faut agir sur son fichier de configuration (chaque utilisateur peut avoir le sien, //root// aussi).\\
Pour cela [[:tutoriel:comment_editer_un_fichier|créez ou éditez le fichier]] **~/.vimrc** (le fichier vimrc global peut se trouver dans /usr/share/vim/vimrc ).
S'il n'existe pas de fichier .vimrc dans le dossier de l'utilisateur, vim se lance en « compatibilité » avec vi. C'est-à-dire qu'il va charger les options par défaut de vi, et non pas celles de vim. La simple existence de ce fichier suffit normalement à charger les options par défaut de vim, mais, par précaution, forcez la désactivation de cette compatibilité (en tout début de fichier, car ça change les options).
Voici quelques paramètres utiles à ajouter dans ce fichier :
^ Paramètre ^ Action ^
| set nocompatible
| Désactive la compatibilité avec vi |
| set background=dark
| Adapte les couleurs pour un fond noir |
| syntax on
| Active la coloration syntaxique |
| set number
| Affiche les numéros de lignes |
| set tabstop=4
| Indentation toutes les quatre colonnes |
| set expandtab
| Conversion des tabulations en espaces |
| set shiftwidth=4
| Indentation de quatre colonnes |
| set smartindent
| Indentation "intelligents" |
| set autoindent
| Conserve l'indentation courante sur les nouvelles lignes |
| set backspace=indent,eol,start
| Retours arrières intelligents |
| set shiftround
| Indentation à la marque de Tab la plus proche |
| set ignorecase
| Ignore la casse lors de recherche |
| set showmode
| Affiche le mode d'édition |
| set ruler
| Affiche la position du curseur |
| set showcmd
| Affiche les commandes incomplète |
|map :resize
| Ctrl-m Agrandit la fenêtre courante (:help map)|
|map :bNext
| Ctrl-b Va au tampon suivant (:help map)|
Si vim ne se souvient pas de la position précédente du curseur lorsque vous réouvrez un fichier, il faut ajouter la ligne suivante dans le fichier ~/.vimrc:
au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g'\"" | endif
confère commande vim **:help last-position-jump** ou bien en tapant:
grep -A4 last-position-jump /usr/local/share/vim/vim72/doc/eval.txt
Il est également possible de faire ces modifications dans le fichier **/etc/vim/vimrc** avec les [[:sudo| droit administrateur]] pour qu'elles s'appliquent à tous les utilisateurs du système.
Un fichier exemple est disponible également **/usr/share/vim/vimcurrent/vimrc_example.vim**
Si vous avez l'erreur "Sorry, the command is not available in this version: syntax on", vous utilisez sûrement vim-tiny et non vim "complet". Pour y remédier, [[:tutoriel:comment_supprimer_un_paquet| supprimez le paquet]] **vim-tiny** et [[:tutoriel:comment_installer_un_paquet|ré-installez le paquet]] **vim**
Vous pouvez aussi utiliser la commande suivante et choisir vim.gnome : sudo update-alternatives --config vim
==== Support des souris ====
Le service **gpm**((**gpm** : General Purpose Mouse interface https://www.nico.schottelius.org/software/gpm/)) permet l'utilisation de la souris dans le terminal pour sélectionner, copier et coller. Vérifiez que le paquet [[apt://gpm|gpm]] est [[:tutoriel:comment_installer_un_paquet|installé]] et [[:tutoriel:comment_modifier_un_fichier|modifiez votre fichier]] ~/.vimrc comme expliqué plus haut pour y insérer :
set mouse=a
====Thème de coloration syntaxique====
Placez le thème dans ~/.vim/colors et activez le thème dans le .vimrc avec la ligne :
colorscheme nom_du_theme
Si vous utilisez vim dans un terminal, il est possible que votre thème ne soit pas utilisé, et qu'il n'y ait pas de coloration syntaxique. Il faut donc forcer les couleurs en ajoutant dans le .vimrc la ligne suivante :
set t_Co=256
Si votre terminal ne supporte que 88 couleurs :
set t_Co=88
Il est cependant nécessaire que le thème ait été pensé à la fois pour la GUI et le terminal. Si ce n'est pas le cas du thème que vous avez choisi, le plus simple est d'utiliser le plugin [[https://www.vim.org/scripts/script.php?script_id=1809|guicolorscheme]].
Nota : les thèmes installés par défaut se trouvent dans le répertoire /usr/share/vim/vim**xx**/colors ou xx correspond à la version en cours, 74 ou 80 à ce jour
=== Indiquer (forcer) la coloration syntaxique ===
Il peut-être pratique de pouvoir indiquer la coloration syntaxique, en particulier lorsqu'on édite des fichiers sans extension (ou non représentative du type de fichier), par exemple lire le fichier ///var/log/syslog.1//\\
Pour cela, il faut saisir dans vim :
# :set syntax=
:set syntax=messages
((src : https://stackoverflow.com/a/3853036/6614155))\\
Pour connaître la liste des types, cd /usr/share/nvim/runtime/syntax && grep -rn "Language:"
===== Extensions, plugins et packages =====
Il existe de nombreuses extensions à VIM, notamment pour les développeurs, pour ajouter des fonctionnalités telle que l'arborescence du répertoire de travail, la liste des fonctions/variables, des colorations spécifiques…
Pour lister les plugins installés, dans VIM, tapez la commande:
:scriptnames
==== Les plugins ====
C'est assez simple, ils se composent généralement de deux fichiers, un //.vim// et un //.txt//.
Le //.vim// peut simplement être déposé dans ///usr/share/vim/vim80/plugin///,\\
le //.txt// dans ///usr/share/vim/vim80/doc///
==== Les packages ====
C'est plus compliqué, mais il existe des outils, tel que [[https://github.com/tpope/vim-pathogen|Pathogen]] ou [[https://github.com/VundleVim/Vundle.vim|Vundle]] pour simplifier leur installation
===== Pour aller plus loin =====
* [[https://www.vim.org/]] -- Site officiel (en)
* [[ftp://ftp.vim.org/pub/vim/doc/book/vimbook-OPL.pdf|Vim book (fichier PDF, anglais)]]
* [[https://arolla.developpez.com/tutoriels/programmation/editeurs-code/dompter-vim-en-trois-temps/|Tuto sur developpez.com]]
* [[https://yannesposito.com/Scratch/fr/blog/Learn-Vim-Progressively/|Apprendre Vim progressivement]]
* [[https://touticphoto.fr/assistance-informatique/30-editeur-de-texte-vim|Quelques notes de prises en main sur Vim]]
* [[https://github.com/dpelle/vim-Grammalecte|Plugin Grammalecte]] étendre les fonctionnalités de VIM avec un Correcteur grammatical dédié à la langue française.
----
//Contributeurs : [[:utilisateurs:YoBoY|YoBoY]], [[:utilisateurs:Mr_Djez|Mr_Djez]], [[:utilisateurs:bcag2|bcag2]]//