Difference between revisions of "Vim (Italiano)"

From ArchWiki
Jump to: navigation, search
(Saving and Quitting: tradotto)
(rm temporary i18n template)
(32 intermediate revisions by 4 users not shown)
Line 1: Line 1:
 
[[Category:Development (Italiano)]]
 
[[Category:Development (Italiano)]]
 
[[Category:Text editors (Italiano)]]
 
[[Category:Text editors (Italiano)]]
{{i18n|Vim}}
+
[[en:Vim]]
{{translateme}} {{Attenzione|Questo articolo è in fase di traduzione. Seguite per ora le istruzioni della versione inglese.}}
+
[[es:Vim]]
 +
[[lt:Vim]]
 +
[[ru:Vim]]
 +
[[zh-CN:Vim]]
 +
[[zh-TW:Vim]]
 
{{Article summary start|Sommario}}
 
{{Article summary start|Sommario}}
 
{{Article summary text|Un tutorial base, ed alcuni consigli per la configurazione dell'editor di testi per console/terminale.}}
 
{{Article summary text|Un tutorial base, ed alcuni consigli per la configurazione dell'editor di testi per console/terminale.}}
 
{{Article summary end}}
 
{{Article summary end}}
  
''"[http://www.vim.org/about.php Vim] is an advanced text editor that seeks to provide the power of the de-facto UNIX editor ‘vi’, with a more complete feature set."'' Vim is not a simple text editor like nano or pico. It does require some time to learn, and a great amount of time to master.
+
''"[http://www.vim.org/about.php Vim] è un editor di testi avanzato che mira a fornire la potenza del de-facto editor UNIX ‘vi’, con maggiori caratteristiche e funzionalità."'' Vim non è un semplice editor di testo come nano o pico. Esso richiede un po' di pratica per imparare, e molto tempo per padroneggiarlo.
  
Vim is designed to make your fingers work as little as possible, and you should never have to use the mouse. This may seem odd, but once you master vim, you’ll begin to understand the reasoning.
+
Vim è ideato per ridurre al minimo il lavoro delle dita, e non ci sarà mai bisogno di usare il mouse. Questo può sembrare sciocco, ma una volta padroneggiato vim, se ne comprenderà il motivo.
 
+
==Feature==
+
  
 +
==Caratteristiche==
 
* Vim è molto potente per effettuare editing avanzati
 
* Vim è molto potente per effettuare editing avanzati
 
* Espandibile, grazie alle opzioni di configurazione
 
* Espandibile, grazie alle opzioni di configurazione
Line 19: Line 22:
  
 
==Installazione==
 
==Installazione==
* Per installare vim per la linea di comando
 
pacman -S vim
 
  
* Per installare la versione con la GUI (fornisce vim):
+
Si può [[pacman (Italiano)|installare]] la versione da linea di comando con il pacchetto {{Pkg|vim}}, oppure si può installare la versione con interfaccia grafica (che fornisce anche {{ic|vim}}) installando il pacchetto {{Pkg|gvim}}.
pacman -S gvim
+
  
{{Nota|Vim non è più compilato con l'opzione X server. Per molti utenti, significa che la normale funzione di copia e incolla dagli appunti di un ambiente grafico non funzionerà. Se questa è una operazione fondamentale, considerare l'installazione di {{Package Official|gvim}} che include una versione di Vim con questo supporto. [https://bugs.archlinux.org/task/14609 (Attribution)]}}
+
{{Nota|{{Pkg|vim}} non è più compilato con l'opzione X server. Per molti utenti, significa che la normale funzione di copia e incolla dagli appunti di un ambiente grafico non funzionerà. Se non si vuole rinunciare a questa funzionalità, considerare l'installazione di {{Pkg|gvim}} che include una versione di Vim con questo supporto. Vedere {{Bug|14609}} per maggiori informazioni.}}
 +
 
 +
{{Nota|Il pacchetto vim è concepito per essere il più leggero possibile, per cui non supporta gli interpreti di Python, Lua, e Ruby. Se si richiede tale supporto, scegliere il pacchetto gvim, il quale include il binario vim. Il repository non ufficiale {{ic|herecura-stable}} fornisce qualche variante di vim / gvim:
 +
{{hc|$ pacman -Slq herecura-stable | grep vim|
 +
vim-cli
 +
vim-gvim-gtk
 +
vim-gvim-motif
 +
vim-gvim-qt
 +
vim-gvim-x11
 +
vim-rt
 +
vim-tiny
 +
}}
 +
}}
  
 
==Uso==
 
==Uso==
Questa è una panoramica base su come utilizzare vim. Alternativamente, è possibile utilizzare {{Codeline|vimtutor}} per familiarizzare con l'editor. Vim ha quattro differenti modalità:
+
Questa è una panoramica base su come utilizzare vim. Alternativamente, è possibile utilizzare {{ic|vimtutor}} per familiarizzare con l'editor. Vim ha quattro differenti modalità:
 
+
* ''Command mode'': i tasti premuti vengono interpretati come comandi.
+
* ''Insert mode'': i tasti premuti vengono inseriti nel file.
+
* ''Visual mode'': i tasti premuti selezionano, tagliano o copiano il testo.
+
* ''Ex mode'': una modalità di input per comandi addizionali (esempio salvare un file, sostituire parti di testo, ecc.).
+
  
===Editing base===
+
* ''Command mode'' (modalità comando): i tasti premuti vengono interpretati come comandi.
 +
* ''Insert mode'' (modalità inserimento): i tasti premuti vengono inseriti nel file.
 +
* ''Visual mode'' (modalità visuale): i tasti premuti selezionano, tagliano o copiano il testo.
 +
* ''Ex mode'' (modalità ex): una modalità di input per comandi addizionali (esempio salvare un file, sostituire parti di testo, ecc.).
  
 +
===Editing di base===
 
Se si avvia vim con:
 
Se si avvia vim con:
  
Line 50: Line 61:
  
 
===Spostamento===
 
===Spostamento===
 
 
In vim, è possibile spostare il cursore usando le frecce della tastiera, ma questa non è considerata la '''vim way'''. Si dovrebbe spostare la mano tropo a destra dalla normale posizione di battitura per raggiungere le frecce, e poi ritornare in posizione. Non è divertente.
 
In vim, è possibile spostare il cursore usando le frecce della tastiera, ma questa non è considerata la '''vim way'''. Si dovrebbe spostare la mano tropo a destra dalla normale posizione di battitura per raggiungere le frecce, e poi ritornare in posizione. Non è divertente.
  
Line 59: Line 69:
 
{{Nota|{{Keypress|^}} e {{Keypress|$}} sono comunemente utilizzati nelle espressioni regolari per rappresentare l'inizio e la fine della linea. Le espressioni regolari sono molto potenti e comunemente usate negli ambienti *nix, quindi per ora sarà ingannevole, ma più avanti si capirà "l'idea" dietro a molti di queste combinazioni da tastiera.}}
 
{{Nota|{{Keypress|^}} e {{Keypress|$}} sono comunemente utilizzati nelle espressioni regolari per rappresentare l'inizio e la fine della linea. Le espressioni regolari sono molto potenti e comunemente usate negli ambienti *nix, quindi per ora sarà ingannevole, ma più avanti si capirà "l'idea" dietro a molti di queste combinazioni da tastiera.}}
  
Per spostarsi di una parola premere {{Keypress|w}}. {{Keypress|W}} considera come appartenenti alla parola più caratteri (ad esempio gli underscore, i trattini come parte della parola). Per tornare indietro di una parola si usa {{Keypress|b}}. Anche in questo caso {{Keypress|B}} considera come appartenenti alla parola più caratteri. Per avanzare fino alla fine di una parola {{Keypress|e}}, {{Keypress|E}}} per comprendere altri caratteri.
+
Per spostarsi di una parola premere {{Keypress|w}}. {{Keypress|W}} considera come appartenenti alla parola più caratteri (ad esempio gli underscore, i trattini come parte della parola). Per tornare indietro di una parola si usa {{Keypress|b}}. Anche in questo caso {{Keypress|B}} considera come appartenenti alla parola più caratteri. Per avanzare fino alla fine di una parola {{Keypress|e}}, {{Keypress|E}} per comprendere altri caratteri.
  
 
Per spostarsi all'inizio di una frase {{Keypress|(}} effettuerà lo spostamento. {{Keypress|)}} farà invece l'opposto, spostandosi alla fine della frase. Per uno spostamento maggiore {{Keypress|{}} posizionerà il cursore all'inizio del paragrafo. {{Keypress|<nowiki>}</nowiki>}} sposterà il cursore alla fine dell'intero paragrafo.
 
Per spostarsi all'inizio di una frase {{Keypress|(}} effettuerà lo spostamento. {{Keypress|)}} farà invece l'opposto, spostandosi alla fine della frase. Per uno spostamento maggiore {{Keypress|{}} posizionerà il cursore all'inizio del paragrafo. {{Keypress|<nowiki>}</nowiki>}} sposterà il cursore alla fine dell'intero paragrafo.
  
Per spostarsi all'inizio dello schermo, {{Keypress|H}} effettuerà lo spostamento. {{Keypress|M}} sposterà il cursore al centro dello schermo, ed {{Keypress|L}} alla fine della schermata. {{Keypress|g}}{{Keypress|g}} posizionerà il cursore all'inizio del file, {{Keypress|G}} invece alla sua fine. {{Keypress|CTRL}}+{{Keypress|D}} permetterà di scorrere pagina per pagina.
+
Per spostarsi all'inizio dello schermo, {{Keypress|H}} effettuerà lo spostamento. {{Keypress|M}} sposterà il cursore al centro dello schermo, ed {{Keypress|L}} alla fine della schermata. {{Keypress|gg}} posizionerà il cursore all'inizio del file, {{Keypress|G}} invece alla sua fine. {{Keypress|Ctrl+D}} permetterà di scorrere pagina per pagina.
  
 
===Ripetere i comandi===
 
===Ripetere i comandi===
 
+
Se un comando è preceduto da un numero, allora questo comando verrà eseguito un numero di volte uguale al numero premuto (ci sono delle eccezioni, ma possono avere senso, come il comando {{Keypress|s}}). Ad esempio premendo {{Keypress|3i}} ed inserendo il testo "Help! " e successivamente {{Keypress|Esc}} verrà inserito il testo "Help! Help! Help! “. Premendo {{Keypress|2<nowiki>}</nowiki>}} il cursore si sposterà in avanti di due paragrafi. Questo è utile con alcuni dei comandi di seguito.
Se un comando è preceduto da un numero, allora questo comando verrà eseguito un numero di volte uguale al numero premuto (ci sono delle eccezioni, ma possono avere senso, come il comando {{Keypress|s}}). Ad esempio premendo {{Keypress|3}}{{Keypress|i}} ed inserendo il testo "Help! " e successivamente {{Keypress|Esc}} verrà inserito il testo "Help! Help! Help! “. Premendo {{Keypress|2}}{{Keypress|<nowiki>}</nowiki>}} il cursore si sposterà in avanti di due paragrafi. Questo è utile con alcuni dei comandi di seguito.
+
  
 
===Cancellare===
 
===Cancellare===
 +
Il comando {{Keypress|x}} cancellerà il carattere sotto al cursore. {{Keypress|X}} cancellerà il carattere prima del cursore. Qui è dove la funzione dei numeri diventa interessante. {{Keypress|6x}} cancellerà 6 caratteri. Premere {{Keypress|.}} (punto) ripeterà il comando precedente. Quindi, ipotizzando di avere la parola "foobar" in diversi punti, ma dopo averci pensato, si preferisce usare la parola "foo". Spostare il cursore sopra la lettera "b", premere {{Keypress|3x}}, spostare il cursore sulla successiva parola "foobar" e premere {{Keypress|.}} (punto).
  
Il comando {{Keypress|x}} cancellerà il carattere sotto al cursore. {{Keypress|X}} cancellerà il carattere prima del cursore. Qui è dove la funzione dei numeri diventa interessante. {{Keypress|6}}{{Keypress|x}} cancellerà 6 caratteri. Premere {{Keypress|.}} (punto) ripeterà il comando precedente. Quindi, ipotizzando di avere la parola "foobar" in diversi punti, ma dopo averci pensato, si preferisce usare la parola "foo". Spostare il cursore sopra la lettera "b", premere {{Keypress|3}}{{Keypress|x}}, spostare il cursore sulla successiva parola "foobar" e premere {{Keypress|.}} (punto).
+
Il comando {{Keypress|d}} comunicherà a vim che si intende cancellare qualcosa. Dopo aver premuto {{Keypress|d}}, sarà necessario indicare cosa cancellare. Si possono utilizzare anche i comandi di movimento. {{Keypress|dW}} cancellerà finito alla prossima parola. {{Keypress|d^}} cancellerà fino all'inizio della linea. Anteporre un numero al comando di eliminazione funzionerà altrettanto: {{Keypress|3dW}} cancellerà fino alle tre parole successive. {{Keypress|D}} (maiuscolo) è una scorciatoia per cancellare fino alla fine della linea (come {{Keypress|d$}}). Premere {{Keypress|dd}} cancellerà tutta la linea.
 
+
Il comando {{Keypress|d}} comunicherà a vim che si intende cancellare qualcosa. Dopo aver premuto {{Keypress|d}}, sarà necessario indicare cosa cancellare. Si possono utilizzare anche i comandi di movimento. {{Keypress|d}}{{Keypress|W}} cancellerà finito alla prossima parola. {{Keypress|d}}{{Keypress|^}} cancellerà fino all'inizio della linea. Anteporre un numero al comando di eliminazione funzionerà altrettanto: {{Keypress|3}}{{Keypress|d}}{{Keypress|W}} cancellerà fino alle tre parole successive. {{Keypress|D}} (maiuscolo) è una scorciatoia per cancellare fino alla fine della linea (come {{Keypress|d}}{{Keypress|$}}). Premere {{Keypress|d}}{{Keypress|d}} cancellerà tutta la linea.
+
  
Per cancellare e sostituire la parola corrente, posizionare il cursore sulla parola ed eseguire il comando {{Keypress|c}}{{Keypress|w}}. Questo comando cancellerà la parola e cambierà la modalità in inserimento. Per sostituire una singola lettera usare {{Keypress|r}}.
+
Per cancellare e sostituire la parola corrente, posizionare il cursore sulla parola ed eseguire il comando {{Keypress|cw}}. Questo comando cancellerà la parola e cambierà la modalità in inserimento. Per sostituire una singola lettera usare {{Keypress|r}}.
  
 
===Annulla e ripeti===
 
===Annulla e ripeti===
Vim ha una funzione appunti integrata (anche nota come buffer). Le azioni possono essere annullate con il tasto {{Keypress|u}} e ripetute con la combinazione {{Keypress|CTRL}}+{{Keypress|r}}.
+
Vim ha una funzione appunti integrata (anche nota come buffer). Le azioni possono essere annullate con il tasto {{Keypress|u}} e ripetute con la combinazione {{Keypress|Ctrl+r}}.
  
===Visual Mode===
+
===Modalità visuale===
Premendo {{Keypress|v}} si entrerà in ''visual mode''. In  questa modalità è possibile selezionare parti di testo, una volta selezionato premendo {{Keypress|y}} verrà memorizzato nel buffer, è possibile tagliare il testo premendo {{Keypress|c}}. {{Keypress|p}} incollerà il testo memorizzato nel buffer dopo il cursore, {{Keypress|P}} prima. Il tasto {{Keypress|V}} attiverà la ''visual line mode'', analoga alla modalità precedente ma con effetto su intere linee. {{Keypress|CTRL}}+{{Keypress|v}} invece per i blocchi di testo.
+
Premendo {{Keypress|v}} si entrerà in ''visual mode''. In  questa modalità è possibile selezionare parti di testo, una volta selezionato premendo {{Keypress|y}} verrà memorizzato nel buffer, è possibile tagliare il testo premendo {{Keypress|c}}. {{Keypress|p}} incollerà il testo memorizzato nel buffer dopo il cursore, {{Keypress|P}} prima. Il tasto {{Keypress|V}} attiverà la ''visual line mode'', analoga alla modalità precedente ma con effetto su intere linee. {{Keypress|Ctrl+v}} invece per i blocchi di testo.
  
 
{{Nota|In qualsiasi momento si cancelli del testo, questo vine inserito nel buffer e sarà disponibile per essere incollato.}}
 
{{Nota|In qualsiasi momento si cancelli del testo, questo vine inserito nel buffer e sarà disponibile per essere incollato.}}
  
 
===Trova e sostituisci===
 
===Trova e sostituisci===
Per cercare una parola o un carattere nel file, basterà semplicemente premere {{Keypress|/}} e successivamente il/i carattere/i da cercare ed infine premere {{Keypress|ENTER}}. Per visualizzare l'occorrenza successiva della ricerca usare {{Keypress|n}}.
+
Per cercare una parola o un carattere nel file, basterà semplicemente premere {{Keypress|/}} e successivamente il/i carattere/i da cercare ed infine premere {{Keypress|ENTER}}. Per visualizzare l'occorrenza successiva della ricerca usare {{Keypress|n}}, mentre per la precedente usare {{keypress|N}}.
  
 
+
Per cercare e sostituire usare il comando ''substitute'' {{Keypress|:s/}}. La sua sintassi è {{ic|[range]s///[arguments]}}. Ad esempio:
Per cercare e sostituire usare il comando ''substitute'' {{Keypress|:}}{{Keypress|s}}{{Keypress|/}}. La sua sintassi è {{Codeline|[range]s///[arguments]}}. Ad esempio:
+
  
 
  Comando        Risultato
 
  Comando        Risultato
Line 97: Line 104:
 
  :%s/xxx/yyy/g  Sostituisce xxx con yyy globalmente in tutto il file
 
  :%s/xxx/yyy/g  Sostituisce xxx con yyy globalmente in tutto il file
  
 
+
Si può usare il comando ''global'' {{Keypress|:g/}} per ricercare un pattern ed eseguire un comando per ogni corrispondenza. La sintassi è: {{ic|[range]:g//[cmd]}}.
Si può usare il comando ''global'' {{Keypress|:}}{{Keypress|g}}{{Keypress|/}} per ricercare un pattern ed eseguire un comando per ogni corrispondenza. La sintassi è: {{Codeline|[range]:g//[cmd]}}.
+
  
 
  Comando  Risultato
 
  Comando  Risultato
Line 105: Line 111:
  
 
===Salvare ed uscire===
 
===Salvare ed uscire===
Per salvare e/o uscire, sarà necessario usare la modalità ''Ex''. I comandi della modalità ''Ex'' sono preceduti da {{Keypress|:}}. Per salvare un file usare {{Keypress|:}}{{Keypress|w}} '''nomefile'''. Per uscire {{Keypress|:}}{{Keypress|q}}. Se invece si disidera uscire senza salvare le modifiche effettuate, usare {{Keypress|:}}{{Keypress|q}}{{Keypress|!}}. Per salvare ed uscire {{Keypress|:}}{{Keypress|x}}. Esiste anche un'altra scorciatoia per salvare ed uscire cioè la combinazione {{Keypress|Z}}{{Keypress|Z}}(maiuscole).
+
Per salvare e/o uscire, sarà necessario usare la modalità ''Ex''. I comandi della modalità ''Ex'' sono preceduti da {{Keypress|:}}. Per salvare un file usare {{ic|''':w''' nomefile}}. Per uscire {{Keypress|:q}}. Se invece si desidera uscire senza salvare le modifiche effettuate, usare {{Keypress|:q!}}. Per salvare ed uscire {{Keypress|:x}}. Esiste anche un'altra scorciatoia per salvare ed uscire cioè la combinazione {{Keypress|ZZ}} (maiuscole).
  
=== Additional Commands ===
+
===Altri comandi===
  
# Pressing '''s''' will erase the current letter under the cursor, and place you in insert mode. '''S''' will erase the whole line, and place you in insert mode.
+
# Premendo {{Keypress|s}} verrà cancellato il carattere sotto al cursore, e verrà attivata la modalità inserimento. {{Keypress|S}} cancellerà l'intera linea ed attiverà la modalità inserimento.
# '''o''' will create a newline below the line and put you insert mode, '''O''' will create a newline above the line and put you in insert mode.
+
# {{Keypress|o}} creerà una nuova linea sotto alla linea corrente ed attiverà la modalità inserimento. {{Keypress|O}} invece creerà una nuova linea sopra a quella corrente ed avvierà la modalità inserimento.
# '''yy''' will yank an entire line
+
# {{Keypress|yy}} memorizzerà una linea nel buffer.
# '''cc''' will delete the current line and place you in insert mode.
+
# {{Keypress|cc}} cancellerà la linea corrente ed attiverà la modalità inserimento.
# '''*''' will highlight the current word and '''n''' will search it
+
# {{Keypress|*}} evidenzierà la parola corrente e {{Keypress|n}} la cercherà.
  
==Configuration==
+
==Configurazione==
 +
Il file di configurazione personale di vim si trova nella cartella home dell'utente {{ic|~/.vimrc}}. Gli utenti esperti di vim tendono a tenere un {{ic|~/.vimrc}} molto ben strutturato. La configurazione globale di vim è situata in {{ic|/etc/vimrc}}. La variabile di ripiego {{ic|$VIM}} è definita come {{ic|/usr/share/vim/}}. Ad esempio per creare uno schema di colori globale il file {{ic|*.vim}} dello shema di colori dovrebbe essere salvato in {{ic|/usr/share/vim/vimfiles/}}.
  
Vim's personal configuration file is located in the home directory: {{Filename|~/.vimrc}}. Advanced users tend to keep a well-tailored {{Filename|~/.vimrc}}.  The global configuration file is located at {{Filename|/etc/vimrc}}. The fall-back {{Codeline|$VIM}} variable is defined as {{Filename|/usr/share/vim/}}. For example, to create a global colorscheme the {{Filename|*.vim}} colorscheme file should be stored in {{Filename|/usr/share/vim/vimfiles/}}.
+
Correntemente, la configurazione globale di vim in Arch Linux è molto basilare a differenza delle configurazioni di default di vim nelle altre distribuzioni. Per ottenere i comportamenti comunemente utilizzati (come evidenziare la sintassi, il ritorno alla linea dell'ultima modifica...), utilizzare il file di configurazione d'esempio:
 
+
Currently, the vim global configuration in Arch Linux is very basic and differs from many other distributions' default vim configuration file. To get some commonly expected behaviors (like syntax highlighting, return to the line of the last edit...), consider using vim's example configuration file:
+
  
 
  cp /etc/vimrc /etc/vimrc.bak
 
  cp /etc/vimrc /etc/vimrc.bak
 
  cp /usr/share/vim/vim73/vimrc_example.vim /etc/vimrc
 
  cp /usr/share/vim/vim73/vimrc_example.vim /etc/vimrc
  
===Backup Files===
+
===File di backup===
 
+
Vim per default crea un backup di un file modificato nella stesa cartella del file chiamandolo {{ic|nomefile~}}. Per evitare di ingombrare, alcuni utenti impostano vim per utilizzare una apposita cartella per i backup:
Vim by default creates a backup of an edited file in the same directory as the file called {{Filename|filename~}}. To prevent clutter, many users tell vim to use a backup directory:
+
  
 
  set backupdir=~/.vim/backup,/tmp
 
  set backupdir=~/.vim/backup,/tmp
  
Or, it's possible to even disable this behavior:
+
Oppure è possibile disabilitare questa funzione:
  
 
  set nobackup
 
  set nobackup
 
  set nowritebackup
 
  set nowritebackup
  set noswapfile    ! (additionally disable swap files)
+
  set noswapfile    ! (disabilita i file swap)
  
===Wrap Searches===
+
===Ripetizione della ricerca===
 +
Con quest'opzione, ''trova successivo'' torna all'inizio del file quando ne raggiunge la fine. Similarmente, ''trova precedente'' va alla fine del file quando ne raggiunge l'inizio.
  
 
  set wrapscan
 
  set wrapscan
  
===Check Spelling===
+
===Controllo ortografico===
  
 
  set spell
 
  set spell
  
Vim will now highlight incorrectly spelled words. With the cursor on a misspelled word, use '''z=''' to view suggested corrections.
+
Con questa opzione Vim evidenzierà le parole non scritte correttamente. Muovere il cursore su una parola errata e usare {{Keypress|z<nowiki>=</nowiki>}} per vedere le correzioni proposte.
  
Only English language dictionaries are installed by default, more can be found at the [http://ftp.vim.org/vim/runtime/spell/ vim ftp archive].  After downloading the spl files for the given language (e.g. hu.cp1250.spl, hu.iso-8859-2.spl and/or hu.utf-8.spl for Hungarian) into {{Filename|~/.vim/spell}}, run:
+
Solo il dizionario inglese sarà installato di default, altri possono essere trovati nei [[Official Repositories (Italiano)|repository ufficiali]]. Per ottenere una lista dei linguaggi disponibili, eseguire:
  
  :setlocal spell spelllang=LL
+
  # pacman -Ss vim-spell
  
To activate spell checking for the selected language (i.e. {{Codeline|1=:setlocal spell spelllang=hu}} for the above mentioned example).
+
I file dei dizionari possono essere trovati anche nell'[http://ftp.vim.org/vim/runtime/spell/ archivio FTP di Vim]. Mettere i dizionari scaricati nella cartella {{ic|~/.vim/spell}} e configurare il dizionario eseguendo: {{ic|1=:setlocal spell spelllang=LL}}.
  
===Syntax Highlighting===
+
{{Tip|
 +
* Per abilitare il controllo ortografico soltanto per i documenti LaTeX (o TeX), aggiungere {{ic|autocmd FileType tex setlocal spell spelllang<nowiki>=</nowiki>en_us}} al file {{ic|~/.vimrc}} oppure in {{ic|/etc/vimrc}}, e riavviare vim. Per il controllo ortografico di linguaggi diversi dall'inglese, semplicemente sostituire {{ic|en_us}} con il valore appropriato al proprio linguaggio.
 +
* Sarà possibile abilitare il controllo ortografico per alcuni tipi di file (ad esempio *.txt) usando il plugin FileType ed una regola personalizzata per dichiarare il tipo di file. Per abilitare il controllo ortografico per ogni file di tipo {{ic|*.txt}}, creare il file {{ic|/usr/share/vim/vimfiles/ftdetect/plaintext.vim}}, ed inserire la linea {{ic|autocmd BufRead,BufNewFile *.txt    setfiletype plaintext}} nel file. Successivamente, inserire la linea {{ic|autocmd FileType plaintext setlocal spell spelllang<nowiki>=</nowiki>en_us}} nel proprio file {{ic|~/.vimrc}} oppure in {{ic|/etc/vimrc}}, e riavviare vim.}}
  
To enable syntax highlighting (vim supports a huge list of programming languages):
+
===Evidenziare la sintassi===
 +
Per abilitare l'opzione ed evidenziare la sintassi (''syntax highlighting'') (vim supporta una vasta lista di linguaggi di programmazione):
  
 
  filetype plugin on
 
  filetype plugin on
 
  syntax on
 
  syntax on
  
===Example {{Filename|~/.vimrc}}===
+
===Esempio di ~/.vimrc===
 +
Un esempio della [[Vim/.vimrc (Italiano)|configurazione di Vim]].
  
An example {{Filename|~/.vimrc}} covering common options.
+
==Unire file (Vimdiff)==
 +
Vim include un editor di comparazione (un programma che può mostrare le differenze tra due file). Può essere avviato con {{ic|vimdiff file1 file2}}; successivamente usare:
  
{{File
+
  ]c :        - differenza successiva
|name=~/.vimrc
+
  [c :        - differenza precedente
|content=<nowiki>
+
  Ctrl+w +w  - cambio finestra
" .vimrc
+
  do          - invia modifica
" See: http://vimdoc.sourceforge.net/htmldoc/options.html for details
+
  dp          - ottieni modifica
 
+
  zo          - mostra il testo nascosto
" For multi-byte character support (CJK support, for example):
+
  zc          - nasconde il testo
"set fileencodings=ucs-bom,utf-8,cp936,big5,euc-jp,euc-kr,gb18030,latin1
+
  :diffupdate - ricontrolla i file in cerca di differenze
     
+
set tabstop=4      " Number of spaces that a <Tab> in the file counts for.
+
+
set shiftwidth=4    " Number of spaces to use for each step of (auto)indent.
+
+
set expandtab      " Use the appropriate number of spaces to insert a <Tab>.
+
                    " Spaces are used in indents with the '>' and '<' commands
+
                    " and when 'autoindent' is on. To insert a real tab when
+
                    " 'expandtab' is on, use CTRL-V <Tab>.
+
+
set smarttab        " When on, a <Tab> in front of a line inserts blanks
+
                    " according to 'shiftwidth'. 'tabstop' is used in other
+
                    " places. A <BS> will delete a 'shiftwidth' worth of space
+
                    " at the start of the line.
+
+
set showcmd        " Show (partial) command in status line.
+
 
+
set number          " Show line numbers.
+
 
+
set showmatch      " When a bracket is inserted, briefly jump to the matching
+
                    " one. The jump is only done if the match can be seen on the
+
                    " screen. The time to show the match can be set with
+
                    " 'matchtime'.
+
+
set hlsearch        " When there is a previous search pattern, highlight all
+
                    " its matches.
+
+
set incsearch      " While typing a search command, show immediately where the
+
                    " so far typed pattern matches.
+
+
set ignorecase      " Ignore case in search patterns.
+
+
set smartcase      " Override the 'ignorecase' option if the search pattern
+
                    " contains upper case characters.
+
+
set backspace=2    " Influences the working of <BS>, <Del>, CTRL-W
+
                    " and CTRL-U in Insert mode. This is a list of items,
+
                    " separated by commas. Each item allows a way to backspace
+
                    " over something.
+
+
set autoindent      " Copy indent from current line when starting a new line
+
                    " (typing <CR> in Insert mode or when using the "o" or "O"
+
                    " command).
+
+
set textwidth=79    " Maximum width of text that is being inserted. A longer
+
                    " line will be broken after white space to get this width.
+
+
set formatoptions=c,q,r,t " This is a sequence of letters which describes how
+
                    " automatic formatting is to be done.
+
                    "
+
                    " letter    meaning when present in 'formatoptions'
+
                    " ------    ---------------------------------------
+
                    " c        Auto-wrap comments using textwidth, inserting
+
                    "          the current comment leader automatically.
+
                    " q        Allow formatting of comments with "gq".
+
                    " r        Automatically insert the current comment leader
+
                    "          after hitting <Enter> in Insert mode.
+
                    " t        Auto-wrap text using textwidth (does not apply
+
                    "          to comments)
+
+
set ruler          " Show the line and column number of the cursor position,
+
                    " separated by a comma.
+
+
set background=dark " When set to "dark", Vim will try to use colors that look
+
                    " good on a dark background. When set to "light", Vim will
+
                    " try to use colors that look good on a light background.
+
                    " Any other value is illegal.
+
+
set mouse=a        " Enable the use of the mouse.
+
+
filetype plugin indent on
+
syntax on
+
</nowiki>}}
+
 
+
Some more examples can be found in [[#Resources]].
+
 
+
==Merging Files (Vimdiff)==
+
 
+
Vim includes a diff editor (a program that can merge differences between two files).  Begin with {{Codeline|vimdiff file1 file2}}; to use:
+
 
+
  ]c :        - next difference
+
  [c :        - previous difference
+
  Ctrl+w +w  - switch windows
+
  do          - diff obtain
+
  dp          - diff put
+
  zo          - open folded text
+
  zc          - close folded text
+
  :diffupdate - re-scan the files for differences
+
  
 
==Vim Tips==
 
==Vim Tips==
 +
Trucchi per portare a termine alcuni compiti.
  
Specific user tricks to accomplish tasks.
+
===Numeri linea===
 
+
# Per mostrare i numeri linea {{ic|:set number}}.
===Line Numbers===
+
# Per andare ad una linea specifica {{ic|:<numero linea>}}.
 
+
# Show line numbers by {{Codeline|:set number}}.
+
# Jump to line number {{Codeline|:<line number>}}.
+
 
+
===Substitute on Lines===
+
 
+
To only substitute between certain lines:
+
  
 +
===Sostituzioni tra linee===
 +
Per sostituire solo tra un intervallo di certe linee:
 
  :''n'',''n''s/one/two/g
 
  :''n'',''n''s/one/two/g
  
For example, to replace instances of 'one' with 'two' between lines 3&4, one would execute:
+
Ad esempio, per sostituire il pattern 'one' con 'two' tra le linee 3 e 4, è possibile eseguire:
 
+
 
  :3,4s/one/two/g
 
  :3,4s/one/two/g
  
===Make Vim restore cursor position in files===
+
===Ripristinare la posizione del cursore nei file===
 +
Se si desidera che all'apertura di un file vim posizioni il cursore dove era situato durante l'ultima modifica del file, aggiungere la seguente linea al file {{ic|~/.vimrc}}:
  
If you want the cursor to appear in its previous position after you open a file, add the following to your {{Filename|~/.vimrc}}:
+
if has("autocmd")
 +
au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g`\"" | endif
 +
endif
  
<pre>
+
Consultare anche [http://vim.wikia.com/wiki/Restore_cursor_to_file_position_in_previous_editing_session questo articolo] del wiki di Vim.
if has("autocmd")
+
au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g`\"" | endif
+
endif
+
</pre>
+
  
See also [http://vim.wikia.com/wiki/Restore_cursor_to_file_position_in_previous_editing_session this] tip in Vim Wiki.
+
===Spazio vuoto all'inizio della finestra di gvim===
 +
Quando si usa un [[Window Manager (Italiano)|window manager]] configurato per ignorare le dimensioni delle finestre, gvim riempirà l'area non funzionale con il colore dell sfondo  del tema GTK.
  
===Empty space at the bottom of gvim windows===
+
Una soluzione è disabilitare la barra dei menu in {{ic|.vimrc}}, questo farà apparire la finestra di gvim come dovrebbe, occupando l'intera area:
When using a [[window manager]] configured to ignore window size hints, gvim will fill the non-functional area with the GTK theme background color.
+
  
A solution is to make a more pleasing background color: just put the following lines in {{filename|~/.gtkrc-2.0}}:
+
set go-=m "remove menubar
 +
 
 +
Un'altra soluzione consiste nel rendere più omogeneo il colore dello sfondo: semplicemente inserendo questa linea nel file {{ic|~/.gtkrc-2.0}}:
  
 
  style "vimfix" {
 
  style "vimfix" {
Line 301: Line 219:
 
  widget "vim-main-window.*GtkForm" style "vimfix"
 
  widget "vim-main-window.*GtkForm" style "vimfix"
  
==Resources==
+
===Sostituire il comando vi con vim===
  
'''Official'''
+
Eseguire questi comandi:
  
* [http://www.vim.org/ Vim homepage]
+
# ln -s $(which vim) /usr/local/bin/vi
* [http://vimdoc.sourceforge.net/ Vim documentation]
+
# ln -s $(which vim) /usr/local/bin/view
* [http://vim.wikia.com Vim Tips Wiki]
+
  
'''Tutorials'''
+
Leggere anche http://superuser.com/questions/27091/vim-to-replace-vi
  
* [http://usalug.org/vi.html vi Tutorial and Reference Guide]
+
==Altre risorse==
* [http://www.viemu.com/a_vi_vim_graphical_cheat_sheet_tutorial.html Graphical vi-vim Cheat Sheet and Tutorial]
+
* [http://vimcasts.org/ Vimcasts] - screencasts in .ogg format.
+
* [http://www.derekwyatt.org/vim/vim-tutorial-videos/vim-novice-tutorial-videos/ Tutorial Videos] - Tutorial videos, covering the basics up to advanced topics.
+
* [http://blog.interlinked.org/tutorials/vim_tutorial.html Vim Introduction and Tutorial]
+
  
'''Example configurations'''
+
===Ufficiali===
 +
* [http://www.vim.org/ Homepage]
 +
* [http://vimdoc.sourceforge.net/ Documentazione]
 +
* [http://vim.wikia.com Tips Wiki]
  
* [http://nion.modprobe.de/setup/vimrc nion's]
+
===Tutorial===
* [http://amix.dk/vim/vimrc.html A detailed configuration from Amir Salihefendic]
+
* [http://usalug.org/vi.html vi Tutorial e  Reference Guide]
* [http://www.jukie.net/~bart/conf/vimrc Bart Trojanowski]
+
* [http://www.viemu.com/a_vi_vim_graphical_cheat_sheet_tutorial.html vi-vim trucchi consigli e Tutorial grafici]
 +
* [http://blog.interlinked.org/tutorials/vim_tutorial.html Vim introduzione e tutorial]
 +
* [http://vim.runpaint.org/ Vim Recipes] - Un manuale liberamente consultabile.
  
'''Other'''
+
===Video===
 +
* [http://vimcasts.org/ Vimcasts] - Screencasts in formato .ogg.
 +
* [http://www.derekwyatt.org/vim/vim-tutorial-videos/vim-novice-tutorial-videos/ Video tutorial] - Tratta dagli argomenti base a quelli avanzati.
 +
 
 +
===Esempi di configurazione===
 +
* [http://nion.modprobe.de/setup/vimrc Setup di nion]
 +
* [http://amix.dk/vim/vimrc.html Una configurazione dettagliata da Amir Salihefendic]
 +
* [http://www.jukie.net/~bart/conf/vimrc Bart Trojanowski]
  
* [http://www.gentoo-wiki.info/HOWTO_VIM HOWTO Vim] -- Gentoo wiki article which this article was based on (author unknown).
+
===Altro===
 +
* [http://www.gentoo-wiki.info/HOWTO_VIM HOWTO Vim] - Articolo del wiki di Gentoo su cui è basato questo articolo (autore sconosciuto).
 +
* [http://bytefluent.com/vivify/ Vivify] - Un editor dello schema di colori per Vim

Revision as of 13:43, 15 June 2012

Sommario help replacing me
Un tutorial base, ed alcuni consigli per la configurazione dell'editor di testi per console/terminale.

"Vim è un editor di testi avanzato che mira a fornire la potenza del de-facto editor UNIX ‘vi’, con maggiori caratteristiche e funzionalità." Vim non è un semplice editor di testo come nano o pico. Esso richiede un po' di pratica per imparare, e molto tempo per padroneggiarlo.

Vim è ideato per ridurre al minimo il lavoro delle dita, e non ci sarà mai bisogno di usare il mouse. Questo può sembrare sciocco, ma una volta padroneggiato vim, se ne comprenderà il motivo.

Caratteristiche

  • Vim è molto potente per effettuare editing avanzati
  • Espandibile, grazie alle opzioni di configurazione
  • Semplici e robuste scorciatoie da tastiera
  • Evidenziazione della sintassi

Installazione

Si può installare la versione da linea di comando con il pacchetto vim, oppure si può installare la versione con interfaccia grafica (che fornisce anche vim) installando il pacchetto gvim.

Nota: vim non è più compilato con l'opzione X server. Per molti utenti, significa che la normale funzione di copia e incolla dagli appunti di un ambiente grafico non funzionerà. Se non si vuole rinunciare a questa funzionalità, considerare l'installazione di gvim che include una versione di Vim con questo supporto. Vedere FS#14609 per maggiori informazioni.
Nota: Il pacchetto vim è concepito per essere il più leggero possibile, per cui non supporta gli interpreti di Python, Lua, e Ruby. Se si richiede tale supporto, scegliere il pacchetto gvim, il quale include il binario vim. Il repository non ufficiale herecura-stable fornisce qualche variante di vim / gvim:
$ pacman -Slq herecura-stable | grep vim
vim-cli
vim-gvim-gtk
vim-gvim-motif
vim-gvim-qt
vim-gvim-x11
vim-rt
vim-tiny

Uso

Questa è una panoramica base su come utilizzare vim. Alternativamente, è possibile utilizzare vimtutor per familiarizzare con l'editor. Vim ha quattro differenti modalità:

  • Command mode (modalità comando): i tasti premuti vengono interpretati come comandi.
  • Insert mode (modalità inserimento): i tasti premuti vengono inseriti nel file.
  • Visual mode (modalità visuale): i tasti premuti selezionano, tagliano o copiano il testo.
  • Ex mode (modalità ex): una modalità di input per comandi addizionali (esempio salvare un file, sostituire parti di testo, ecc.).

Editing di base

Se si avvia vim con:

$ vim somefile.txt

si vedrà un documento vuoto (presumendo che somefile.txt non esista. Se esiste, si vedrà il suo contenuto). Non sarà possibile modificarlo immediatamente - la modalità in cui si avvia vim è la modalità comando(Command Mode). In questa modalità sarà possibile utilizzare i comandi vim dalla tastiera.

Nota: Vim è un esempio dello stile Unix. Questo significa che non è vistoso, e non lascerà ferme le nostre mani. Non ha assistenti o giochi integrati. Esso però ci permetterà comunque di portare a termine il lavoro, ed anche velocemente. Anche tutti i suoi comandi sono case sensitive. A volte i comandi maiuscoli sono una versione con effetto più ampio (Template:Keypress sostituisce un carattere, Template:Keypress sostituisce una linea), altre volte sono comandi completamente diversi (Template:Keypress sposta il cursore in basso, Template:Keypress unisce due linee).

Per inserire il testo (prima del cursore) usare il comando Template:Keypress. Template:Keypress (i maiuscola) entra in inserimento all'inizio della linea. Per aggiungere del testo dopo il cursore (quello che la maggior parte degli utenti si aspetta) premere Template:Keypress. Premendo Template:Keypress posizionerà il cursore per l'inserimento alla fine della linea.

Si può tornare in modalità comando, in qualsiasi momento premendo Template:Keypress.

Spostamento

In vim, è possibile spostare il cursore usando le frecce della tastiera, ma questa non è considerata la vim way. Si dovrebbe spostare la mano tropo a destra dalla normale posizione di battitura per raggiungere le frecce, e poi ritornare in posizione. Non è divertente.

In vim ci si può spostare in basso premendo Template:Keypress. Si può ricordare perché la lettera "j" punta verso il basso. Per spostare il cursore in alto premendo Template:Keypress. A sinistra con Template:Keypress (si trova a sinistra di "j"), ed a destra con Template:Keypress (L minuscolo).

Template:Keypress posizionerà il cursore all'inizio della linea, e Template:Keypress alla fine di essa.

Nota: Template:Keypress e Template:Keypress sono comunemente utilizzati nelle espressioni regolari per rappresentare l'inizio e la fine della linea. Le espressioni regolari sono molto potenti e comunemente usate negli ambienti *nix, quindi per ora sarà ingannevole, ma più avanti si capirà "l'idea" dietro a molti di queste combinazioni da tastiera.

Per spostarsi di una parola premere Template:Keypress. Template:Keypress considera come appartenenti alla parola più caratteri (ad esempio gli underscore, i trattini come parte della parola). Per tornare indietro di una parola si usa Template:Keypress. Anche in questo caso Template:Keypress considera come appartenenti alla parola più caratteri. Per avanzare fino alla fine di una parola Template:Keypress, Template:Keypress per comprendere altri caratteri.

Per spostarsi all'inizio di una frase Template:Keypress effettuerà lo spostamento. Template:Keypress farà invece l'opposto, spostandosi alla fine della frase. Per uno spostamento maggiore Template:Keypress posizionerà il cursore all'inizio del paragrafo. Template:Keypress sposterà il cursore alla fine dell'intero paragrafo.

Per spostarsi all'inizio dello schermo, Template:Keypress effettuerà lo spostamento. Template:Keypress sposterà il cursore al centro dello schermo, ed Template:Keypress alla fine della schermata. Template:Keypress posizionerà il cursore all'inizio del file, Template:Keypress invece alla sua fine. Template:Keypress permetterà di scorrere pagina per pagina.

Ripetere i comandi

Se un comando è preceduto da un numero, allora questo comando verrà eseguito un numero di volte uguale al numero premuto (ci sono delle eccezioni, ma possono avere senso, come il comando Template:Keypress). Ad esempio premendo Template:Keypress ed inserendo il testo "Help! " e successivamente Template:Keypress verrà inserito il testo "Help! Help! Help! “. Premendo Template:Keypress il cursore si sposterà in avanti di due paragrafi. Questo è utile con alcuni dei comandi di seguito.

Cancellare

Il comando Template:Keypress cancellerà il carattere sotto al cursore. Template:Keypress cancellerà il carattere prima del cursore. Qui è dove la funzione dei numeri diventa interessante. Template:Keypress cancellerà 6 caratteri. Premere Template:Keypress (punto) ripeterà il comando precedente. Quindi, ipotizzando di avere la parola "foobar" in diversi punti, ma dopo averci pensato, si preferisce usare la parola "foo". Spostare il cursore sopra la lettera "b", premere Template:Keypress, spostare il cursore sulla successiva parola "foobar" e premere Template:Keypress (punto).

Il comando Template:Keypress comunicherà a vim che si intende cancellare qualcosa. Dopo aver premuto Template:Keypress, sarà necessario indicare cosa cancellare. Si possono utilizzare anche i comandi di movimento. Template:Keypress cancellerà finito alla prossima parola. Template:Keypress cancellerà fino all'inizio della linea. Anteporre un numero al comando di eliminazione funzionerà altrettanto: Template:Keypress cancellerà fino alle tre parole successive. Template:Keypress (maiuscolo) è una scorciatoia per cancellare fino alla fine della linea (come Template:Keypress). Premere Template:Keypress cancellerà tutta la linea.

Per cancellare e sostituire la parola corrente, posizionare il cursore sulla parola ed eseguire il comando Template:Keypress. Questo comando cancellerà la parola e cambierà la modalità in inserimento. Per sostituire una singola lettera usare Template:Keypress.

Annulla e ripeti

Vim ha una funzione appunti integrata (anche nota come buffer). Le azioni possono essere annullate con il tasto Template:Keypress e ripetute con la combinazione Template:Keypress.

Modalità visuale

Premendo Template:Keypress si entrerà in visual mode. In questa modalità è possibile selezionare parti di testo, una volta selezionato premendo Template:Keypress verrà memorizzato nel buffer, è possibile tagliare il testo premendo Template:Keypress. Template:Keypress incollerà il testo memorizzato nel buffer dopo il cursore, Template:Keypress prima. Il tasto Template:Keypress attiverà la visual line mode, analoga alla modalità precedente ma con effetto su intere linee. Template:Keypress invece per i blocchi di testo.

Nota: In qualsiasi momento si cancelli del testo, questo vine inserito nel buffer e sarà disponibile per essere incollato.

Trova e sostituisci

Per cercare una parola o un carattere nel file, basterà semplicemente premere Template:Keypress e successivamente il/i carattere/i da cercare ed infine premere Template:Keypress. Per visualizzare l'occorrenza successiva della ricerca usare Template:Keypress, mentre per la precedente usare Template:Keypress.

Per cercare e sostituire usare il comando substitute Template:Keypress. La sua sintassi è [range]s///[arguments]. Ad esempio:

Comando        Risultato
:s/xxx/yyy/    Sostituisce xxx con yyy alla prima occorrenza
:s/xxx/yyy/g   Sostituisce xxx con yyy alla prima occorrenza, globalmente, (in una intera frase)
:s/xxx/yyy/gc  Sostituisce xxx con yyy globalmente con conferma
:%s/xxx/yyy/g  Sostituisce xxx con yyy globalmente in tutto il file

Si può usare il comando global Template:Keypress per ricercare un pattern ed eseguire un comando per ogni corrispondenza. La sintassi è: [range]:g//[cmd].

Comando  Risultato
:g/^#/d  Cancella tutte le linee che iniziano per #
:g/^$/d  Cancella tutte le linee che sono vuote

Salvare ed uscire

Per salvare e/o uscire, sarà necessario usare la modalità Ex. I comandi della modalità Ex sono preceduti da Template:Keypress. Per salvare un file usare :w nomefile. Per uscire Template:Keypress. Se invece si desidera uscire senza salvare le modifiche effettuate, usare Template:Keypress. Per salvare ed uscire Template:Keypress. Esiste anche un'altra scorciatoia per salvare ed uscire cioè la combinazione Template:Keypress (maiuscole).

Altri comandi

  1. Premendo Template:Keypress verrà cancellato il carattere sotto al cursore, e verrà attivata la modalità inserimento. Template:Keypress cancellerà l'intera linea ed attiverà la modalità inserimento.
  2. Template:Keypress creerà una nuova linea sotto alla linea corrente ed attiverà la modalità inserimento. Template:Keypress invece creerà una nuova linea sopra a quella corrente ed avvierà la modalità inserimento.
  3. Template:Keypress memorizzerà una linea nel buffer.
  4. Template:Keypress cancellerà la linea corrente ed attiverà la modalità inserimento.
  5. Template:Keypress evidenzierà la parola corrente e Template:Keypress la cercherà.

Configurazione

Il file di configurazione personale di vim si trova nella cartella home dell'utente ~/.vimrc. Gli utenti esperti di vim tendono a tenere un ~/.vimrc molto ben strutturato. La configurazione globale di vim è situata in /etc/vimrc. La variabile di ripiego $VIM è definita come /usr/share/vim/. Ad esempio per creare uno schema di colori globale il file *.vim dello shema di colori dovrebbe essere salvato in /usr/share/vim/vimfiles/.

Correntemente, la configurazione globale di vim in Arch Linux è molto basilare a differenza delle configurazioni di default di vim nelle altre distribuzioni. Per ottenere i comportamenti comunemente utilizzati (come evidenziare la sintassi, il ritorno alla linea dell'ultima modifica...), utilizzare il file di configurazione d'esempio:

cp /etc/vimrc /etc/vimrc.bak
cp /usr/share/vim/vim73/vimrc_example.vim /etc/vimrc

File di backup

Vim per default crea un backup di un file modificato nella stesa cartella del file chiamandolo nomefile~. Per evitare di ingombrare, alcuni utenti impostano vim per utilizzare una apposita cartella per i backup:

set backupdir=~/.vim/backup,/tmp

Oppure è possibile disabilitare questa funzione:

set nobackup
set nowritebackup
set noswapfile    ! (disabilita i file swap)

Ripetizione della ricerca

Con quest'opzione, trova successivo torna all'inizio del file quando ne raggiunge la fine. Similarmente, trova precedente va alla fine del file quando ne raggiunge l'inizio.

set wrapscan

Controllo ortografico

set spell

Con questa opzione Vim evidenzierà le parole non scritte correttamente. Muovere il cursore su una parola errata e usare Template:Keypress per vedere le correzioni proposte.

Solo il dizionario inglese sarà installato di default, altri possono essere trovati nei repository ufficiali. Per ottenere una lista dei linguaggi disponibili, eseguire:

# pacman -Ss vim-spell

I file dei dizionari possono essere trovati anche nell'archivio FTP di Vim. Mettere i dizionari scaricati nella cartella ~/.vim/spell e configurare il dizionario eseguendo: :setlocal spell spelllang=LL.

Tip:
  • Per abilitare il controllo ortografico soltanto per i documenti LaTeX (o TeX), aggiungere autocmd FileType tex setlocal spell spelllang=en_us al file ~/.vimrc oppure in /etc/vimrc, e riavviare vim. Per il controllo ortografico di linguaggi diversi dall'inglese, semplicemente sostituire en_us con il valore appropriato al proprio linguaggio.
  • Sarà possibile abilitare il controllo ortografico per alcuni tipi di file (ad esempio *.txt) usando il plugin FileType ed una regola personalizzata per dichiarare il tipo di file. Per abilitare il controllo ortografico per ogni file di tipo *.txt, creare il file /usr/share/vim/vimfiles/ftdetect/plaintext.vim, ed inserire la linea autocmd BufRead,BufNewFile *.txt setfiletype plaintext nel file. Successivamente, inserire la linea autocmd FileType plaintext setlocal spell spelllang=en_us nel proprio file ~/.vimrc oppure in /etc/vimrc, e riavviare vim.

Evidenziare la sintassi

Per abilitare l'opzione ed evidenziare la sintassi (syntax highlighting) (vim supporta una vasta lista di linguaggi di programmazione):

filetype plugin on
syntax on

Esempio di ~/.vimrc

Un esempio della configurazione di Vim.

Unire file (Vimdiff)

Vim include un editor di comparazione (un programma che può mostrare le differenze tra due file). Può essere avviato con vimdiff file1 file2; successivamente usare:

]c :        - differenza successiva
[c :        - differenza precedente
Ctrl+w +w   - cambio finestra
do          - invia modifica
dp          - ottieni modifica
zo          - mostra il testo nascosto
zc          - nasconde il testo
:diffupdate - ricontrolla i file in cerca di differenze

Vim Tips

Trucchi per portare a termine alcuni compiti.

Numeri linea

  1. Per mostrare i numeri linea :set number.
  2. Per andare ad una linea specifica :<numero linea>.

Sostituzioni tra linee

Per sostituire solo tra un intervallo di certe linee:

:n,ns/one/two/g

Ad esempio, per sostituire il pattern 'one' con 'two' tra le linee 3 e 4, è possibile eseguire:

:3,4s/one/two/g

Ripristinare la posizione del cursore nei file

Se si desidera che all'apertura di un file vim posizioni il cursore dove era situato durante l'ultima modifica del file, aggiungere la seguente linea al file ~/.vimrc:

if has("autocmd")
au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g`\"" | endif
endif

Consultare anche questo articolo del wiki di Vim.

Spazio vuoto all'inizio della finestra di gvim

Quando si usa un window manager configurato per ignorare le dimensioni delle finestre, gvim riempirà l'area non funzionale con il colore dell sfondo del tema GTK.

Una soluzione è disabilitare la barra dei menu in .vimrc, questo farà apparire la finestra di gvim come dovrebbe, occupando l'intera area:

set go-=m "remove menubar

Un'altra soluzione consiste nel rendere più omogeneo il colore dello sfondo: semplicemente inserendo questa linea nel file ~/.gtkrc-2.0:

style "vimfix" {
  bg[NORMAL] = "#242424" # this matches my gvim theme 'Normal' bg color.
}
widget "vim-main-window.*GtkForm" style "vimfix"

Sostituire il comando vi con vim

Eseguire questi comandi:

# ln -s $(which vim) /usr/local/bin/vi
# ln -s $(which vim) /usr/local/bin/view

Leggere anche http://superuser.com/questions/27091/vim-to-replace-vi

Altre risorse

Ufficiali

Tutorial

Video

Esempi di configurazione

Altro

  • HOWTO Vim - Articolo del wiki di Gentoo su cui è basato questo articolo (autore sconosciuto).
  • Vivify - Un editor dello schema di colori per Vim