{{tag>shell Jammy}}
====== Bash : Bourne-Again Shell ======
**[[wpfr>Bourne-Again_shell|Bash]]** est un //[[:shell]]//, soit un interpréteur de ligne de commande : il permet de "discuter" avec l'ordinateur, en [[:commande shell|ligne de commande]]. Sur Ubuntu c'est le //shell// utilisé par défaut dans le [[:terminal]]. Il est bien évidemment libre, sous licence GPL.\\
La plupart des scripts que vous verrez sur la documentation comporte un //[[wpfr>shebang]]// ''#!/bin/bash'', votre système utilisera donc **Bash** pour interpréter les commandes.
**Bash** n'est pas totalement compatible avec **[[:ZSH]]**, un shell plus orienté pour l'interactivité avec l'utilisateur.
===== Introduction / Utilisation =====
Voir l'utilisation des [[:commande_shell|commandes et lignes de commandes]] que les //shells// comme **Bash** peuvent interpréter.
===== Utilisation avancée =====
==== Création de scripts shell ====
* Commencer par le [[:tutoriel:script_shell|tutoriel d'introduction aux scripts shell]] ou [[:projets:ecole:scripting:initiation_au_shell|Initiation au shell (cours fait par des Ubunteros)]]
* [[https://abs.traduc.org/abs-fr/|Guide avancé d'écriture des scripts Bash]]
==== Séparateur de mot ====
L'IFS est le ou les caractères qui servent de séparateur. Voici un bout de code pour comprendre par l'exemple :
phrase="plusieurs mots...
sur une ligne ?"
function afficher_phrase(){
for chaine in `echo "$phrase"`; do
echo $chaine
done
}
afficher_phrase
IFS='
'
echo "Séparateur interne à bash changé"
afficher_phrase
Pour plus d'explication, voir [[wpfr>Input_Field_Separators|IFS]] sur Wikipédia.
==== Une meilleure gestion de l'historique ====
Par défaut, toutes les commandes tapées dans un terminal sont enregistrées dans votre historique et vous pouvez les retrouver en appuyant sur les touches fléchées //haut// ''↑'' et //bas// ''↓''. La façon dont vous parcourez l'historique peut être améliorée de façon à ce que si vous tapez un début de commande avant votre recherche, vous puissiez accéder uniquement aux entrées commençant par ce que vous venez de taper. Vous me suivez ?
[[:tutoriel:comment_modifier_un_fichier|Ouvrez le fichier]] ''~/.inputrc'' (ou créer-le s'il n'existe pas) et ajoutez-y :
"\e[A": history-search-backward
"\e[B": history-search-forward
[[:tutoriel:comment_modifier_un_fichier|Ouvrez le fichier]] ''~/.bashrc'' et ajoutez-y :
shopt -s histappend
PROMPT_COMMAND='history -a'
==== Fonctionnalité "push-line", édition d'une deuxième ligne puis revenir à la première ====
La fonctionnalité ''push-line'' sert à éditer une deuxième ligne de code en effaçant la première que vous éditiez et en la gardant en mémoire pour pouvoir la restaurer après avoir exécuter la deuxième commande : ''Ctrl''+''U'' puis ''Ctrl''+''Y''.
Voir [[https://linuxfr.org/forums/programmation-shell/posts/recherche-d-une-fonctionnalite-zsh-bash#comment-1905228|Recherche d'une fonctionnalité zsh / bash]].
===== Les fichiers de configuration Bash =====
==== ~/.bashrc ====
Le fichier ''~/.bashrc'' permet la configuration lors du lancement du programme **Bash**.
Il est possible de personnaliser le prompteur :
dans votre éditeur de texte préférer chercher ''PS1''((sigle de prompt shell 1)).
Avec [[:gedit]] vous pouvez presser ''Ctrl''+''F'' pour rechercher dans le fichier.
Remplacer la première occurrence ou toutes occurrences par cela :
PS1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\n\$ '
En supprimant ''\h'' (nom d'hôte) il n'y a plus le nom de votre ordinateur.
En ajoutant ''\n'' (saut de ligne) avant le dollar le curseur ira sur une nouvelle ligne.
Il y a beaucoup plus de personnalisation possible mais ne nous étalons pas.
==== ~/.bash_aliases ====
Le fichier ''~/.bash_aliases'' permet de séparer le script ''.bashrc'' des [[:alias]].\\
Vous pouvez y définir des variables qui seront chargées à chaque lancement de terminal.
Vous pouvez par exemple mettre de la couleur dans les pages du man plutôt que d'avoir du blanc.
[[https://blog.shevarezo.fr/post/2018/01/25/comment-avoir-couleurs-pages-man-linux|ce site vous dit comment faire]].\\ Plusieurs couleurs sont disponibles via l'utilisation de code couleurs : [[https://misc.flogisoft.com/bash/tip_colors_and_formatting|les choix de couleurs]].
==== ~/.bash_history ====
''~/.bash_history'' est le fichier consulté lorsqu'on utilise les flèches //haut// ''↑'' et //bas// ''↓'' pour rechercher une commande.\\
On peut afficher le contenu du fichier avec la commande
history
Pour rechercher plus rapidement, utilisez ''Ctrl''+''R'' dans le terminal puis entrez le texte recherché.\\ Utilisez plusieurs fois ''Ctrl''+''R'' et non pas les flèches pour retrouver les commandes qui correspondent.
==== ~/.profile ====
Comme indiqué dans le fichier ''~/.profile'', celui-ci n'est lu que si ''~/.bash_profile'' ou ''~/.bash_login'' n'existe pas.
Il est interprété à chaque connexion de l'utilisateur (au démarrage de la session), contrairement à ''[[#~/.bashrc]]'' qui est interprété à chaque lancement de **Bash** (à chaque ouverture d'un onglet du [[:terminal]] par ex.).
Il permet entre autre de définir de nouveaux [[:chemins]] pour la [[:variables_d_environnement|variable d'environnement]] ''[[:variables_d_environnement#variables_liees_aux_emplacements_de_fichiers|$PATH]]''.
===== Voir aussi =====
* **(//en//)** [[https://www.gnu.org/software/bash/|site officiel de Bash]]
* [[:variables_d_environnement|Les variables d'environnement]]
* [[:tutoriel:script_shell|Introduction aux scripts shell]]
* [[wpfr>Bourne-Again_shell]]
----
//Contributeur(s) : [[:utilisateurs:Id2ndR]], [[:utilisateurs:Amiralgaby]]//