Bash tips: differenze tra le versioni

nessun oggetto della modifica
(in espansione!)
Nessun oggetto della modifica
Riga 25: Riga 25:


Ecco un esempio stupido, creare una directory ed entrarvi:
Ecco un esempio stupido, creare una directory ed entrarvi:
<pre>
$ mkdir /usr/local/nuovo-programma
$ mkdir /usr/local/nuovo-programma
$ cd ESC.
$ cd ESC.
</pre>


Altro esempio forse un po' più utile, creare velocemente uno script:
Altro esempio forse un po' più utile, creare velocemente uno script:
<pre>
$ :> /usr/local/bin/nomescript
$ :> /usr/local/bin/nomescript
$ chmod +x ESC.
$ chmod +x ESC.
$ gvim ESC.
$ gvim ESC.
</pre>


===Editing della linea di comando===
===Editing della linea di comando===
Vi sono due differenti modalità di shortcut in bash che richiamano i comandi di due famosi editor di testo. La prima nonché quella di default è, per ragioni storiche, la modalità emacs, la seconda, ovvero quella '''VI'''ncente, è la modalità VI.
Vi sono due differenti modalità di shortcut in bash che richiamano i comandi di due famosi editor di testo. La prima nonché quella di default è, per ragioni storiche, la modalità emacs, la seconda, ovvero quella '''VI'''ncente, è la modalità VI.
Per passare dall'una all'altra si può dare nel prompt i seguenti comandi oppure inserirli nel file ~/.bashrc:
Per passare dall'una all'altra si può dare nel prompt i seguenti comandi oppure inserirli nel file ~/.bashrc:
<pre>set -o vi</pre>
$ set -o vi
<pre>set -o emacs</pre>
$ set -o emacs


Alcuni tasti di scelta rapida per l'editing da linea di comando:
Alcuni tasti di scelta rapida per l'editing da linea di comando:
Riga 106: Riga 102:
Questa funzionalità non è abilitata di default; bisogna modificare il file <code>/etc/inputrc</code> (o creare un analogo file <code>.inputrc</code> nella propria home), aggiungendo le righe:
Questa funzionalità non è abilitata di default; bisogna modificare il file <code>/etc/inputrc</code> (o creare un analogo file <code>.inputrc</code> nella propria home), aggiungendo le righe:


<pre>
# PgUp/Down searches history in bash
# PgUp/Down searches history in bash
"\e[5~":        history-search-backward
"\e[5~":        history-search-backward
"\e[6~":        history-search-forward
"\e[6~":        history-search-forward
</pre>


In questo esempio si è scelto di usare i tasti <code>PGUP</code> e <code>PGDOWN</code>.
In questo esempio si è scelto di usare i tasti <code>PGUP</code> e <code>PGDOWN</code>.
Riga 118: Riga 112:
Il carattere <code>!</code> permette di richiamare un preciso comando dello storico:
Il carattere <code>!</code> permette di richiamare un preciso comando dello storico:


<pre>
$ !-3
$ !-3
</pre>


richiama ed esegue il terzultimo comando, mentre:
richiama ed esegue il terzultimo comando, mentre:


<pre>
$ !ta
$ !ta
</pre>


richiama ed esegue l'ultimo comando che comincia con '''ta''' (potrebbe essere: <code>tail -f /var/log/messages</code>). Il <code>'''!!'''</code> richiama invece l'ultimo comando.
richiama ed esegue l'ultimo comando che comincia con '''ta''' (potrebbe essere: <code>tail -f /var/log/messages</code>). Il <code>'''!!'''</code> richiama invece l'ultimo comando.
Riga 132: Riga 122:
Se si vuole richiamare il comando ma non eseguirlo si può usare il modificatore <code>:p </code>(''print''), ad esempio
Se si vuole richiamare il comando ma non eseguirlo si può usare il modificatore <code>:p </code>(''print''), ad esempio


<pre>
$ !ta:p
$ !ta:p
</pre>


stampa l'ultimo comando che inizia con ''ta''.
stampa l'ultimo comando che inizia con ''ta''.
Riga 140: Riga 128:
Per richiamare l'ultimo comando che contiene una certa parola (non all'inizio):
Per richiamare l'ultimo comando che contiene una certa parola (non all'inizio):


<pre>
$ !?parola?
$ !?parola?
</pre>


È possibile anche richiamare un parametro di un comando usando <code>''':'''</code> seguito dal numero del parametro (0 indica il comando stesso). Ad esempio:
È possibile anche richiamare un parametro di un comando usando <code>''':'''</code> seguito dal numero del parametro (0 indica il comando stesso). Ad esempio:


<pre>
$ man !-1:0
$ man !-1:0
</pre>


visualizza la pagina di manuale dell'ultimo comando.
visualizza la pagina di manuale dell'ultimo comando.
Riga 154: Riga 138:
Per eseguire un comando con gli stessi argomenti del comando precedente:
Per eseguire un comando con gli stessi argomenti del comando precedente:


<pre>
$ nuovocomando !!:*
$ nuovocomando !!:*
 
</pre>
 
Il comando <code>'''history'''</code> mostra l'elenco numerato per una veloce ricerca dei comandi da richiamare con <code>'''!numero'''</code>; <code>'''!$'''</code> equivale all'ultimo argomento del precedente comando di conseguenza funziona anche <code>'''!numero$'''</code>.


Per ulteriori informazioni sull'uso interattivo dello storico si rimanda all'apposita sezione del manuale di riferimento:
Per ulteriori informazioni sull'uso interattivo dello storico si rimanda all'apposita sezione del manuale di riferimento:


* [http://www.gnu.org/software/bash/manual/bashref.html#SEC117 Hystory expansion]
* [http://www.gnu.org/software/bash/manual/bashref.html#History-Interaction Hystory expansion]


==Bash Scripting==
==Bash Scripting==
Riga 167: Riga 152:
===Variabili speciali===
===Variabili speciali===


; <code>$?</code> : contiene il valore di uscita dell'ultimo comando o funzione. Il comando ha successo se ritorna zero, qualsiasi altro valore indica invece un codice di errore;
; <code>$?</code> : contiene il valore di uscita dell'ultimo comando o funzione. Il comando ha successo se restituisce zero, qualsiasi altro valore indica invece un codice di errore;
 
''Esempio:''
$ cd ..
$ echo $?
0
 
$ cd ...
$ echo $?
1


; <code>$@</code> : contiene la lista dei parametri passati allo script corrente. Ogni parametro viene opportunamente quotato, questo permette l'utilizzo di questa variabile nei '''cicli for''' per processare (ad esempio) una lista di nomi di file che possono contenere anche spazi. L'uso di questa variabile è quindi in genere consigliato rispetto a <code>'''$*'''</code> che ha la stessa funzione ma non quota i vari parametri;
; <code>$@</code> : contiene la lista dei parametri passati allo script corrente. Ogni parametro viene opportunamente quotato, questo permette l'utilizzo di questa variabile nei '''cicli for''' per processare (ad esempio) una lista di nomi di file che possono contenere anche spazi. L'uso di questa variabile è quindi in genere consigliato rispetto a <code>'''$*'''</code> che ha la stessa funzione ma non quota i vari parametri;
Riga 173: Riga 167:
''Esempio:''
''Esempio:''
<pre>
<pre>
FILES=$@
FILES=$@


for file in $FILES; do
for file in $FILES; do
Riga 193: Riga 187:
In Bash una stringa non è altro che una variabile, si indica dunque con <code>${nome}</code> oppure con la forma abbreviata <code>$nome</code>. Il nome dentro le graffe può essere seguito da un modificatore che manipola la variabile, ad esempio:
In Bash una stringa non è altro che una variabile, si indica dunque con <code>${nome}</code> oppure con la forma abbreviata <code>$nome</code>. Il nome dentro le graffe può essere seguito da un modificatore che manipola la variabile, ad esempio:


<pre>VAR="stringa-di-esempio"
VAR="stringa-di-esempio"
echo ${VAR#stringa-}</pre>
echo ${VAR#stringa-}


elimina "stringa-" dall'inizio della variabile.
elimina "stringa-" dall'inizio della variabile.
Riga 238: Riga 232:
; <code>;</code> : separatore di comandi, il secondo comando verrà eseguito in ogni caso
; <code>;</code> : separatore di comandi, il secondo comando verrà eseguito in ogni caso


<pre>
$ cd ... && echo done
$ cd ... && echo done
$ cd ... ; echo done
$ cd ... ; echo done
</pre>


Nel caso specifico di un'applicazione che resta in esecuzione il secondo comando non verrà eseguito finché il
Nel caso specifico di un'applicazione che resta in esecuzione il secondo comando non verrà eseguito finché il
primo non sarà terminato, in questo caso si usa <code>'''&'''</code> e saranno eseguiti entrambi in quanto il primo comando viene mandato in background; prendiamo xterm come esempio:
primo non sarà terminato, in questo caso si usa <code>'''&'''</code> e saranno eseguiti entrambi in quanto il primo comando viene mandato in background; prendiamo xterm come esempio:


<pre>
$ xterm && xterm -rv
$ xterm && xterm -rv
$ xterm ; xterm -rv
$ xterm ; xterm -rv
$ xterm & xterm -rv
$ xterm & xterm -rv
</pre>


; <code>|</code> : pipe, passa l'output del comando che la precede come input del comando che la segue
; <code>|</code> : pipe, passa l'output del comando che la precede come input del comando che la segue


<pre>
$ ls -A1 | less
$ ls -A1 | less
</pre>


; <code>||</code> : operatore logico OR, restituisce esito positivo se almeno una delle condizioni di verifica valutate è vera
; <code>||</code> : operatore logico OR, restituisce esito positivo se almeno una delle condizioni di verifica valutate è vera
Riga 271: Riga 259:




Dirige output di comando su file: <pre> $ man xterm > xterm.txt </pre>
Dirige output di comando su file:
Dirige output di errore su file: <pre> $ xterm 2> xterm-errors.log </pre>
$ man xterm > xterm.txt
Entrambi su file diversi: <pre> $ xterm > xterm_out.log 2> xterm_err.log </pre>
Dirige output di errore su file:
Entrambi sullo stesso file: <pre> $ xterm &> xterm.log </pre>
$ xterm 2> xterm-errors.log
Entrambi sullo stesso file, alternativa:<pre>$ xterm > xterm.log 2>&1
Entrambi su file diversi:
$ xterm > /dev/null 2>&1 </pre>
$ xterm > xterm_out.log 2> xterm_err.log
Aggiunge nuovo testo ad un file: <pre> $ man uxterm >> xterm.txt </pre>
Entrambi sullo stesso file:
Cancella contenuto di un file: <pre> $ :> xterm.txt </pre>
$ xterm &> xterm.log
Entrambi sullo stesso file, alternativa:
$ xterm > xterm.log 2>&1
Appende nuovo testo a quello già presente in un file:
$ man uxterm >> xterm.txt
Cancella contenuto di un file:
$ :> xterm.txt




Riga 295: Riga 289:
Rinomina tutti i file <code>*.txt</code> della directory corrente in <code>*.log</code>:
Rinomina tutti i file <code>*.txt</code> della directory corrente in <code>*.log</code>:


<pre>for f in *.txt; do mv "$f" "${f/%txt/log}"; done</pre>
$ for f in *.txt; do mv "$f" "${f/%txt/log}"; done


==Miscellanea==
==Miscellanea==
Riga 301: Riga 295:
# seleziona, apri file, incolla, salva: noioso
# seleziona, apri file, incolla, salva: noioso
# quota il tutto e appendi ad un file con echo: già meglio
# quota il tutto e appendi ad un file con echo: già meglio
# <code>ctrl-x</code> <code>ctrl-e</code>, si apre il nostro editor di fiducia e salviamo: superbo
# <code>'''CTRL-x'''</code> <code>'''CTRL-e'''</code>, si apre il nostro editor di fiducia e salviamo: superbo
 
 
Processo in background.
Si avvia un processo che tiene occupato il prompt:
$ xterm
 
anziché chiuderlo è possibile interromperlo, per liberare momentaneamente il prompt e magari eseguire altro, digitando <code>'''CTRL-z'''</code>. Si può quindi controllare quali processi siano riesumabili:
$ jobs -l
  [1]+  5598 Stopped                xterm
 
Per riprenderlo si usa il numero tra le parentesi quadre (l'altro è il pid):
$ fg 1
 
Se invece si vuole riesumare mantenendo libero il prompt:
$ bg 1
 




271

contributi