Bip visuel mini-Howto (Visual bell mini-Howto)

Alessandro Rubini, rubini@linux.it
Traduction Jean-Albert Ferrez, Jean-Albert.Ferrez@epfl.ch

v2.2, 11 Novembre 1997
Ce document explique comment utiliser termcap pour configurer un bip visuel sur son système et comment désactiver à la demande le bip sonore.

1. Introduction

La console Linux émet un bip sonore lorsqu'un caractère BEL (code ASCII 7) est produit. Bien que ce soit un choix raisonnable dans la plupart des cas, bien des utilisateurs n'aiment pas que leur ordinateur fasse du bruit. Ce mini-howto est censé expliquer comment indiquer aux applications de ne pas produire de caractère BEL. Il explique également comment faire en sorte que le noyau et le serveur X Window ne sonnent pas en présence d'un caractère BEL. Notez que la plupart de ce document concerne la console texte, étant donné que la configuration du serveur X est triviale pour ceux qui travaillent dans un environnement graphique.

A mon avis, la meilleure attitude à adopter face à un ordinateur bruyant consiste à opérer au niveau du matériel, le mien n'a même pas de haut-parleur.

2. "Spekearectomy", ablation du haut-parleur

L'ablation du haut-parleur est de loin la solution la plus brillante au problème du bip sonore. Comme son nom l'indique, elle consiste à supprimer le bip à la source. L'opération est simple, elle ne nécessite pas d'anesthésie.

Les PC sont habituellement équipés d'un bouton ridicule servant à réduire la fréquence du CPU. Ce bouton n'est jamais utilisé dans un environnement multitâche, puisque l'on n'a jamais besoin de ralentir la machine pour utiliser des jeux basés sur des boucles de temporisation. Malheureusement, on ne peut pas utiliser ce bouton pour augmenter la fréquence du CPU, mais on peut l'utiliser pour activer/désactiver le haut-parleur. Parfois, ce dernier est utile même si vous préférez un ordinateur silencieux, par exemple pour signaler la fin d'une longue compilation. Pour modifier la fonction de ce bouton, il suffit de le déconnecter de la carte-mère et de le brancher en série avec le haut-parleur.

Cela dit, les possesseurs de portables n'ont pas accès au haut-parleur, pas plus qu'ils ne disposent d'un bouton inutile à réassigner. La solution pour ces utilisateurs réside dans la configuration de leurs logiciels, comme indiqué ci-dessous.

3. Configuration du bip console par console

Depuis la version 1.3.43, Martin Mares a modifié console.c, y ajoutant la possibilité de configurer la hauteur et la durée du bip. Chaque console peut être configurée pour avoir un bip de hauteur et/ou durée différente. Ce but est atteint au moyen de séquences d'échappement interprétées par le gestionnaire de la console. Vous pouvez configurer vos fichiers ~/.profile ou ~/.login pour choisir un bip particulier pour chaque console (ou, le cas échéant, pas de bip du tout).

Les séquences d'échappement fonctionnent comme suit :

Pour avoir par exemple un bip à 50Hz durant une seconde, faites "echo -e "\\33[10;50]\\33[11;1000]"" avec bash (le "-e" signifie `digère les séquences d'échappement'. Avec tcsh la commande devient "echo "\\033[10;50]\\033[11;1000]"".

Bien que je ne connaisse aucune version de la commande setterm qui supporte une telle configuration, il est possible qu'une version future offre une option permettant de configurer le bip.

Si vous utilisez Linux-1.3.43 ou plus récent, vous pouvez vous contenter des séquences d'échappement et interrompre votre lecture ici. Si votre noyau est plus vieux, ou si vous désirez un bip visuel, vous aller aimer le reste de ce document.

4. Concepts de base au sujet de Termcap et Terminfo

Le fichier /etc/termcap est un fichier texte contenant les "terminal capabilities" (capacités des terminaux, N.d.T.). Plusieurs applications utilisent les informations de termcap pour déplacer le curseur sur l'écran ou d'autres actions en relation avec ce dernier. tcsh, bash, vi et toutes les applications basées sur curses utilisent la base de données termcap.

La base de données décrit plusieurs types de terminaux. La variable d'environnement TERM sélectionne le comportement correct lors de l'exécution en indiquant aux applications quelle entrée de termcap utiliser.

Dans la base de données, chaque capacité d'un terminal est représentée par un code de deux lettres et une représentation de la séquence d'échappement permettant d'obtenir l'effet désiré. Les deux-points ":" servent de séparateur entre les différentes capacités. Par exemple, le bip sonore dont le code est "bl" apparaît généralement sous la forme "bl=^G", ce qui signifie que le bip est obtenu en "affichant" le caractère control-G, correspondant au code ASCII BEL.

En plus de bl, la capacité vb est reconnue. Elle est utilisée pour représenter le "bip visible". vb est généralement absent de l'entrée linux du fichier termcap.

La plupart des applications et librairies modernes utilisent la base de données terminfo au lieu de termcap. Cette base de données utilise un fichier par type de terminal et est située dans /usr/lib/terminfo; pour éviter de trop grands répertoires, les descriptions de chaque type de terminal sont stockées dans un répertoire nommé d'après la première lettre : ainsi, l'entrée linux se situe dans /usr/lib/terminfo/l/linux. Pour construire une entrée terminfo il faut "compiler" une description termcap, voir le programme tic et sa page de manuel.

5. Mise sur pied d'un bip visible

Vous pouvez ajouter une entrée pour la capacité vb dans votre fichier termcap, si ce n'est pas déjà fait. Dennis Henriksen (duke@diku.dk) a suggéré la ligne suivante dans l'entrée linux (appelée console dans les anciennes distributions) du fichier termcap :

:vb=\E7\E[?5h\E[?5l\E[?5h\E[?5l\E[?5h\E[?5l\E[?5h\E[?5l\E8:\

Le backslash final sert à cacher le retour à la ligne dans la base. Le code de Dennis fonctionne comme suit (selon ses propres mots) :

6. Désactivation du bip sonore dans la console texte

Si vous désirez imposer le bip visuel dans la console, vous pouvez utiliser l'entrée "bl" dans la termcap et lui donner la même valeur que pour "vb" ci-dessus. Cette aproche est pratique si vous ne voulez pas configurer chaque application (cela est de toutes façons décrit ci-dessous). J'utilise cette solution sur toutes les machines sur lesquelles j'utilise Linux sans pouvoir déconnecter le haut-parleur.

7. Empêcher les applications d'émettre des bips

Ceci est une liste incomplète d'applications qui peuvent être configurées pour utiliser l'entrée vb pour le type de terminal utilisé (utilisant soit termcap soit terminfo) :

8. La face cachée du problème

La mauvaise nouvelle est que toutes les applications n'utilisent pas termcap ou terminfo. La plupart des petits programmes ont le caractère 'backslash-a' (l'alarme) dans le code source C. Le code "alarme" devient un caractère ASCII BEL dans les chaînes de caractère du code binaire. Les vraies applications ne sont en principe pas de ce type, mais méfiez-vous des débutants en C qui vous donnent leurs programmes. Les pires, je vous assure, sont les étudiants en informatique.

La seule manière de réduire ces applications au silence est de procéder à une "spekearectomy", ou d'utiliser les séquences d'échappement dues à Martin Mares.