36.9. Problèmes de portabilité

Il est plus facile de migrer un shell, qu'un script shell.

-- Larry Wall

Ce livre s'occupe principalement des scripts Bash sur un système GNU/Linux. De la même façon, les utilisateurs de sh et ksh y trouveront beaucoup d'idées de grande valeur.

Un grand nombre de shells et langages de scripts semblent converger vers le standard POSIX 1003.2. Appeler Bash avec l'option --posix ou insérer un set -o posix au début d'un script fait que Bash se conforme très étroitement à ce standard. Une autre alternative consiste à utiliser, dans le script, un en-tête sha-bang #!/bin/sh plutôt que #!/bin/bash [122] Notez que /bin/sh est un lien vers /bin/bash pour Linux ainsi que dans certaines autres versions d'UNIX et qu'un script appelé de cette façon désactive les fonctionnalités étendues de Bash.

La plupart des scripts Bash fonctionneront directement avec ksh, et vice-versa, car Chet Ramey a beaucoup travaillé sur le portage des fonctionnalités de ksh aux dernières versions de Bash.

Sur un UNIX commercial, les scripts utilisant les fonctionnalités spécifiques aux commandes standards GNU peuvent ne pas fonctionner. Ceci devient de moins en moins un problème ces dernières années car les outils GNU ont petit à petit remplacé les versions propriétaires même sur les UNIX « solides ». La publication des sources de nombreux outils de Caldera ne fera qu'accélérer la tendance.

Bash dispose de certaines fonctionnalités qui manquent au shell Bourne traditionnel. Parmi celles-ci :

Voir la FAQ de Bash pour une liste complète.

36.9.1. Une suite de test

Mettons en lumière quelques-unes des incompatibilités entre Bash et le shell Bourne classique. Téléchargez et installez le « Shell Bourne de Heirloom » et lancez le script ci-dessous, d'abord sur Bash, ensuite sur le sh classique.

Exemple 36.21. Suite de test

#!/bin/bash
# test-suite.sh
# A partial Bash compatibility test suite.


# Double brackets (test)
String="Double brackets supported?"
echo -n "Double brackets test: "
if [[ "$String" = "Double brackets supported?" ]]
then
  echo "PASS"
else
  echo "FAIL"
fi


# Double brackets and regex matching
String="Regex matching supported?"
echo -n "Regex matching: "
if [[ "$String" =~ R.....matching* ]]
then
  echo "PASS"
else
  echo "FAIL"
fi


# Arrays
test_arr=FAIL
Array=( If supports arrays will print PASS )
test_arr=${Array[5]}
echo "Array test: $test_arr"


#  Completing this script is an exercise for the reader.
#  Add to the above similar tests for double parentheses,
#+ brace expansion, $() command substitution, etc.

exit $?



[122] Or, better yet, #!/bin/env sh.