« Vim » : différence entre les versions

De Disposition de clavier bépo
Ligne 209 : Ligne 209 :
  highlight NbSp ctermbg=lightgrey guibg=lightred
  highlight NbSp ctermbg=lightgrey guibg=lightred
  match NbSp /\%xa0/
  match NbSp /\%xa0/
=== Esc plus accessible ===


== Autres applications « à la Vim » ==
== Autres applications « à la Vim » ==

Version du 24 mai 2008 à 01:31

Attention

Page en cours de construction

Vim n'est pas UN éditeur de texte, c'est LE éditeur de texte. Je ne tomberai pas dans le piège grossier du troll Vim/Emacs, puisqu'il est clair Vim est mieux. Je vais tâcher de regrouper sur cette page toutes les infos relatives à l'utilisation de Vim en Bépo.

Ergonomie

Vim n'utilise que très peu de raccourcis en Ctrl+{} et est conçu pour faire toutes les opérations en mode « dactylo », c'est-à-dire avec les doigts proches de la position de repos. L'objectif est la prévention des TMS ; le prix à payer est un temps d'apprentissage assez long.

Parmi les fonctionnalités de base qui tuent, il y a le déplacement du curseur avec HJKL (équivalent des flèches) ou WEB pour le mot-à-mot (équivalent de Ctrl+flèche). Là où le bât blesse, c'est que Vim est conçu pour un clavier Qwerty. Il convient donc de reconfigurer Vim pour l'utiliser en Bépo.

TODO : ajouter des liens vers des tutoriels Vim.

http://www.viemu.com/a_vi_vim_graphical_cheat_sheet_tutorial.html

Reconfiguration partielle des touches

On ne cherche ici qu'à implémenter le déplacement en [HJKL] avec le moins d'impact possible sur le reste des commandes Vim. Reste à voir à l'usage si ça suffit pour utiliser Vim confortablement, à suivre…

Ces lignes sont à ajouter au fichier ~/.vimrc.

[W] -> {È}

W E B sont les trois commandes de déplacement mot-à-mot de Vim. Le placement de {W} est catastrophique, mais ça se soigne :

 Bépo   Qwerty   Commande 
 è  w word mot suivant
 È  W Word mot suivant (délimiteur = espace)
 e  e end fin de mot
 E  E End fin de mot (délimiteur = espace)
 b  b back mot précédant
 B  B Back mot précédant (délimiteur = espace)

On conserve donc {B} et {E}, mais on utilise {È} comme commande {W} :

noremap è w
noremap È W

Par contre, il semble impossible de remapper Ctrl+W en Ctrl+È, ce qui est regrettable pour les manipulations de fenêtres… À défaut, on peut toutefois utiliser {W} comme un Ctrl+W :

noremap W <C-w>

Nota : les adeptes du Bépo-intl n'ont pas besoin de ces mappings, {W} étant déjà placé sur la touche [T].

[HJKL] -> {CTSR}

L'objectif principal est d'utiliser les touches de déplacement case-à-case de Vim :

 Bépo   Qwerty   Commande 
 c  h gauche
 t  j bas
 s  k haut
 r  l droite

Les majuscules ont une fonction différente :

 Bépo   Qwerty   Commande 
 C  H haut de l'écran
 T  J Join joindre les lignes
 S  K Keyword lancer man sur le mot courant
 R  L bas de l'écran

Ce qui donne :

" {cr} = « gauche / droite »
noremap c h
noremap r l
" {ts} = « haut / bas »
noremap t j
noremap s k
" {CR} = « haut / bas de l'écran »
noremap C H
noremap R L
" {TS} = « joindre / aide »
noremap T J
noremap S K

{HJKL} <- [CTSR]

Maintenant il faut replacer {HJKL}. En première approche, on pourrait se contenter d'échanger les touches deux à deux, mais il est plus opportun de regrouper les commandes C et T sur la ligne du haut, S et R sur la ligne du bas. En effet, la commande « Change » — [C] en Qwerty — est très souvent couplée avec une commande de déplacement telle que [w][b][t]…

 Bépo   Qwerty   Commande 
 h  r replace remplacer le caractère
 H  R Replace remplacer à partir du caractère
 j  t till jusqu'au caractère suivant
 J  T Till jusqu'au caractère précédant
 k  s suppr. supprimer le caractère et insérer
 K  S Suppr. supprimer la ligne et insérer
 l  c change changer
 L  C Change changer jusqu'à la fin de ligne

{L} devient ainsi la touche « Change », c'est juste à coté de {D} (« Delete »), donc assez cohérent.

" {J} = « Jusqu'à »            (j = suivant, J = précédant)
noremap j t
noremap J T
" {L} = « Change »             (h = bloc, H = jusqu'à la fin de ligne)
noremap l c
noremap L C
" {H} = « Remplace »           (l = caractère, L = texte)
noremap h r
noremap H R
" {K} = « Supprime et insère » (k = caractère, K = ligne)
noremap k s
noremap K S

Problème avec [gj] et [gk]

Avec le fichier de configuration proposé en l'état, les commandes [gj] et [gk] ne fonctionnent pas ; cela est dû au fait que [gt] et [gT] sont déjà affectées à la sélection d'onglets. Les commandes [gj] et [gk] sont utilisées respectivement pour se déplacer ver le bas et vers le haut à l'intérieur d'une ligne, ce qui peut s'avérer nécessaire quand on utilise Vim pour des tâches littéraires.

Pour implémenter [gj] et [gk] il est nécessaire d'utiliser une touche supplémentaire. Voilà trois possibilités de correction.

Utiliser {Tab} pour changer d'onglet

On ajoute ces lignes à la fin du fichier ~/.vimrc :

noremap gt gj
noremap gs gk
noremap g<Tab> gt
noremap g<S-Tab> gT
Utiliser {Ç} et modifier le comportement de {ST}

En Bépo, les commandes gj et surtout gk (bas / haut) sont difficiles à faire. On peut contourner la difficulté en utilisant :

  • {T} et {S} pour [j] et [k]
  • {t} et {s} pour [gj] et [gk]
  • {ç} pour J (joindre deux lignes) et {Ç} pour K (aide)

La section 2.2 devient alors :

" {ctsr} = « gauche / bas / haut / droite »
noremap c h
noremap t gj
noremap s gk
noremap r l
" {CR} = « haut / bas de l'écran »
noremap C H
noremap R L
" {TS} = « ligne suivante / précédente »
noremap T j
noremap S k
" Effet domino : J et K manquent à l'appel
noremap ç J
noremap Ç K

C'est surtout pour un usage littéraire de Vim que cette variante est appréciable, les longues lignes de texte étant alors plus faciles à manipuler.

Déplacer la commande [g] ailleurs…

…mais où ?

Remarques

Les touches {É}{Ê}{Ç}{À} sont inutilisées par Vim, et peuvent donc être affectées librement. Par exemple, on peut faire de {É} une touche « début de ligne » :

noremap é ^
noremap É 0

Parmi les problèmes rencontrés : {t} et {s} ne fonctionnent pas avec l'explorateur « :Ex », c'est ballot — penser à utiliser les flèches dans ce cas.

À compléter.

Reconfiguration totale des touches

Une option radicale consisterait à reconfigurer toutes les touches en mode normal, afin qu'elles correspondent aux labels du clavier Azerty. On pourrait même générer un tel fichier automatiquement avec les outils du projet Bépo si suffisamment d'utilisateurs étaient intéressés…

Bépo/Qwerty

C'est à priori la meilleure solution du point de vue de l'ergonomie. On peut reprendre les cheat sheets classiques en l'état.

À faire.

Bépo/Azerty

Cette variante permettrait de se référer aux labels des touches du clavier Azerty pour les commandes Vim.

À faire.

Autres options utiles

À ajouter dans le fichier ~/.vimrc.

Appliquer automatiquement les modifications de ~/.vimrc

La première chose à faire pour jouer avec ~/.vimrc !

if has("autocmd")
  autocmd! bufwritepost .vimrc source ~/.vimrc
endif

Voir les espaces insécables

Bien entendu, on peut changer la couleur.

" colore les nbsp
highlight NbSp ctermbg=lightgrey guibg=lightred
match NbSp /\%xa0/

Esc plus accessible

Autres applications « à la Vim »

Bon nombre d'applications courantes utilisent les touches de déplacement de Vim :

  • beaucoup d'outils standard du shell : man, more, less…
  • la plupart des gestionnaires de fenêtres en mosaïque : Wmii, Dwm, Xmonad, Awesome…
  • certains logiciels comme aptitude, mutt, ou même Firefox avec l'extension Vimperator…
  • même Emacs dispose d'un mode Vim qui le rend utilisable permet de déplacer le curseur sans bouger les mains (pas testé ;-))

Par contre, ces applications n'utilisent pas le fichier ~/.vimrc, et pour la plupart d'entre elles la syntaxe de configuration est complètement différente. Liste à compléter.

Pire : certaines applications ne sont pas adaptables au Bépo, les touches de commande étant codées en dur (!). Liste à compléter.

  • vifm

À compléter.