= Guide utilisateur WeeChat :author: Sébastien Helleu :email: flashcode@flashtux.org :lang: fr :toc: left :toclevels: 4 :toc-title: Table des matières :sectnums: :sectnumlevels: 3 :docinfo1: Ce manuel documente le client de messagerie instantanée WeeChat, il fait partie de WeeChat. La dernière version de ce document peut être téléchargée sur https://weechat.org/doc/[cette page ^↗^,window=_blank]. [[introduction]] == Introduction WeeChat (Wee Enhanced Environment for Chat) est un client de discussion libre, rapide et léger, conçu pour différents systèmes d'exploitation. [[features]] === Fonctionnalités Ses principales fonctionnalités sont les suivantes : * multi-protocoles (principalement IRC) * connexion multi-serveurs (avec SSL, IPv6, proxy) * petit, rapide et léger * paramétrable et extensible avec des extensions et des scripts * conforme aux RFCs IRC https://datatracker.ietf.org/doc/html/rfc1459[1459 ^↗^,window=_blank], https://datatracker.ietf.org/doc/html/rfc2810[2810 ^↗^,window=_blank], https://datatracker.ietf.org/doc/html/rfc2811[2811 ^↗^,window=_blank], https://datatracker.ietf.org/doc/html/rfc2812[2812 ^↗^,window=_blank] et https://datatracker.ietf.org/doc/html/rfc2813[2813 ^↗^,window=_blank] * proxy IRC et relai pour interfaces distantes * multi plates-formes (GNU/Linux, *BSD, macOS, Windows et d'autres systèmes) * 100% GPL, logiciel libre La liste complète des fonctionnalités peut être trouvée sur https://weechat.org/[cette page ^↗^,window=_blank]. [[prerequisites]] === Prérequis Pour installer WeeChat, vous devez avoir : * un système GNU/Linux (avec le compilateur et les outils associés pour le paquet des sources), ou un système compatible * droits "root" (pour installer WeeChat dans un répertoire système) * quelques bibliothèques (voir les <>). [[install]] == Installation [[binary_packages]] === Paquets binaires Les paquets binaires sont disponibles pour beaucoup de distributions, dont : * Arch Linux : `pacman -S weechat` * Cygwin (Windows) : sélectionnez les paquets WeeChat dans setup.exe * Debian/Ubuntu (ou toute distribution compatible Debian) : `apt-get install weechat-curses weechat-plugins` + Pour les dernières versions et les constructions nocturnes : https://weechat.org/download/debian/[dépôts Debian ^↗^,window=_blank] * Fedora Core : `dnf install weechat` * FreeBSD : `pkg install weechat` * Gentoo : `emerge weechat` * Mandriva/RedHat (ou toute distribution compatible avec les RPM) : `rpm -i /path/to/weechat-x.y.z-1.i386.rpm` * openSUSE : `zypper in weechat` * Sourcemage : `cast weechat` * macOS (avec https://brew.sh/[Homebrew ^↗^,window=_blank]) : `brew install weechat` (pour l'aide : `brew info weechat`) Des paquets additionnels peuvent être utiles également, comme weechat-plugins. Pour les autres distributions supportées, merci de vous référer au manuel de la distribution pour la méthode d'installation. [[containers]] === Conteneurs Des conteneurs avec WeeChat peuvent être construits ou installés directement depuis le https://hub.docker.com/r/weechat/weechat[Docker Hub ^↗^,window=_blank]. + Pour plus d'informations, voire le README dans le dépôt https://github.com/weechat/weechat-container[weechat-container ^↗^,window=_blank]. [[source_package]] === Paquet source WeeChat peut être compilé avec CMake ou les autotools (CMake est la méthode recommandée). [NOTE] Sous macOS, vous pouvez utiliser https://brew.sh/[Homebrew ^↗^,window=_blank] : `brew install --build-from-source weechat`. [[dependencies]] ==== Dépendances Le tableau suivant liste les paquets *requis* pour compiler WeeChat : [width="100%",cols="5,^3,.^15",options="header"] |=== | Paquet ^(1)^ | Version | Fonctionnalités | compilateur C (gcc / clang) | | Construction. | cmake | ≥ 3.0 | Construction (autotools toujours possible, mais CMake est recommandé). | pkg-config | | Détection des bibliothèques installées. | libncursesw5-dev ^(2)^ | | Interface ncurses. | libcurl4-gnutls-dev | | Transfert d'URL. | libgcrypt20-dev | | Données sécurisées, authentification IRC SASL. | libgnutls28-dev | ≥ 2.2.0 ^(3)^ | Extension IRC : support des connexions TLS, authentification IRC SASL (ECDSA-NIST256P-CHALLENGE). + Extension Relay : support des connexions TLS. | zlib1g-dev | | Extension Logger : compression des fichiers de log qui tournent (gzip). + Extention Relay : compression des messages (WeeChat -> client) avec https://zlib.net/[zlib ^↗^,window=_blank] (protocole weechat). + Extension Script : lecture du fichier d'index du dépôt (gzip). | libzstd-dev | ≥ 0.8.1 | Extension Logger : compression des fichiers de log qui tournent. + Extension Relay : compression des messages (WeeChat -> client) avec https://facebook.github.io/zstd/[Zstandard ^↗^,window=_blank] (protocole weechat). |=== [NOTE] ^(1)^ Le nom provient de la distribution GNU/Linux Debian Bullseye, la version et le nom peuvent être différents dans les autres distributions. ^(2)^ Il est recommandé de compiler avec libncurses**w**5-dev (le *w* est important). WeeChat peut compiler avec libncurses5-dev, mais ce n'est *PAS* recommandé : vous pourriez avoir des problèmes d'affichage avec les caractères larges. + ^(3)^ GnuTLS ≥ 3.0.21 est requis pour l'authentification SASL avec le mécanisme ECDSA-NIST256P-CHALLENGE. Le tableau suivant liste les paquets optionnels pour compiler WeeChat : [width="100%",cols="5,^3,.^15",options="header"] |=== | Paquet ^(1)^ | Version | Fonctionnalités | compilateur {cpp} (pass:[g++ / clang++]) | | Construction et lancement des tests, extension JavaScript. | gettext | | Internationalisation (traduction des messages ; la langue de base est l'anglais). | ca-certificates | | Certificats pour les connexions SSL. | libaspell-dev / libenchant-dev | | Extension spell. | python3-dev | ≥ 3.0 | Extension python. | libperl-dev | | Extension perl. | ruby2.7, ruby2.7-dev | ≥ 1.9.1 | Extension ruby. | liblua5.4-dev | | Extension lua. | tcl-dev | ≥ 8.5 | Extension tcl. | guile-2.2-dev | ≥ 2.0 | Extension guile (scheme). | libv8-dev | ≤ 3.24.3 | Extension javascript. | php-dev | ≥ 7.0 | Extension PHP. | libphp-embed | ≥ 7.0 | Extension PHP. | libxml2-dev | | Extension PHP. | libargon2-dev | | Extension PHP (si PHP ≥ 7.2). | libsodium-dev | | Extension PHP (si PHP ≥ 7.2). | asciidoctor | ≥ 1.5.4 | Construction de la page man et de la documentation. | ruby-pygments.rb | | Construction de la documentation. | libcpputest-dev | ≥ 3.4 | Construction et lancement des tests. |=== [NOTE] ^(1)^ Le nom provient de la distribution GNU/Linux Debian Bullseye, la version et le nom peuvent être différents dans les autres distributions. Si vous utilisez une distribution basée sur Debian ou Ubuntu, et si vous avez des entrées source "deb-src" dans votre fichier _/etc/apt/sources.list_, vous pouvez installer toutes les dépendances avec la commande : ---- # apt-get build-dep weechat ---- [[compile_with_cmake]] ==== Compilation avec CMake * Installation dans les répertoires systèmes (nécessite les droits _root_) : ---- $ mkdir build $ cd build $ cmake .. $ make $ sudo make install ---- * Installation dans un répertoire spécifique (par exemple dans votre "home") : ---- $ mkdir build $ cd build $ cmake .. -DCMAKE_INSTALL_PREFIX=/chemin/vers/répertoire $ make $ make install ---- Des options peuvent être utilisées pour CMake, avec le format : `-DOPTION=VALUE`. Liste des options couramment utilisées : [width="100%",cols="3m,3,3m,10",options="header"] |=== | Option | Valeurs | Valeur par défaut | Description | CMAKE_BUILD_TYPE | `Debug`, `Release`, `RelWithDebInfo`, `MinSizeRel` | | Type de construction : `Debug` (ou `RelWithDebInfo`) est recommandé si vous utilisez une version de développement de WeeChat. | CMAKE_INSTALL_PREFIX | répertoire | /usr/local | Le répertoire dans lequel WeeChat sera installé. | WEECHAT_HOME | répertoire | (chaîne vide) | Le répertoire "maison" par défaut lors du lancement de WeeChat. + Avec une valeur vide (recommandé), les répertoires XDG sont utilisés par défaut. Si non vide, un répertoire unique est utilisé pour tous les fichiers. La valeur peut aussi être 4 répertoires séparés par ":", dans cet ordre : config, data, cache, runtime. | ENABLE_ALIAS | `ON`, `OFF` | ON | Compiler <>. | ENABLE_BUFLIST | `ON`, `OFF` | ON | Compiler <>. | ENABLE_CHARSET | `ON`, `OFF` | ON | Compiler <>. | ENABLE_MAN | `ON`, `OFF` | OFF | Construire la page man. | ENABLE_DOC | `ON`, `OFF` | OFF | Construire la documentation HTML. | ENABLE_ENCHANT | `ON`, `OFF` | OFF | Compiler <> avec Enchant. | ENABLE_EXEC | `ON`, `OFF` | ON | Compiler <>. | ENABLE_FIFO | `ON`, `OFF` | ON | Compiler <>. | ENABLE_FSET | `ON`, `OFF` | ON | Compiler <>. | ENABLE_GUILE | `ON`, `OFF` | ON | Compiler <> (Scheme). | ENABLE_IRC | `ON`, `OFF` | ON | Compiler <>. | ENABLE_JAVASCRIPT | `ON`, `OFF` | OFF | Compiler <>. | ENABLE_LARGEFILE | `ON`, `OFF` | ON | Support des gros fichiers. | ENABLE_LOGGER | `ON`, `OFF` | ON | Compiler <>. | ENABLE_LUA | `ON`, `OFF` | ON | Compiler <>. | ENABLE_NCURSES | `ON`, `OFF` | ON | Compiler l'interface Ncurses. | ENABLE_NLS | `ON`, `OFF` | ON | Activer NLS (traductions). | ENABLE_PERL | `ON`, `OFF` | ON | Compiler <>. | ENABLE_PHP | `ON`, `OFF` | ON | Compiler <>. | ENABLE_PYTHON | `ON`, `OFF` | ON | Compiler <>. | ENABLE_RELAY | `ON`, `OFF` | ON | Compiler <>. | ENABLE_RUBY | `ON`, `OFF` | ON | Compiler <>. | ENABLE_SCRIPT | `ON`, `OFF` | ON | Compiler <>. | ENABLE_SCRIPTS | `ON`, `OFF` | ON | Compiler <> (Python, Perl, Ruby, Lua, Tcl, Guile, JavaScript, PHP). | ENABLE_SPELL | `ON`, `OFF` | ON | Compiler <>. | ENABLE_TCL | `ON`, `OFF` | ON | Compiler <>. | ENABLE_TRIGGER | `ON`, `OFF` | ON | Compiler <>. | ENABLE_TYPING | `ON`, `OFF` | ON | Compiler <>. | ENABLE_XFER | `ON`, `OFF` | ON | Compiler <>. | ENABLE_TESTS | `ON`, `OFF` | OFF | Compiler les tests. | ENABLE_CODE_COVERAGE | `ON`, `OFF` | OFF | Compiler avec les options de couverture de code. + Cette option ne devrait être utilisée que pour les tests, pour mesurer la couverture de tests. |=== Les autres options peuvent être affichées avec cette commande : ---- $ cmake -LA ---- Ou avec l'interface Curses : ---- $ ccmake .. ---- [[compile_with_autotools]] ==== Compilation avec autotools [WARNING] Seul CMake est officiellement supporté pour construire WeeChat. Vous ne devriez utiliser les autotools que si vous n'avez pas la possibilité d'utiliser CMake. + La compilation avec les autotools requiert plus de dépendances et est plus lente qu'avec CMake. * Installation dans les répertoires systèmes (nécessite les droits _root_) : ---- $ ./autogen.sh $ mkdir build $ cd build $ ../configure $ make $ sudo make install ---- * Installation dans un répertoire spécifique (par exemple dans votre "home") : ---- $ ./autogen.sh $ mkdir build $ cd build $ ../configure --prefix=/chemin/vers/répertoire $ make $ make install ---- Des options peuvent être utilisées pour le script _configure_, elles peuvent être affichées avec cette commande : ---- $ ./configure --help ---- [[run_tests]] ==== Lancement des tests Les paquets suivants sont nécessaires pour compiler les tests : * libcpputest-dev * C++ compiler Les tests doivent être activés pour compiler WeeChat (avec CMake) : ---- $ cmake .. -DENABLE_TESTS=ON ---- Ils peuvent être lancés après compilation depuis le répertoire de construction (avec CMake) : ---- $ ctest -V ---- [[git_sources]] === Sources Git Attention : les sources Git sont réservées aux utilisateurs avancés : il se peut que WeeChat ne compile pas et qu'il soit très instable. Vous êtes prévenus ! Pour récupérer les sources Git, tapez cette commande : ---- $ git clone https://github.com/weechat/weechat.git ---- Suivez alors les instructions du paquet source (voir <>). [[report_crashes]] === Rapporter les plantages Si vous avez eu des plantages, ou si vous souhaitez rapporter tout plantage futur de WeeChat, vous devez : * Compiler avec : ** les infos de debug (ou installer un paquet binaire avec les infos de debug), ** la vérification des adresses (« address sanitizer ») (facultatif). * Activer les fichiers _core_ sur votre système. * Installer gdb. [[debug_build]] ==== Construction en debug Si vous compilez avec CMake : ---- $ cmake .. -DCMAKE_BUILD_TYPE=Debug ---- [[address_sanitizer]] ==== Vérification des adresses Vous pouvez aussi activer la vérification des adresses (« address sanitizer »), ce qui provoquera immédiatement un plantage de WeeChat en cas de problème : ---- $ cmake .. -DCMAKE_BUILD_TYPE=Debug -DCMAKE_C_FLAGS=-fsanitize=address -DCMAKE_CXX_FLAGS=-fsanitize=address -DCMAKE_EXE_LINKER_FLAGS=-fsanitize=address ---- [WARNING] Vous ne devriez activer la vérification des adresses que si vous essayez de provoquer un plantage, ce qui n'est pas recommandé en production. Une fois compilé et installé, vous devez lancer WeeChat comme ceci : ---- $ ASAN_OPTIONS="detect_odr_violation=0 log_path=asan.log" weechat ---- En cas de plantage, la trace se trouve dans le fichier `asan.log`. [[core_files]] ==== Fichiers core Pour activer les fichiers _core_, vous pouvez utiliser l'option <> : ---- /set weechat.startup.sys_rlimit "core:-1" ---- Pour WeeChat ≤ 0.3.8 ou si vous voulez activer les fichiers core avant que WeeChat ne démarre, vous pouvez utiliser la commande `ulimit`. Par exemple sous Linux avec le shell _bash_, ajoutez cette ligne dans votre `~/.bashrc` : ---- ulimit -c unlimited ---- Ou une taille maximum : ---- ulimit -c 200000 ---- [[gdb_backtrace]] ==== Obtenir la trace avec gdb Lorsque WeeChat se plante, votre système génère un fichier _core_ ou _core.12345_ (_12345_ est l'identifiant du processus) si <>. Ce fichier est créé dans le répertoire où vous avez lancé WeeChat (ce n'est *pas* le répertoire où WeeChat est installé !). [NOTE] Sur certains systèmes comme Archlinux, les fichiers _core_ se trouvent dans un autre répertoire tel que _/var/lib/systemd/coredump_ et vous devez utiliser la commande `coredumpctl` pour le lire. + Pour plus d'informations, voir cette https://wiki.archlinux.org/title/Core_dump[page wiki ^↗^,window=_blank]. Par exemple si _weechat_ est installé dans _/usr/bin/_ et que le fichier _core_ se trouve dans _/home/user/_, alors il faut lancer gdb avec cette commande : ---- gdb /usr/bin/weechat /home/user/core ---- Puis sous gdb, utilisez la commande `bt full` pour afficher la trace. Vous verrez quelque chose comme ceci : ---- (gdb) set logging file /tmp/crash.txt (gdb) set logging on Copying output to /tmp/crash.txt. (gdb) bt full #0 0x00007f9dfb04a465 in raise () from /lib/libc.so.6 #1 0x00007f9dfb04b8e6 in abort () from /lib/libc.so.6 #2 0x0000000000437f66 in weechat_shutdown (return_code=1, crash=1) at /some_path/src/core/weechat.c:351 #3 #4 0x000000000044cb24 in hook_process_timer_cb (arg_hook_process=0x254eb90, remaining_calls=) at /some_path/src/core/wee-hook.c:1364 hook_process = 0x254eb90 status = #5 0x000000000044cc7d in hook_timer_exec () at /some_path/src/core/wee-hook.c:1025 tv_time = {tv_sec = 1272693881, tv_usec = 212665} ptr_hook = 0x2811f40 next_hook = 0x0 #6 0x000000000041b5b0 in gui_main_loop () at /some_path/src/gui/curses/gui-curses-main.c:319 hook_fd_keyboard = 0x173b600 tv_timeout = {tv_sec = 0, tv_usec = 0} read_fds = {fds_bits = {0 }} write_fds = {fds_bits = {0 }} except_fds = {fds_bits = {0 }} max_fd = ---- Vous devez envoyer cette trace aux développeurs, et leur indiquer quelle action a été la cause de ce plantage. Merci pour votre aide ! [[debug_running_weechat]] ==== Debug de WeeChat qui tourne Pour déboguer WeeChat qui tourne (par exemple si WeeChat semble bloqué), vous pouvez utiliser gdb avec l'identifiant du processus (remplacez _12345_ par le PID du processus weechat) : ---- gdb /usr/bin/weechat 12345 ---- Ensuite comme pour un crash, utilisez la commande `bt full` : ---- (gdb) bt full ---- [[upgrade]] == Mise à jour Si une nouvelle version stable de WeeChat est disponible, il est temps pour vous de passer à cette version. Avant toute chose, vous devez installer la nouvelle version de WeeChat, soit via votre gestionnaire de paquets ou en le compilant vous-même, de telle sorte que le nouveau binaire `weechat` et tous les fichiers requis sont dans les mêmes répertoires. + Cela peut être fait pendant que WeeChat tourne. [[upgrade_command]] === Commande de mise à jour WeeChat peut redémarrer le nouveau binaire avec la commande <> : le contenu des tampons et les connexions non SSL sont préservées. + Les connexions SSL sont perdues pendant la mise à jour et sont automatiquement rétablies après la mise à jour (le rechargement des sessions SSL n'est pas possible actuellement avec GnuTLS). La commande peut aussi être utilisée si vous devez redémarrer la machine, par exemple pour mettre à jour le noyau ou déplacer WeeChat vers une autre machine : ---- /upgrade -quit ---- Cela sauvegarde l'état actuel dans des fichiers `*.upgrade`. Vous pouvez soit rebooter ou déplacer les répertoires WeeChat (config, data, cache) vers une autre machine, et redémarrer WeeChat plus tard avec cette commande : ---- $ weechat --upgrade ---- [[restart_after_upgrade]] === Redémarrage après mise à jour [[restart_release_notes]] ==== Notes de version Après une mise à jour, il est *fortement recommandé* de lire les https://weechat.org/files/releasenotes/ReleaseNotes-devel.html[notes de version ^↗^,window=_blank] qui contiennent des informations importantes sur les changements majeurs et quelques actions manuelles qui pourraient être nécessaires. Vous devez lire les notes des versions entre votre version ancienne (exclue) et votre nouvelle version (incluse). + Par exemple si vous passez de la version 3.0 à 3.2, vous devez lire les notes des versions 3.1 et 3.2. [[restart_configuration_upgrade]] ==== Mise à jour de la configuration WeeChat a un système de mise à jour automatique des fichiers de configuration (`*.conf`) : * les nouvelles options sont silencieusement ajoutées avec la valeur par défaut * les options obsolètes sont automatiquement supprimées et WeeChat affiche un avertissement avec la valeur lue dans le fichier. Exemple d'avertissement lorsqu'une option a été supprimée : ---- =!= Attention : /home/user/.config/weechat/sec.conf, ligne 15 : option inconnue pour la section "crypt" : passphrase_file = "" ---- Cela signifie que l'option `sec.crypt.passphrase_file` a été supprimée, et vous aviez la valeur définie à une chaîne vide, ce qui était la valeur par défaut dans la version précédente (dans ce cas aucune action manuelle n'est nécessaire). [[running_weechat]] == Lancement de WeeChat Pour lancer WeeChat, tapez cette commande : ---- $ weechat ---- Lorsque vous lancez WeeChat pour la première fois, les fichiers de configuration par défaut sont créés dans _~/.config/weechat_ avec les options et valeurs par défaut (voir <>). [[command_line_options]] === Options de ligne de commande include::includes/cmdline_options.fr.adoc[tag=standard] Quelques options supplémentaires sont disponibles pour du debug seulement : [WARNING] N'utilisez *AUCUNE* de ces options in production ! include::includes/cmdline_options.fr.adoc[tag=debug] [[environment_variables]] === Variables d'environnement Des variables d'environnement sont utilisées par WeeChat si elles sont définies : [width="100%",cols="1m,6",options="header"] |=== | Nom | Description | WEECHAT_HOME | Le répertoire "maison" de WeeChat (avec les fichiers de configuration, logs, scripts, etc.). Même comportement que <> `WEECHAT_HOME`. | WEECHAT_PASSPHRASE | La phrase secrète utilisée pour déchiffrer les données sécurisées. | WEECHAT_EXTRA_LIBDIR | Un répertoire supplémentaire pour charger les extensions (depuis le répertoire "plugins" sous ce chemin). |=== [[colors_support]] === Support des Couleurs WeeChat peut utiliser jusqu'à 32767 paires de couleur pour afficher le texte dans les barres et la zone de discussion (votre terminal doit supporter 256 couleurs pour pouvoir les utiliser dans WeeChat). Selon la valeur de la variable d'environnement _TERM_, vous pouvez avoir les limites suivantes pour les couleurs dans WeeChat : [width="75%",cols="8,>3,>3",options="header"] |=== | $TERM | Couleurs | Paires | "rxvt-unicode", "xterm", ... | 88 | 32767 | "rxvt-256color", "xterm-256color", ... | 256 | 32767 | "screen" | 8 | 64 | "screen-256color" | 256 | 32767 | "tmux" | 8 | 64 | "tmux-256color" | 256 | 32767 |=== Vous pouvez lancer `weechat --colors` ou utiliser la commande `/color` dans WeeChat pour afficher les limites de votre environnement. Quelques valeurs recommandées pour _TERM_ si vous voulez 256 couleurs : * sous screen : _screen-256color_ * sous tmux : _screen-256color_ ou _tmux-256color_ * en dehors de screen/tmux : _xterm-256color_, _rxvt-256color_, _putty-256color_, ... Si vous utilisez screen, vous pouvez ajouter cette ligne dans votre _~/.screenrc_ : [NOTE] Vous devrez peut-être installer le paquet "ncurses-term" pour utiliser ces valeurs dans la variable _TERM_. ---- term screen-256color ---- Si votre variable _TERM_ a une valeur erronée et que WeeChat est déjà lancé, vous pouvez la changer avec ces deux commandes : ---- /set env TERM screen-256color /upgrade ---- [[files_and_directories]] === Fichiers et répertoires [[xdg_directories]] ==== XDG directories WeeChat utilise les répertoires XDG par défaut (selon la https://specifications.freedesktop.org/basedir-spec/basedir-spec-latest.html[spécification "XDG Base Directory" ^↗^,window=_blank]). + Un répertoire de base unique pour tous les fichiers peut être forcé par l'option CMake `WEECHAT_HOME`, la variable d'environnement `WEECHAT_HOME` ou l'option de ligne de commande `-d` / `--dir`. Lorsqu'un répertoire de base unique n'est pas forcé, les répertoires XDG sont utilisés et déterminés ainsi : [width="100%",cols="1,2m,5",options="header"] |=== | Répertoire | Valeur par défaut | Valeur de repli | config | $XDG_CONFIG_HOME/weechat | `$HOME/.config/weechat` si `$XDG_CONFIG_HOME` n'est pas défini ou vide. | data | $XDG_DATA_HOME/weechat | `$HOME/.local/share/weechat` si `$XDG_DATA_HOME` n'est pas défini ou vide. | cache | $XDG_CACHE_HOME/weechat | `$HOME/.cache/weechat` si `$XDG_CACHE_HOME` n'est pas défini ou vide. | runtime | $XDG_RUNTIME_DIR/weechat | Identique au répertoire _cache_ si `$XDG_RUNTIME_DIR` n'est pas défini ou vide. |=== Les fichiers de configuration sont créés avec les valeurs par défaut la première fois que vous lancez WeeChat. [[weechat_directories]] ==== Répertoires de WeeChat Les répertoires de WeeChat sont : [width="100%",cols="1m,3",options="header"] |=== | Chemin ^(1)^ | Description | ~/.config/weechat/ | Fichiers de configuration WeeChat : `*.conf`, certificats, etc. | ~/.local/share/weechat/ | Fichiers de données WeeChat : logs, scripts, données des scripts, fichiers xfer, etc. |    logs/ | Fichiers de log (un fichier par tampon). |    python/ | Scripts Python. |       autoload/ | Scripts Python chargés automatiquement au démarrage ^(2)^. |    perl/ | Scripts Perl. |       autoload/ | Scripts Perl chargés automatiquement au démarrage ^(2)^. |    ruby/ | Scripts Ruby. |       autoload/ | Scripts Ruby chargés automatiquement au démarrage ^(2)^. |    lua/ | Scripts Lua. |       autoload/ | Scripts Lua chargés automatiquement au démarrage ^(2)^. |    tcl/ | Scripts Tcl. |       autoload/ | Scripts Tcl chargés automatiquement au démarrage ^(2)^. |    guile/ | Scripts Guile. |       autoload/ | Scripts Guile chargés automatiquement au démarrage ^(2)^. |    javascript/ | Scripts JavaScript. |       autoload/ | Scripts JavaScript chargés automatiquement au démarrage ^(2)^. |    php/ | Scripts PHP. |       autoload/ | Scripts PHP chargés automatiquement au démarrage ^(2)^. | ~/.cache/weechat/ | Fichiers de cache WeeChat : cache des scripts. | /run/user/1000/weechat/ | Fichiers "runtime" WeeChat : tube FIFO, sockets UNIX Relay. |=== [NOTE] ^(1)^ Les répertoires XDG peuvent être différents selon vos variables d'environnement `XDG_*`. + ^(2)^ Ce répertoire contient souvent seulement des liens symboliques vers les scripts dans le répertoire parent. [[weechat_files]] ==== Fichiers de WeeChat Les fichiers dans le répertoire principal de WeeChat sont : [width="100%",cols="1m,3,6",options="header"] |=== | Fichier | Description | Données sensibles | weechat.conf | Fichier de configuration principal de WeeChat | Possible (par exemple : liste des canaux sauvés dans la disposition des tampons). | sec.conf | Fichier de configuration avec les données sécurisées | *Oui, très sensibles* : ce fichier ne doit jamais être partagé avec quiconque. | plugins.conf | Fichier de configuration des extensions | Possible, cela dépend des extensions/scripts. | alias.conf | Fichier de configuration de l'extension _alias_ | Possible, cela dépend des alias. | buflist.conf | Fichier de configuration de l'extension _buflist_ | Non. | charset.conf | Fichier de configuration de l'extension _charset_ | Non. | exec.conf | Fichier de configuration de l'extension _exec_ | Non. | fifo.conf | Fichier de configuration de l'extension _fifo_ | Non. | fset.conf | Fichier de configuration de l'extension _fset_ | Non. | guile.conf | Fichier de configuration de l'extension _guile_ | Non. | irc.conf | Fichier de configuration de l'extension _irc_ | *Oui* : il peut contenir des mots de passes pour les serveurs, nickserv et les canaux (si non stockés dans `sec.conf`). | javascript.conf | Fichier de configuration de l'extension _javascript_ | Non. | logger.conf | Fichier de configuration de l'extension _logger_ | Non. | lua.conf | Fichier de configuration de l'extension _lua_ | Non. | perl.conf | Fichier de configuration de l'extension _perl_ | Non. | php.conf | Fichier de configuration de l'extension _php_ | Non. | python.conf | Fichier de configuration de l'extension _python_ | Non. | relay.conf | Fichier de configuration de l'extension _relay_ | *Oui* : il peut contenir le mot de passe relay et le secret TOTP (si non stockés dans `sec.conf`), les adresses IP/origines websocket autorisées et les ports ouverts. | ruby.conf | Fichier de configuration de l'extension _ruby_ | Non. | script.conf | Fichier de configuration de l'extension _script_ | Non. | tcl.conf | Fichier de configuration de l'extension _tcl_ | Non. | spell.conf | Fichier de configuration de l'extension _spell_ | Non. | trigger.conf | Fichier de configuration de l'extension _trigger_ | Possible, cela dépend des triggers. | typing.conf | Fichier de configuration de l'extension _typing_ | Non. | xfer.conf | Fichier de configuration de l'extension _xfer_ | Non. | weechat.log | Fichier de log WeeChat | Non. |=== [IMPORTANT] Il n'est *pas recommandé* de modifier les fichiers de configuration à la main car WeeChat peut les écrire à tout moment (par exemple sur <>) et après chaque changement vous devez lancer la commande <> (avec le risque de perdre d'autres changements qui n'auraient pas été sauvés avec <>). + Vous pouvez utiliser la commande <>, qui vérifie la valeur et applique les changements immédiatement. [[interface]] == Interface [[screen_layout]] === Organisation de l'écran Exemple de terminal avec WeeChat : .... ▼ barre "buflist" ▼ barre "title" ┌──────────────────────────────────────────────────────────────────────────────────────┐ │1.libera │Bienvenue sur #test, canal de test │ │ weechat│12:52:27 --> | Flashy (flashcode@weechat.org) a rejoint #test │@Flashy│ │2. #test│12:52:27 -- | Pseudos #test: [@Flashy @joe +weebot peter] │@joe │ │3. #abc │12:52:27 -- | Canal #test: 4 pseudos (2 ops, 1 voice, 1 normal) │+weebot│ │4. #def │12:52:27 -- | Canal créé le Tue Jan 27 06:30:17 2009 │peter │ │5. #ghi │12:54:15 peter | bonjour ! │ │ │ │12:55:01 @joe | salut │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 2:#test(+n){4}* [H: 3:#abc(2,5), 5] │ │ │[@Flashy(i)] salut peter !█ │ └──────────────────────────────────────────────────────────────────────────────────────┘ ▲ barres "status" et "input" barre "nicklist" ▲ .... Par défaut, l'écran est composé des zones suivantes : * zone de discussion (milieu de l'écran) avec les lignes de discussion, et pour chaque ligne : ** heure ** préfixe (avant "|") ** message (après "|") * barres autour de la zone de discussion, les barres par défaut sont : ** barre _buflist_, sur la gauche ** barre _title_, au dessus de la zone de discussion ** barre _status_, sous la zone de discussion ** barre _input_, sous la barre de statut ** barre _nicklist_, sur la droite La barre _buflist_ contient les objets (items) suivants par défaut : [width="100%",cols="^3,^3,9",options="header"] |=== | Objet (item) | Exemple | Description | buflist | `1.weechat` | Liste des tampons. |=== La barre _title_ contient les objets (items) suivants par défaut : [width="100%",cols="^3,^3,9",options="header"] |=== | Objet (item) | Exemple | Description | buffer_title | `Bienvenue sur #test` | Titre du tampon. |=== La barre _status_ contient les objets (items) suivants par défaut : [width="100%",cols="^3,^3,9",options="header"] |=== | Objet (item) | Exemple | Description | time | `[12:55]` | Heure. | buffer_last_number | `[5]` | Numéro du dernier tampon de la liste. | buffer_plugin | `[irc/libera]` | Extension du tampon courant (l'extension irc peut afficher le nom du serveur IRC auquel est rattaché ce tampon). | buffer_number | `2` | Numéro du tampon courant. | buffer_name | `#test` | Nom du tampon courant. | buffer_modes | `+n` | Modes du canal IRC. | buffer_nicklist_count | `{4}` | Nombre de pseudos affichés dans la liste des pseudos. | buffer_zoom | ! | `!` signifie que le tampon mélangé est zoomé, une valeur vide signifie que tous les tampons mélangés sont affichés. | buffer_filter | `+*+` | Indicateur de filtrage : `+*+` signifie que des lignes sont filtrées (cachées), une valeur vide signifie que toutes les lignes sont affichées. | scroll | `-PLUS(50)-` | Indicateur de scroll, avec le nombre de lignes sous la dernière ligne affichée. | lag | `[Lag: 2.5]` | Indicateur de "lag" (ralentissements réseau), en secondes (caché si le lag est faible). | hotlist | `[H: 3:#abc(2,5), 5]` | Liste des tampons où il y a de l'activité (messages non lus) (dans cet exemple, 2 highlights et 5 messages non lus sur _#abc_, un message non lu sur le tampon numéro 5). | completion | `abc(2) def(5)` | Liste des mots pour la complétion, avec le nombre de complétions possibles pour chaque mot. |=== La barre _input_ contient les objets (items) suivants par défaut : [width="100%",cols="^3,^3,9",options="header"] |=== | Objet (item) | Exemple | Description | input_prompt | `[@Flashy(i)]` | Prompt, pour irc : pseudo et modes (le mode "+i" signifie invisible sur libera). | away | `(absent)` | Indicateur d'absence. | input_search | `[Recherche (~ str,msg)]` | Indicateur de recherche de texte ("`~`" : insensible à la casse, "`==`" : sensible à la casse, "`str`" : recherche de chaîne, "`regex`" : recherche d'expression régulière, "`msg`" : recherche dans les messages, "`pre`" : recherche dans les préfixes, "`pre\|msg`" : recherche dans les préfixes et messages). | input_paste | `[Coller 7 lignes ? [ctrl-Y] Oui [ctrl-N] Non]` | Question à l'utilisateur pour coller des lignes. | input_text | `salut peter !` | Texte entré. |=== La barre _nicklist_ contient les objets (items) suivants par défaut : [width="100%",cols="^3,^3,9",options="header"] |=== | Objet (item) | Exemple | Description | buffer_nicklist | `@Flashy` | Liste des pseudos sur le tampon courant. |=== Autres objets (non utilisés dans des barres par défaut) : [width="100%",cols="^3,^3,9",options="header"] |=== | Objet (item) | Exemple | Description | buffer_count | `10` | Nombre total de tampons ouverts. | buffer_last_number | `10` | Numéro du dernier tampon (peut être différent de `buffer_count` si l'option <> est `off`). | buffer_nicklist_count_all | `4` | Nombre de groupes et pseudos visibles dans la liste de pseudos. | buffer_nicklist_count_groups | `0` | Nombre de groupes visibles dans la liste de pseudos. | buffer_short_name | `#test` | Nom court du tampon courant. | buflist2 | `1.weechat` | Liste des tampons, deuxième objet de barre (voir l'option <>). | buflist3 | `1.weechat` | Liste des tampons, troisième objet de barre (voir l'option <>). | fset | `+buflist.look.sort: …+` | Aide sur l'option sélectionnée dans le tampon fset. | irc_channel | `#test` | Nom de canal IRC courant. | irc_host | `+user@host.com+` | Hôte sur IRC. | irc_nick | `+Flashy+` | Pseudo IRC. | irc_nick_host | `+Flashy!user@host.com+` | Pseudo et hôte IRC. | irc_nick_modes | `i` | Modes IRC pour le pseudo. | irc_nick_prefix | `@` | Préfixe de pseudo IRC sur le canal. | mouse_status | `M` | Statut de la souris (vide si la souris est désactivée). | spell_dict | `fr,en` | Dictionnaires utilisés pour la vérification de l'orthographe sur le tampon courant. | spell_suggest | `print,prone,prune` | Suggestions pour le mot sous le curseur (si mal orthographié). | tls_version | `TLS1.3` | Version de TLS utilisée sur le serveur IRC courant. | window_number | `2` | Numéro de la fenêtre courante. |=== Chaque aspect de la disposition peut être configuré par la <> appropriée : <> pour configurer les barres, <> et <> pour configurer les <>, et <> pour nommer, sauver et restaurer la disposition de l'écran et l'association entre les fenêtres et les tampons. [[command_line]] === Ligne de commande La ligne de commande WeeChat (située en bas de la fenêtre) permet d'exécuter des commandes ou d'envoyer du texte vers le tampon. [[command_line_syntax]] ==== Syntaxe Les commandes débutent par un caractère "/", suivi du nom de la commande. Par exemple pour afficher la liste de toutes les options : ---- /set ---- Le texte envoyé à un tampon est tout texte ne commençant pas par le caractère "/", par exemple pour envoyer _bonjour_ sur le tampon courant : ---- bonjour ---- Il est cependant possible de faire débuter un texte par "/" en le doublant. Par exemple pour envoyer le texte `/set` sur le tampon courant : ---- //set ---- [[command_line_colors]] ==== Codes couleurs Pour certaines extensions comme IRC, il est possible d'utiliser des codes couleur et attributs comme suit (appuyer sur kbd:[Ctrl+c] puis sur la lettre qui suit et éventuellement une valeur) : [width="100%",cols="1,2",options="header"] |=== | Touche | Description | kbd:[Ctrl+c], kbd:[b] | Texte gras. | kbd:[Ctrl+c], kbd:[c], kbd:[xx] | Couleur du texte `xx` (voir la liste des couleurs ci-dessous). | kbd:[Ctrl+c], kbd:[c], kbd:[xx], kbd:[,], kbd:[yy] | Couleur du texte `xx` et du fond `yy` (voir la liste des couleurs ci-dessous). | kbd:[Ctrl+c], kbd:[i] | Texte en italique. | kbd:[Ctrl+c], kbd:[o] | Désactiver la couleur et tous les attributs. | kbd:[Ctrl+c], kbd:[v] | Vidéo inverse (inversion de la couleur d'écriture et du fond). | kbd:[Ctrl+c], kbd:[_] | Texte souligné. |=== [NOTE] Le même code (sans le numéro pour kbd:[Ctrl+c], kbd:[c]) peut être utilisé pour stopper l'attribut défini. Les codes couleur pour kbd:[Ctrl+c], kbd:[c] sont : include::includes/autogen_user_irc_colors.fr.adoc[tag=irc_colors] [NOTE] Pour voir toutes les couleurs disponibles dans votre terminal, vous pouvez taper `/color` puis kbd:[Alt+c] dans WeeChat ou lancez cette commande dans le terminal : `weechat --colors`. Exemple : affichage de "bonjour Alice !" avec "bonjour" en bleu clair gras, et "Alice" en rouge clair souligné : ---- ^Cc12^Cbbonjour ^Cb^Cc04^C_Alice^C_^Cc ! ---- Touches : kbd:[Ctrl+c] kbd:[c] kbd:[1] kbd:[2] kbd:[Ctrl+c] kbd:[b] + kbd:[b] kbd:[o] kbd:[n] kbd:[j] kbd:[o] kbd:[u] kbd:[r] kbd:[Espace] + kbd:[Ctrl+c] kbd:[b] kbd:[Ctrl+c] kbd:[c] kbd:[0] kbd:[4] kbd:[Ctrl+c] kbd:[pass:[_]] + kbd:[A] kbd:[l] kbd:[i] kbd:[c] kbd:[e] + kbd:[Ctrl+c] kbd:[pass:[_]] kbd:[Ctrl+c] kbd:[c] + kbd:[Espace] kbd:[!] [NOTE] Dans l'extension irc, vous pouvez réassigner les couleurs en utilisant l'option <>. [[buffers_and_windows]] === Tampons et fenêtres Un tampon (_buffer_) est composé d'un numéro, un nom, des lignes affichées (ainsi que d'autres données). Exemples de tampons : * tampon core (créé par WeeChat au démarrage, ne peut pas être fermé) * serveur irc (affiche les messages du serveur) * canal irc * messages privés irc Une fenêtre (_window_) est une zone de l'écran affichant un tampon. Il est possible de découper l'écran horizontalement ou verticalement en plusieurs fenêtres (exemples <>, voir la commande <> pour plus d'informations). Chaque fenêtre affiche un tampon. Un tampon peut être caché (affiché par aucune fenêtre) ou affiché par une ou plusieurs fenêtres. Les dispositions d'écran et l'association entre les fenêtres et les tampons peuvent être <>. [[window_split_examples]] ==== Exemples Exemple de découpage horizontal (`/window splith`) : .... ▼ fenêtre n°2 (tampon n°4) ┌──────────────────────────────────────────────────────────────────────────────────────┐ │1.libera │Bienvenue sur #def │ │ weechat│12:55:12 Max | bonjour │@Flashy│ │2. #test│12:55:20 @Flashy | salut Max ! │Max │ │3. #abc │ │ │ │4. #def │ │ │ │5. #ghi │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 4:#def(+n){2} │ │ │[@Flashy] │ │ │────────────────────────────────────────────────────────────────────────────│ │ │Bienvenue sur #abc │ │ │12:54:15 peter | ohé ! │@Flashy│ │ │12:55:01 @joe | salut │@joe │ │ │ │+weebot│ │ │ │peter │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 3:#abc(+n){4} │ │ │[@Flashy] salut peter !█ │ └──────────────────────────────────────────────────────────────────────────────────────┘ ▲ fenêtre n°1 (tampon n°3) .... Exemple de découpage vertical (`/window splitv`) : .... ┌──────────────────────────────────────────────────────────────────────────────────────┐ │1.libera │Bienvenue sur #abc │Bienvenue sur #def │ │ weechat│12:54:15 peter | ohé ! │@Flashy│12:55:12 Max | bonjour │@Flashy│ │2. #test│12:55:01 @joe | salut │@joe │12:55:20 @Flashy | salut Max │Max │ │3. #abc │ │+weebot│ │ │ │4. #def │ │peter │ │ │ │5. #ghi │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 3:#abc(+n) │[12:55] [5] [irc/libera] 4:#def(+n) │ │ │[@Flashy] salut peter !█ │[@Flashy] │ └──────────────────────────────────────────────────────────────────────────────────────┘ ▲ fenêtre n°1 (tampon n°3) ▲ fenêtre n°2 (tampon n°4) .... Exemple de découpage vertical + horizontal : .... ▼ fenêtre n°3 (tampon n°5) ┌──────────────────────────────────────────────────────────────────────────────────────┐ │1.libera │Bienvenue sur #abc │Bienvenue sur #ghi │ │ weechat│12:54:15 peter | ohé ! │@Flashy│12:55:42 @Flashy | salut │@Flashy│ │2. #test│12:55:01 @joe | salut │@joe │12:55:56 alex | salut │alex │ │3. #abc │ │+weebot│ │ │ │4. #def │ │peter │ │ │ │5. #ghi │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 5:#ghi(+n) │ │ │ │ │[@Flashy] │ │ │ │ │──────────────────────────────────────│ │ │ │ │Bienvenue sur #def │ │ │ │ │12:55:12 Max | bonjour │@Flashy│ │ │ │ │12:55:20 @Flashy | salut Max │Max │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 3:#abc(+n) │[12:55] [5] [irc/libera] 4:#def(+n) │ │ │[@Flashy] salut peter !█ │[@Flashy] │ └──────────────────────────────────────────────────────────────────────────────────────┘ ▲ fenêtre n°1 (tampon n°3) ▲ fenêtre n°2 (tampon n°4) .... [[bare_display]] ==== Affichage dépouillé Un affichage spécial, appelé "dépouillé" (_bare display_) peut être utilisé pour un clic facile sur les URLs longs et la sélection de texte (avec la souris). L'affichage dépouillé a les caractéristiques suivantes : * Il n'affiche que le contenu du tampon courant : pas de découpage de fenêtres ni de barre (pas de titre, liste de pseudos, statut, ligne de commande, ...). * Le support souris de WeeChat est désactivé (s'il avait été activé) : vous pouvez utiliser votre souris comme vous le faites dans le terminal pour cliquer sur les URLs et sélectionner du texte. * Ncurses n'est pas utilisé, par conséquent les URLs ne sont pas coupés en fin de ligne. La touche par défaut pour activer l'affichage dépouillé est kbd:[Alt+l] (`L`), et la même touche pour en sortir (ou par défaut tout changement dans la ligne de commande sortira de l'affichage dépouillé, voir l'option <>). Le format de l'heure peut être personnalisé avec l'option <>. L'affichage dépouillé peut être activé pour un temps donné en utilisant la commande <>. Si WeeChat ressemble à ceci : .... ┌──────────────────────────────────────────────────────────────────────────────────────┐ │1.libera │Bienvenue sur #abc │ │ weechat│12:52:27 --> | Flashy (flashcode@weechat.org) a rejoint #abc │@Flashy│ │2. #test│12:52:27 -- | Pseudos #abc: [@Flashy @joe +weebot peter] │@joe │ │3. #abc │12:52:27 -- | Canal #abc: 4 pseudos (2 ops, 1 voice, 1 normal) │+weebot│ │4. #def │12:52:27 -- | Canal créé le Tue Jan 27 06:30:17 2009 │peter │ │5. #ghi │12:54:15 peter | bonjour ! │ │ │ │12:55:01 @joe | peter: hook_process: https://weechat.org/files/doc │ │ │ │ | /devel/weechat_plugin_api.en.html#_weechat_hook_pr │ │ │ │ | ocess │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │[12:55] [5] [irc/libera] 3:#abc(+n){4} │ │ │[@Flashy(i)] salut peter !█ │ └──────────────────────────────────────────────────────────────────────────────────────┘ .... L'écran ressemblera à ça en mode dépouillé : .... ┌──────────────────────────────────────────────────────────────────────────────────────┐ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │12:52 --> Flashy (flashcode@weechat.org) a rejoint #abc │ │12:52 -- Pseudos #abc: [@Flashy @joe +weebot peter] │ │12:52 -- Canal #abc: 4 pseudos (2 ops, 1 voice, 1 normal) │ │12:52 -- Canal créé le Tue Jan 27 06:30:17 2009 │ │12:54 bonjour ! │ │12:55 <@joe> peter: hook_process: https://weechat.org/files/doc/devel/weechat_plugin_a│ │pi.en.html#_weechat_hook_process │ └──────────────────────────────────────────────────────────────────────────────────────┘ .... Donc vous pouvez cliquer l'URL de _joe_ sans problème dans votre terminal (bien entendu cela suppose que votre terminal permet le clic sur les URLs). [[buffers]] === Tampons [[lines_format]] ==== Format des lignes Les lignes affichées dans les tampons formatés ont les champs suivants : [width="100%",cols="2,2,10",options="header"] |=== | Champ | Affiché | Description | date/heure (message) | Oui | Date/heure du message (peut être dans le passé). | date/heure (print) | Non | Date/heure lorsque WeeChat affiche le message. | préfixe | Oui | Préfixe du message, couramment un pseudo. | message | Oui | Le message lui-même. | affichée | Non | Booléen : vrai si la ligne est affichée, faux si la ligne est filtrée avec la commande <>. | highlight | Non | Booléen : vrai si la ligne a un highlight, faux sinon. | étiquettes | Avec `/debug tags` | Étiquettes associées avec la ligne (voir <>). |=== L'affichage des lignes peut être personnalisé avec des nombreuses options de présentation (_pass:[weechat.look.*]_) et de couleur (_pass:[weechat.color.chat_*]_). [[lines_tags]] ==== Étiquettes des lignes WeeChat utilise des étiquettes (« tags ») dans les lignes pour différentes raisons : * highlight * niveau de notification * enregistrement (« log ») * utilisation de la commande <> Les étiquettes peuvent être affichées avec la commande `/debug tags` (même commande pour les cacher). Les étiquettes couramment utilisées (liste non exhaustive) : [width="100%",cols="1m,4",options="header"] |=== | Étiquette | Description | no_filter | La ligne ne peut pas être filtrée. | no_highlight | Aucun highlight n'est possible sur cette ligne. | no_log | La ligne n'est pas écrite dans le fichier de log. | log0 … log9 | Niveau de log pour la ligne (voir `/help logger`). | notify_none | La ligne ne doit pas être ajoutée à la "hotlist". ^(1)^ | notify_message | La ligne est un message utilisateur. ^(1)^ | notify_private | La ligne est un message privé. ^(1)^ | notify_highlight | La ligne est un message avec un highlight. ^(1)^ | self_msg | Message de soi-même. | nick_xxx | Le message vient du pseudo "xxx". | prefix_nick_ccc | Le préfixe est un pseudo avec la couleur "ccc". | host_xxx | Nom d'utilisateur et hôte dans le message. | irc_xxx | Message IRC "xxx" (peut-être une commande ou un numérique sur 3 chiffres). | irc_numeric | Message IRC numérique. | irc_error | Erreur du serveur IRC. | irc_action | Action d'un pseudo (commande `/me`). | irc_ctcp | Message CTCP. | irc_ctcp_reply | Réponse à un message CTCP. | irc_smart_filter | Message IRC qui peut être filtré avec le "smart filter" (filtre intelligent). | away_info | Message avec une info d'absence. |=== [NOTE] ^(1)^ Lorsque aucune étiquette "notify_xxx" n'est présente, le niveau de notification par défaut est "low". Si une étiquette "notify_xxx" est présente, le niveau de notification réel peut être différent, par exemple si un niveau maximum de hotlist est utilisé pour un pseudo, le niveau de notification peut être inférieur à la valeur de l'étiquette. [[local_variables]] ==== Variables locales Des variables locales peuvent être définies dans les tampons. Une variable locale a : * un nom (chaîne) * une valeur (chaîne, peut être vide). Les variables locales peuvent être définies par WeeChat, les extensions, les scripts, ou manuellement sur la ligne de commande, dans le tampon. Par exemple pour ajouter la variable locale "completion_default_template" : ---- /buffer setvar completion_default_template %(my_completion) ---- Pour afficher les variables locales du tampon courant : ---- /buffer listvar ---- Pour supprimer la variable locale "completion_default_template" : ---- /buffer delvar completion_default_template ---- Par défaut WeeChat et ses extensions par défaut interprètent ces variables : [width="100%",cols="2m,2,5",options="header"] |=== | Nom | Valeur | Description | away | toute chaîne | Message d'absence sur le serveur, défini par l'extension irc. | channel | toute chaîne | Nom du canal, défini par les extensions irc/xfer et le tampon de debug des extensions relay/trigger. | charset_modifier | toute chaîne | Modificateur de charset du tampon serveur, défini par l'extension irc. | completion_default_template | toute chaîne | Modèle de complétion par défaut pour le tampon, qui remplace l'option `weechat.completion.default_template`. | filter | toute chaîne | Filtre défini sur certains tampons comme `/fset`, `/server raw` (irc) et `/script`. | host | toute chaîne | Nom d'hôte personnel (si connu), défini par l'extension irc. | lag | toute chaîne | Lag sur le serveur, défini par l'extension irc. | name | toute chaîne | Nom du tampon (attention, ce n'est pas le nom complet du tampon et ce nom n'est pas suffisant pour identifier ou chercher un tampon). | nick | toute chaîne | Pseudo personnel, défini par les extensions irc et xfer. | no_log | `1` (or any non-empty string) | Si défini, l'extension logger n'écrira pas le "log" du tampon sur disque. | plugin | toute chaîne | Nom de l'extension qui a créé le tampon (`core` pour les tampons WeeChat). | script_close_cb | toute chaîne | Nom de la fonction de rappel pour la fermeture, défini par un script pour le tampon. | script_close_cb_data | toute chaîne | Données pour la fonction de rappel pour la fermeture, définies par un script pour le tampon. | script_input_cb | toute chaîne | Nom de la fonction de rappel d'entrée, défini par un script pour le tampon. | script_input_cb_data | toute chaîne | Données pour la fonction de rappel d'entrée, définies par un script pour le tampon. | script_name | toute chaîne | Nom du script qui a créé le tampon. | server | toute chaîne | Nom du serveur, défini par l'extension irc et le tampon de debug des extensions relay/trigger. | spell_suggest | toute chaîne | Mot mal orthographié et ses suggestions (format : "mot:suggestions"), défini par l'extension spell. | trigger_filter | toute chaîne | Filtre trigger, défini par l'extension trigger. | type | toute chaîne, par exemple : `channel`, `debug`, `exec`, `option`, `private`, `relay`, `script`, `server`, `user`, `xfer` | Type de tampon, défini par WeeChat et plusieurs extensions. |=== [NOTE] Les extensions et script externes peuvent définir et utiliser d'autres variables locales. [[buflist]] === Liste des tampons L'extension Buflist affiche une liste des tampons dans un objet de barre appelé "buflist" (deux autres objets de barre "buflist2" et "buflist3" sont également disponibles). + Une barre par défaut "buflist" est créée au démarrage avec cet objet de barre. [[buflist_commands]] ==== Commandes include::includes/autogen_user_commands.fr.adoc[tag=buflist_commands] [[buflist_options]] ==== Options Sections dans le fichier _buflist.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | format | /set buflist.format.* | Formats utilisés pour l'affichage de la liste des tampons. | look | /set buflist.look.* | Aspect/présentation. |=== Options : include::includes/autogen_user_options.fr.adoc[tag=buflist_options] [[key_bindings]] == Raccourcis clavier WeeChat fournit beaucoup de raccourcis clavier par défaut, listés dans les chapitres suivants. + Ils peuvent être modifiés et de nouveaux peuvent être ajoutés avec la commande <>. [[key_bindings_cmdline]] === Ligne de commande [[key_bindings_cmdline_cursor_movement]] ==== Mouvement du curseur [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[←] + kbd:[Ctrl+b] | Aller au caractère précédent sur la ligne de commande. | `+/input move_previous_char+` | kbd:[→] + kbd:[Ctrl+f] | Aller au caractère suivant sur la ligne de commande. | `+/input move_next_char+` | kbd:[Ctrl+←] + kbd:[Alt+b] | Aller au mot précédent sur la ligne de commande. | `+/input move_previous_word+` | kbd:[Ctrl+→] + kbd:[Alt+f] | Aller au mot suivant sur la ligne de commande. | `+/input move_next_word+` | kbd:[Home] + kbd:[Ctrl+a] | Aller au début de la ligne de commande. | `+/input move_beginning_of_line+` | kbd:[End] + kbd:[Ctrl+e] | Aller à la fin de la ligne de commande. | `+/input move_end_of_line+` |=== [[key_bindings_cmdline_editing]] ==== Édition [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Del] + kbd:[Ctrl+d] | Effacer le caractère suivant sur la ligne de commande. | `+/input delete_next_char+` | kbd:[Backspace] + kbd:[Ctrl+h] | Effacer le caractère précédent sur la ligne de commande. | `+/input delete_previous_char+` | kbd:[Ctrl+k] | Effacer du curseur jusqu'à la fin de la ligne de commande (la chaîne supprimée est copiée dans le presse-papiers interne). | `+/input delete_end_of_line+` | kbd:[Ctrl+t] | Inverser deux caractères. | `+/input transpose_chars+` | kbd:[Ctrl+u] | Effacer du curseur jusqu'au début de la ligne de commande (la chaîne supprimée est copiée dans le presse-papiers interne). | `+/input delete_beginning_of_line+` | kbd:[Alt+Backspace] | Effacer le mot précédent sur la ligne de commande (la chaîne supprimée est copiée dans le presse-papiers interne). | `+/input delete_previous_word+` | kbd:[Ctrl+w] | Effacer le mot précédent sur la ligne de commande jusqu'à un espace (la chaîne supprimée est copiée dans le presse-papiers interne). | `+/input delete_previous_word_whitespace+` | kbd:[Ctrl+y] | Coller le contenu du presse-papiers interne. | `+/input clipboard_paste+` | kbd:[Ctrl+_] | Défaire la dernière action sur la ligne de commande. | `+/input undo+` | kbd:[Alt+_] | Refaire la dernière action sur la ligne de commande. | `+/input redo+` | kbd:[Tab] | Compléter la commande ou le pseudo (kbd:[Tab] de nouveau : trouver la complétion suivante). | `+/input complete_next+` | kbd:[Shift+Tab] | Sans complétion, effectue une complétion partielle. Avec une complétion en cours, complète avec la complétion précédente. | `+/input complete_previous+` | kbd:[Enter] + kbd:[Ctrl+j] + kbd:[Ctrl+m] | Exécuter la commande ou envoyer le message (en mode recherche : arrêter la recherche). | `+/input return+` | kbd:[Alt+Enter] | Insérer une nouvelle ligne. | `+/input insert \n+` | kbd:[Alt+d] | Effacer le mot suivant (la chaîne supprimée est copiée dans le presse-papiers interne). | `+/input delete_next_word+` | kbd:[Alt+k] | Capturer une touche et insérer son code (et la commande associée si la commande existe) sur la ligne de commande. | `+/input grab_key_command+` | kbd:[Alt+r] | Effacer entièrement la ligne de commande. | `+/input delete_line+` |=== [[key_bindings_cmdline_color_codes]] ==== Codes couleur [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Ctrl+c], kbd:[b] | Insérer le code pour mettre le texte en gras. | `+/input insert \x02+` | kbd:[Ctrl+c], kbd:[c] | Insérer le code pour écrire en couleur. | `+/input insert \x03+` | kbd:[Ctrl+c], kbd:[i] | Insérer le code pour mettre le texte en italique. | `+/input insert \x1D+` | kbd:[Ctrl+c], kbd:[o] | Insérer le code pour réinitialiser la couleur. | `+/input insert \x0F+` | kbd:[Ctrl+c], kbd:[v] | Insérer le code pour écrire en couleur inversée. | `+/input insert \x16+` | kbd:[Ctrl+c], kbd:[_] | Insérer le code pour écrire en souligné. | `+/input insert \x1F+` |=== [[key_bindings_cmdline_history]] ==== Historique de commandes [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[↑] | Rappeler la commande précédente (en mode recherche : chercher plus haut). | `+/input history_previous+` | kbd:[↓] | Rappeler la commande suivante (en mode recherche : chercher plus bas). | `+/input history_next+` | kbd:[Ctrl+↑] | Rappeler la commande précédente dans l'historique global (commun à tous les tampons). | `+/input history_global_previous+` | kbd:[Ctrl+↓] | Rappeler la commande suivante dans l'historique global (commun à tous les tampons). | `+/input history_global_next+` |=== [[key_bindings_buffers]] === Tampons [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Ctrl+r] | Chercher du texte dans l'historique du tampon (voir <>). | `+/input search_text_here+` | kbd:[Ctrl+s], kbd:[Ctrl+u] | Positionner le marqueur de données non lues sur tous les tampons. | `+/input set_unread+` | kbd:[Ctrl+x] | Changer de tampon courant si plusieurs tampons sont mélangés avec le même numéro, par exemple basculer vers un autre tampon serveur IRC. | `+/input switch_active_buffer+` | kbd:[Alt+x] | Zoomer sur le tampon mélangé (kbd:[Alt+x] de nouveau : afficher tous les tampons mélangés). | `+/input zoom_merged_buffer+` | kbd:[PgUp] | Monter d'une page dans l'historique du tampon. | `+/window page_up+` | kbd:[PgDn] | Descendre d'une page dans l'historique du tampon. | `+/window page_down+` | kbd:[Alt+PgUp] | Monter de quelques lignes dans l'historique du tampon. | `+/window scroll_up+` | kbd:[Alt+PgDn] | Descendre de quelques lignes dans l'historique du tampon. | `+/window scroll_down+` | kbd:[Alt+Home] | Aller au début du tampon. | `+/window scroll_top+` | kbd:[Alt+End] | Aller à la fin du tampon. | `+/window scroll_bottom+` | kbd:[Alt+←] + kbd:[Alt+↑] + kbd:[Ctrl+p] + kbd:[F5] | Aller au tampon précédent. | `+/buffer -1+` | kbd:[Alt+→] + kbd:[Alt+↓] + kbd:[Ctrl+n] + kbd:[F6] | Aller au tampon suivant. | `+/buffer +1+` | kbd:[Alt+j], kbd:[Alt+f] | Sauter au premier tampon. | `+/buffer -+` | kbd:[Alt+j], kbd:[Alt+l] (`L`) | Sauter au dernier tampon. | `+/buffer ++` | kbd:[Alt+j], kbd:[Alt+r] | Sauter au tampon IRC de données brutes. | `+/server raw+` | kbd:[Alt+j], kbd:[Alt+s] | Sauter au tampon IRC du serveur. | `+/server jump+` | kbd:[Alt+0...9] | Sauter au tampon qui porte ce numéro (0 = 10). | `+/buffer *N+` | kbd:[Alt+j], kbd:[01...99] | Sauter au tampon qui porte ce numéro. | `+/buffer *NN+` | kbd:[Alt+n] | Se positionner sur le highlight suivant. | `+/window scroll_next_highlight+` | kbd:[Alt+p] | Se positionner sur le highlight précédent. | `+/window scroll_previous_highlight+` | kbd:[Alt+u] | Se positionner sur la première ligne non lue du tampon. | `+/window scroll_unread+` | kbd:[Alt+<] | Sauter au tampon précédent dans la liste des tampons visités. | `+/input jump_previously_visited_buffer+` | kbd:[Alt+>] | Sauter au tampon suivant dans la liste des tampons visités. | `+/input jump_next_visited_buffer+` | kbd:[Alt+/] | Sauter au dernier tampon affiché (avant le dernier saut vers un tampon). | `+/input jump_last_buffer_displayed+` |=== [[key_bindings_windows]] === Fenêtres [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Ctrl+l] (`L`) | Réafficher toute la fenêtre. | `+/window refresh+` | kbd:[Alt+l] (`L`) | Activer/désactiver le mode d'affichage dépouillé. | `+/window bare+` | kbd:[F7] | Aller à la fenêtre précédente. | `+/window -1+` | kbd:[F8] | Aller à la fenêtre suivante. | `+/window +1+` | kbd:[Alt+w], kbd:[Alt+↑] | Sauter à la fenêtre au dessus. | `+/window up+` | kbd:[Alt+w], kbd:[Alt+↓] | Sauter à la fenêtre en dessous. | `+/window down+` | kbd:[Alt+w], kbd:[Alt+←] | Sauter à la fenêtre de gauche. | `+/window left+` | kbd:[Alt+w], kbd:[Alt+→] | Sauter à la fenêtre de droite. | `+/window right+` | kbd:[Alt+w], kbd:[Alt+b] | Équilibrer la taille de toutes les fenêtres. | `+/window balance+` | kbd:[Alt+w], kbd:[Alt+s] | Échanger les tampons de deux fenêtres. | `+/window swap+` | kbd:[Alt+z] | Zoomer sur la fenêtre courante (kbd:[Alt+z] de nouveau : restaurer l'état initial des fenêtres, avant le zoom). | `+/window zoom+` |=== [[key_bindings_bars]] === Barres [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[F1] + kbd:[Ctrl+F1] | Monter d'une page dans la liste des tampons. | `+/bar scroll buflist * -100%+` | kbd:[F2] + kbd:[Ctrl+F2] | Descendre d'une page dans la liste des tampons. | `+/bar scroll buflist * +100%+` | kbd:[Alt+F1] | Aller au début de la liste des tampons. | `+/bar scroll buflist * b+` | kbd:[Alt+F2] | Aller à la fin de la liste des tampons. | `+/bar scroll buflist * e+` | kbd:[F9] | Faire défiler le titre du tampon vers la gauche. | `+/bar scroll title * -30%+` | kbd:[F10] | Faire défiler le titre du tampon vers la droite. | `+/bar scroll title * +30%+` | kbd:[F11] + kbd:[Ctrl+F11] | Monter d'une page dans la liste des pseudos. | `+/bar scroll nicklist * -100%+` | kbd:[F12] + kbd:[Ctrl+F12] | Descendre d'une page dans la liste des pseudos. | `+/bar scroll nicklist * +100%+` | kbd:[Alt+F11] | Aller au début de la liste des pseudos. | `+/bar scroll nicklist * b+` | kbd:[Alt+F12] | Aller à la fin de la liste des pseudos. | `+/bar scroll nicklist * e+` | kbd:[Alt+Shift+B] | Activer/désactiver buflist. | `+/buflist toggle+` | kbd:[Alt+Shift+N] | Activer/désactiver la barre nicklist. | `+/bar toggle nicklist+` |=== [[key_bindings_hotlist]] === Hotlist [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Alt+a] | Sauter au prochain tampon avec activité (avec priorité : highlight, message, autre). | `+/input jump_smart+` | kbd:[Alt+h], kbd:[Alt+c] | Vider la hotlist (notification d'activité sur les tampons). | `+/input hotlist_clear+` | kbd:[Alt+h], kbd:[Alt+m] | Supprimer le tampon courant de la hotlist. | `+/input hotlist_remove_buffer+` | kbd:[Alt+h], kbd:[Alt+r] | Restaurer la dernière hotlist supprimée dans le tampon courant. | `+/input hotlist_restore_buffer+` | kbd:[Alt+h], kbd:[Alt+Shift+R] | Restaurer la dernière hotlist supprimée dans tous les tampons. | `+/input hotlist_restore_all+` |=== [[key_bindings_toggle_keys]] === Touches de bascule [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Alt+m] | Activer/désactiver la souris. | `+/mouse toggle+` | kbd:[Alt+s] | Activer/désactiver la vérification de l'orthographe. | `+/mute spell toggle+` | kbd:[Alt+=] | Activer/désactiver les filtres. | `+/filter toggle+` | kbd:[Alt+-] | Activer/désactiver les filtres dans le tampon courant. | `+/filter toggle @+` |=== [[key_bindings_search_context]] === Contexte de recherche Ces touches sont utilisées dans le contexte "search" (lorsque kbd:[Ctrl+r] est pressé pour chercher du texte dans le tampon). [width="100%",cols="^.^3,.^8,.^5",options="header"] |=== | Touche | Description | Commande | kbd:[Ctrl+r] | Basculer le type de recherche : chaîne (par défaut), expression régulière. | `+/input search_switch_regex+` | kbd:[Alt+c] | Basculer la casse exacte pour la recherche. | `+/input search_switch_case+` | kbd:[Tab] | Basculer la recherche dans : les messages (par défaut), les préfixes, les préfixes + messages. | `+/input search_switch_where+` | kbd:[↑] | Chercher la ligne précédente. | `+/input search_previous+` | kbd:[↓] | Chercher la ligne suivante. | `+/input search_next+` | kbd:[Enter] + kbd:[Ctrl+j] + kbd:[Ctrl+m] | Arrêter la recherche à la position courante. | `+/input search_stop_here+` | kbd:[Ctrl+q] | Arrêter la recherche et aller à la fin du tampon. | `+/input search_stop+` |=== [[key_bindings_cursor_context]] === Contexte curseur Ces touches sont utilisées dans le contexte "cursor" (mouvement libre du curseur à l'écran). [width="100%",cols="^.^3,^.^2,.^7,.^7",options="header"] |=== | Touche | Zone | Description | Commande | kbd:[↑] | - | Déplacer le curseur d'une ligne vers le haut. | `+/cursor move up+` | kbd:[↓] | - | Déplacer le curseur d'une ligne vers le bas. | `+/cursor move down+` | kbd:[←] | - | Déplacer le curseur d'une colonne vers la gauche. | `+/cursor move left+` | kbd:[→] | - | Déplacer le curseur d'une colonne vers la droite. | `+/cursor move right+` | kbd:[Alt+↑] | - | Déplacer le curseur vers la zone au dessus. | `+/cursor move area_up+` | kbd:[Alt+↓] | - | Déplacer le curseur vers la zone en dessous. | `+/cursor move area_down+` | kbd:[Alt+←] | - | Déplacer le curseur vers la zone sur la gauche. | `+/cursor move area_left+` | kbd:[Alt+→] | - | Déplacer le curseur vers la zone sur la droite. | `+/cursor move area_right+` | kbd:[m] | chat | Citer le message. | `+hsignal:chat_quote_message;/cursor stop+` | kbd:[q] | chat | Citer le préfixe + le message. | `+hsignal:chat_quote_prefix_message;/cursor stop+` | kbd:[Q] | chat | Citer l'heure + le préfixe + le message. | `+hsignal:chat_quote_time_prefix_message;/cursor stop+` | kbd:[b] | liste des pseudos | Bannir le pseudo. | `+/window ${_window_number};/ban ${nick}+` | kbd:[k] | liste des pseudos | Retirer par la force le pseudo. | `+/window ${_window_number};/kick ${nick}+` | kbd:[K] | liste des pseudos | Retirer par la force et bannir le pseudo. | `+/window ${_window_number};/kickban ${nick}+` | kbd:[q] | liste des pseudos | Ouvrir une discussion avec le pseudo. | `+/window ${_window_number};/query ${nick};/cursor stop+` | kbd:[w] | liste des pseudos | Effectuer un whois sur le pseudo. | `+/window ${_window_number};/whois ${nick}+` | kbd:[Enter] + kbd:[Ctrl+j] + kbd:[Ctrl+m] | - | Arrêter le mode curseur ("cursor"). | `+/cursor stop+` |=== [[key_bindings_mouse]] === Souris Ces actions avec la souris sont possibles seulement si la souris est activée avec la touche kbd:[Alt+m] (commande : `+/mouse toggle+`). [width="100%",cols="^.^3,^.^3,^.^3,.^8,.^8",options="header"] |=== | Bouton/Roulette ^(1)^ | Geste | Zone | Description | Commande | ◾◽◽ | - | chat | Aller à la fenêtre. | `+/window ${_window_number}+` | ◾◽◽ | left | chat | Aller au tampon précédent. | `+/window ${_window_number};/buffer +1+` | ◾◽◽ | right | chat | Aller au tampon suivant. | `+/window ${_window_number};/buffer +1+` | ◾◽◽ | left (long) | chat | Aller au premier tampon. | `+/window ${_window_number};/buffer 1+` | ◾◽◽ | right (long) | chat | Aller au dernier tampon. | `+/window ${_window_number};/input jump_last_buffer+` | kbd:[▲] | - | chat | Monter de quelques lignes dans l'historique du tampon. | `+/window scroll_up -window ${_window_number}+` | kbd:[▼] | - | chat | Descendre de quelques lignes dans l'historique du tampon. | `+/window scroll_down -window ${_window_number}+` | kbd:[Ctrl+▲] | - | chat | Faire défiler horizontalement vers la gauche. | `+/window scroll_horiz -window ${_window_number} -10%+` | kbd:[Ctrl+▼] | - | chat | Faire défiler horizontalement vers la droite. | `+/window scroll_horiz -window ${_window_number} +10%+` | kbd:[▲] | - | chat : tampon fset | Monter de cinq lignes dans le tampon fset. | `+/fset -up 5+` | kbd:[▼] | - | chat : tampon fset | Descendre de cinq lignes dans le tampon fset. | `+/fset -down 5+` | ◾◽◽ | - | chat : tampon fset | Sélectionner la ligne dans le tampon fset. | `+/window ${_window_number};/fset -go ${_chat_line_y}+` | ◽◽◾ | - | chat : tampon fset | Basculer le booléen (on/off) ou éditer la valeur de l'option. | `+hsignal:fset_mouse+` | ◽◽◾ | left | chat : tampon fset | Décrémenter la valeur de l'entier/couleur, définir/ajouter à la valeur pour les autres types. | `+hsignal:fset_mouse+` | ◽◽◾ | right | chat : tampon fset | Incrémenter la valeur de l'entier/couleur, définir/ajouter à la valeur pour les autres types. | `+hsignal:fset_mouse+` | ◽◽◾ | up / down | chat : tampon fset | Marquer/démarquer de multiples options. | `+hsignal:fset_mouse+` | kbd:[▲] | - | chat : tampon script | Monter de 5 lignes dans le tampon script. | `+/script up 5+` | kbd:[▼] | - | chat : tampon script | Descendre de 5 lignes dans le tampon script. | `+/script down 5+` | ◾◽◽ | - | chat : tampon script | Sélectionner la ligne dans le tampon script. | `+/script go ${_chat_line_y}+` | ◽◽◾ | - | chat : tampon script | Installer/supprimer un script. | `+/script go ${_chat_line_y};/script installremove -q ${script_name_with_extension}+` | ◾◽◽ | up / left | buflist | Déplacer le tampon vers un numéro inférieur. | Signal `+buflist_mouse+`. | ◾◽◽ | down / right | buflist | Déplacer le tampon vers un numéro supérieur. | Signal `+buflist_mouse+`. | ◾◽◽ | - | buflist | Aller au tampon (tampon précédent dans la liste des tampons visités si le tampon est le courant). | Signal `+buflist_mouse+`. | ◽◽◾ | - | buflist | Aller au tampon suivant dans la liste des tampons visités si le tampon est le courant. | Signal `+buflist_mouse+`. | kbd:[Ctrl+▲] | - | buflist | Aller au tampon précédent. | Signal `+buflist_mouse+`. | kbd:[Ctrl+▼] | - | buflist | Aller au tampon suivant. | Signal `+buflist_mouse+`. | ◾◽◽ | up | liste des pseudos | Monter d'une page dans la liste des pseudos. | `+/bar scroll nicklist ${_window_number} -100%+` | ◾◽◽ | down | liste des pseudos | Descendre d'une page dans la liste des pseudos. | `+/bar scroll nicklist ${_window_number} +100%+` | ◾◽◽ | up (long) | liste des pseudos | Aller au début de la liste des pseudos. | `+/bar scroll nicklist ${_window_number} b+` | ◾◽◽ | down (long) | liste des pseudos | Aller à la fin de la liste des pseudos. | `+/bar scroll nicklist ${_window_number} e+` | ◾◽◽ | - | liste des pseudos | Ouvrir une discussion avec le pseudo. | `+/window ${_window_number};/query ${nick}+` | ◽◽◾ | - | liste des pseudos | Effectuer un whois sur le pseudo. | `+/window ${_window_number};/whois ${nick}+` | ◾◽◽ | left | liste des pseudos | Retirer par la force le pseudo. | `+/window ${_window_number};/kick ${nick}+` | ◾◽◽ | left (long) | liste des pseudos | Retirer par la force et bannir le pseudo. | `+/window ${_window_number};/kickban ${nick}+` | ◽◽◾ | left | liste des pseudos | Bannir le pseudo. | `+/window ${_window_number};/ban ${nick}+` | ◽◽◾ | - | ligne de commande | Capturer un évènement de la souris et insérer son code sur la ligne de commande. | `+/input grab_mouse_area+` | kbd:[▲] | - | toute barre | Faire défiler la barre de -20%. | `+/bar scroll ${_bar_name} ${_window_number} -20%+` | kbd:[▼] | - | toute barre | Faire défiler la barre de +20%. | `+/bar scroll ${_bar_name} ${_window_number} +20%+` | ◽◾◽ | - | n'importe où | Démarrer le mode curseur ("cursor") à ce point. | `+/cursor go ${_x},${_y}+` |=== [NOTE] ^(1)^ kbd:[▲] et kbd:[▼] sont la roulette vers le haut et le bas. [[key_bindings_fset_buffer]] === Tampon fset Ces touches et actions sont utilisées sur le tampon fset (voir <>). [width="100%",cols="^.^3,^.^2,.^8,.^5",options="header"] |=== | Touche | Action ^(1)^ | Description | Commande | kbd:[↑] | | Monter d'une ligne. | `+/fset -up+` | kbd:[↓] | | Descendre d'une ligne. | `+/fset -down+` | kbd:[PgUp] | | Monter d'une page. | `+/window page_up+` | kbd:[PgDn] | | Descendre d'une page. | `+/window page_down+` | kbd:[Alt+Home] | `pass:[<<]` | Aller à la première ligne. | `+/fset -go 0+` | kbd:[Alt+End] | `pass:[>>]` | Aller à la dernière ligne. | `+/fset -go end+` | kbd:[F11] | `pass:[<]` | Faire défiler horizontalement vers la gauche. | `+/fset -left+` | kbd:[F12] | `pass:[>]` | Faire défiler horizontalement vers la droite. | `+/fset -right+` | kbd:[Alt+Space] | `t` | Basculer la valeur booléenne. | `+/fset -toggle+` | kbd:[Alt+-] | `-` | Soustraire 1 de la valeur de l'entier/couleur, définir la valeur pour les autres types. | `+/fset -add -1+` | kbd:[Alt++] | `+` | Ajouter 1 à la valeur de l'entier/couleur, ajouter à la valeur pour les autres types. | `+/fset -add 1+` | kbd:[Alt+f], kbd:[Alt+r] | `r` | Réinitialiser la valeur. | `+/fset -reset+` | kbd:[Alt+f], kbd:[Alt+u] | `u` | Supprimer/réinitialiser la valeur. | `+/fset -unset+` | kbd:[Alt+Enter] | `s` | Définir la valeur. | `+/fset -set+` | kbd:[Alt+f], kbd:[Alt+n] | `n` | Définir une nouvelle valeur. | `+/fset -setnew+` | kbd:[Alt+f], kbd:[Alt+a] | `a` | Ajouter à la valeur. | `+/fset -append+` | kbd:[Alt+,] | `,` | Marquer/démarquer l'option. | `+/fset -mark 1+` | kbd:[Shift+↑] | | Se déplacer d'une ligne vers le haut et marquer/démarquer l'option. | `+/fset -up; /fset -mark+` | kbd:[Shift+↓] | | Marquer/démarquer l'option et se déplacer d'une ligne vers le bas. | `+/fset -mark; /fset -down+` | | `m:xxx` | Marquer les options affichées qui correspondent au filtre "xxx" (tout filtre sur une option ou valeur est autorisé, voir la commande <>). | | | `u:xxx` | Démarquer les options affichées qui correspondent au filtre "xxx" (tout filtre sur une option ou valeur est autorisé, voir la commande <>). | | kbd:[Ctrl+l] (`L`) | | Rafraîchir les options et l'écran entier. | `+/fset -refresh+` | | `$` | Rafraîchir les options (garder les options marquées). | | | `$$` | Rafraîchir les options (démarquer toutes les options). | | kbd:[Alt+p] | | Activer/désactiver la description des options d'extensions (`pass:[plugins.desc.*]`). | `+/mute /set fset.look.show_plugins_desc toggle+` | kbd:[Alt+v] | | Activer/désactiver la barre d'aide. | `+/bar toggle fset+` | | `s:x,y` | Trier les options par les champs x,y (voir l'option <>). | `+/mute /set fset.look.sort x,y+` | | `s:` | Réinitialiser le tri à sa valeur par défaut (voir l'option <>). | `+/mute /unset fset.look.sort+` | | `w:xxx` | Exporter les options dans le fichier "xxx". | `+/fset -export xxx+` | | `w-:xxx` | Exporter les options dans le fichier "xxx" sans aide. | `+/fset -export -nohelp xxx+` | | `w+:xxx` | Exporter les options dans le fichier "xxx" avec aide. | `+/fset -export -help xxx+` | kbd:[Ctrl+x] | `x` | Basculer le format utilisé pour afficher les options. | `+/fset -format+` | | `q` | Fermer le tampon fset. | `+/buffer close+` |=== [NOTE] ^(1)^ L'action doit être tapée comme entrée dans la ligne de commande, suivie de kbd:[Enter]. [[key_bindings_script_buffer]] === Tampon script Ces touches et actions sont utilisées sur le tampon script (voir <>). [width="100%",cols="^.^3,^.^2,.^8,.^5",options="header"] |=== | Touche | Action ^(1)^ | Description | Commande | kbd:[↑] | | Move one line up. | `+/script up+` | kbd:[↓] | | Move one line down. | `+/script down+` | kbd:[PgUp] | | Move one page up. | `+/window page_up+` | kbd:[PgDn] | | Move one page down. | `+/window page_down+` | kbd:[Alt+i] | `i` | Install script. | `+/script install+` | kbd:[Alt+r] | `r` | Remove script. | `+/script remove+` | kbd:[Alt+l] (`L`) | `l` | Load script. | `+/script load+` | kbd:[Alt+u] | `u` | Unload script. | `+/script unload+` | kbd:[Alt+Shift+A] | `A` | Autoload script. | `+/script toggleautoload+` | kbd:[Alt+h] | `h` | Hold/unhold script. | `+/script hold+` | kbd:[Alt+v] | `v` | View script. | `+/script show+` |=== [NOTE] ^(1)^ L'action doit être tapée comme entrée dans la ligne de commande, suivie de kbd:[Enter]. [[configuration]] == Configuration [[fset]] === Fset L'extension Fset affiche une liste des options dans un tampon et aide à définir les options de WeeChat et des extensions. Exemple de tampon fset affichant les options commençant par `weechat.look` : [subs="quotes"] .... ┌──────────────────────────────────────────────────────────────────────────────────────┐ │1.weechat│1/121 | Filter: weechat.look.* | Sort: ~name | Key(input): alt+space=toggle │ │2.fset │weechat.look.bare_display_exit_on_input: exit the bare display mode on any c│ │ │hanges in input [default: on] │ │ │----------------------------------------------------------------------------│ │ │ weechat.look.align_end_of_lines integer message │ │ │ weechat.look.align_multiline_words boolean on │ │ │ weechat.look.bar_more_down string "++" │ │ │ weechat.look.bar_more_left string "<<" │ │ │ weechat.look.bar_more_right string ">>" │ │ │ weechat.look.bar_more_up string "--" │ │ │## weechat.look.bare_display_exit_on_input boolean on ##│ │ │ weechat.look.bare_display_time_format string "%H:%M" │ │ │ weechat.look.buffer_auto_renumber boolean on │ │ │ weechat.look.buffer_notify_default integer all │ │ │ weechat.look.buffer_position integer end │ │ │ weechat.look.buffer_search_case_sensitive boolean off │ │ │ weechat.look.buffer_search_force_default boolean off │ │ │ weechat.look.buffer_search_regex boolean off │ │ │ weechat.look.buffer_search_where integer prefix_message │ │ │ weechat.look.buffer_time_format string "%H:%M:%S" │ │ │ weechat.look.buffer_time_same string "" │ │ │[12:55] [2] [fset] 2:fset │ │ │█ │ └──────────────────────────────────────────────────────────────────────────────────────┘ .... [[fset_commands]] ==== Commandes include::includes/autogen_user_commands.fr.adoc[tag=fset_commands] [[fset_options]] ==== Options Sections dans le fichier _fset.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | color | /set fset.color.* | Couleurs. | format | /set fset.format.* | Formats utilisés pour afficher la liste des options. | look | /set fset.look.* | Aspect/présentation. |=== Options : include::includes/autogen_user_options.fr.adoc[tag=fset_options] [[colors]] === Couleurs [[colors_basic]] ==== Couleurs de base Les couleurs de base dans WeeChat sont : [width="75%",cols="1m,4",options="header"] |=== | Nom | Couleur | default | Couleur par défaut du terminal (transparent pour le fond) | black | Noir | darkgray | Gris foncé | red | Rouge foncé | lightred | Rouge clair | green | Vert foncé | lightgreen | Vert clair | brown | Marron | yellow | Jaune | blue | Bleu foncé | lightblue | Bleu clair | magenta | Violet foncé | lightmagenta | Violet clair | cyan | Cyan foncé | lightcyan | Cyan clair | gray | Gris | white | Blanc |=== [[colors_extended]] ==== Couleurs étendues WeeChat alloue dynamiquement les paires de couleurs quand elles sont utilisées sur l'écran (pour afficher les tampons et les barres). En plus des couleurs de base, vous pouvez utiliser un numéro de couleur entre 1 et la limite de votre terminal. Utilisez la commande `/color` pour voir les couleurs et les limites. Avec la touche kbd:[Alt+c], vous pouvez basculer temporairement vers les couleurs du terminal pour choisir une couleur. Par exemple si vous souhaitez afficher l'heure en orange dans le tampon, faites : ---- /set weechat.color.chat_time 214 ---- Ou si vous voulez un fond vert très foncé pour la barre de statut : ---- /set weechat.bar.status.color_bg 22 ---- [[colors_aliases]] ==== Alias Vous pouvez ajouter des alias de couleur avec la commande `/color alias` puis utiliser cet alias dans n'importe quelle option de couleur. Par exemple : ---- /color alias 214 orange /set weechat.color.chat_delimiters orange ---- [[colors_attributes]] ==== Attributs Il est possible d'utiliser des attributs pour les couleurs. Un ou plusieurs attributs peuvent être ajoutés avant le nom ou le numéro de la couleur : * `+*+` : texte gras * `+!+` : mode vidéo inverse * `+/+` : italique * `+_+` : texte souligné * `+|+` : garder les attributs : ne pas réinitialiser gras/inverse/souligné lors du changement de couleur Par exemple si vous voulez votre pseudo en blanc souligné, faites : ---- /set weechat.color.chat_nick_self _white ---- Ou si vous voulez l'heure dans la barre de statut en orange souligné avec gras : ---- /set weechat.color.status_time *_214 ---- Pour utiliser un attribut avec la couleur par défaut du terminal (-1), vous devez utiliser un nombre supérieur à la dernière couleur du terminal, par exemple la couleur maximum de WeeChat : 99999. Exemple de gras avec la couleur de texte du terminal : ---- /set weechat.color.status_time *99999 ---- [[charset]] === Charset L'extension Charset vous permet de décoder et encoder les données en utilisant un jeu de caractères. Il y a un jeu de caractère par défaut pour le décodage/encodage, et un spécifique pour les tampons (ou groupes de tampons). Cette extension est facultative, mais recommandée : si elle n'est pas chargée, WeeChat pourra uniquement lire/écrire des données UTF-8. L'extension Charset devrait être automatiquement chargée par WeeChat au démarrage. Pour s'assurer que l'extension est bien chargée, essayez : ---- /charset ---- Si la commande n'est pas trouvée, alors chargez l'extension avec la commande : ---- /plugin load charset ---- Si l'extension n'est pas trouvée, alors vous devriez recompiler WeeChat avec les extensions et le support de Charset. Lorsque l'extension Charset démarre, elle affiche le jeu de caractères du terminal et l'interne. Le jeu de caractères du terminal dépend de votre locale, et l'interne est UTF-8. Par exemple : .... charset : terminal : ISO-8859-15, interne : UTF-8 .... [[charset_set]] ==== Définir le jeu de caractère Pour modifier les jeux de caractères de décodage et d'encodage globaux, utilisez la commande `/set`. Par exemple : ---- /set charset.default.decode ISO-8859-15 /set charset.default.encode ISO-8859-15 ---- Si le jeu de caractères de décodage global n'est pas renseigné (par exemple pendant le premier chargement de Charset), il sera renseigné automatiquement avec le jeu de caractères du terminal (s'il est différent de UTF-8) ou par défaut à _ISO-8859-1_. La valeur d'encodage par défaut est vide, donc WeeChat envoie par défaut avec le jeu de caractères interne (UTF-8). Pour modifier le jeu de caractères d'un serveur IRC, utilisez la commande `/charset` sur le tampon serveur. Si vous donnez seulement le jeu de caractères, alors vous modifiez en même temps les valeurs de décodage et d'encodage. Par exemple : ---- /charset ISO-8859-15 ---- Ce qui est équivalent à : ---- /charset decode ISO-8859-15 /charset encode ISO-8859-15 ---- Pour modifier le jeu de caractères d'un canal IRC (ou d'une conversation privée), utilisez la même commande que pour le serveur, mais sur le tampon du canal (ou du privé). Pour définir le jeu de caractères pour tous les canaux/privés d'un serveur IRC : ---- /set charset.encode.irc.libera ISO-8859-15 ---- Pour voir tous les jeux de caractères utilisés, utilisez la commande suivante : ---- /set charset.* ---- [[charset_troubleshooting]] ==== En cas de problème Pour tout problème avec les jeux de caractères, merci de consulter la link:weechat_faq.fr.html#charset[FAQ WeeChat / Accents ^↗^,window=_blank]. [[charset_commands]] ==== Commandes include::includes/autogen_user_commands.fr.adoc[tag=charset_commands] [[charset_options]] ==== Options Sections dans le fichier _charset.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | default | /set charset.default.* | Jeu de caractère d'encodage/décodage par défaut. | decode | <> + /set charset.decode.* | Jeu de caractère d'encodage par tampon (les options peuvent être ajoutées/supprimées dans la section). | encode | <> + /set charset.encode.* | Jeu de caractère de décodage par tampon (les options peuvent être ajoutées/supprimées dans la section). |=== Options : include::includes/autogen_user_options.fr.adoc[tag=charset_options] [[notify_levels]] === Niveaux de notification [[setup_notify_levels]] ==== Configurer les niveaux de notification Quatre niveaux sont possibles dans les messages affichés dans les tampons, du moins important au plus important : * _low_ : message avec faible importance (par exemple un join/part/quit irc) * _message_ : message d'un utilisateur * _private_ : message dans un tampon privé * _highlight_ : message avec highlight Chaque tampon a un niveau de notification, qui est utilisé pour décider quels messages ajouteront le tampon dans la hotlist. Le niveau de notification par défaut peut être défini avec l'option <>, la valeur par défaut est _all_. [width="75%",cols="2m,7",options="header"] |=== | Niveau de notification | Niveau des messages ajoutés à la hotlist | none | (aucun) | highlight | highlight + private | message | highlight + private + message | all | highlight + private + message + low |=== Le niveau de notification peut être défini pour un ensemble de tampons, par exemple tous les tampons du serveur irc "libera" : ---- /set weechat.notify.irc.libera message ---- Définir le niveau de notification _highlight_ sur le canal "#weechat" seulement : ---- /set weechat.notify.irc.libera.#weechat highlight ---- Le niveau de notification pour un tampon peut aussi être défini avec la commande `/buffer` : ---- /buffer notify highlight ---- [[max_hotlist_level_nicks]] ==== Niveau maximal de hotlist pour des pseudos Il est possible de définir un niveau maximal de hotlist pour certains pseudos, par tampon ou groupe de tampons (comme des serveurs IRC). La propriété de tampon "hotlist_max_level_nicks" peut être définie avec une liste de pseudos et pour chaque pseudo le niveau maximal de hotlist à déclencher, les niveaux possibles sont : * -1 : pas de changement dans la hotlist pour ce pseudo * 0 : faible priorité (comme les messages join/part) * 1 : message * 2 : message privé * 3 : highlight (en réalité inutile, car il s'agit déjà du niveau maximal par défaut pour tous les messages) Par exemple pour désactiver les « highlights » de "joe" et "mike" sur le tampon courant : ---- /buffer set hotlist_max_level_nicks_add joe:2,mike:2 ---- [NOTE] La propriété de tampon "hotlist_max_level_nicks" n'est pas sauvegardée dans la configuration. + Vous pouvez facilement la sauvegarder avec le script _buffer_autoset.py_ : vous pouvez l'installer avec `+/script install buffer_autoset.py+` et obtenir de l'aide avec `+/help buffer_autoset+`. [[highlights]] === Highlights [[highlights_disable]] ==== Désactiver les highlights Vous pouvez désactiver les highlights avec l'option <> (expression régulière). + Lorsqu'un highlight est désactivé avec cette option, les autres options de highlight sont ignorées. Par exemple pour désactiver tout highlight sur les messages avec un mot commençant par "flash" entre chevrons : ---- /set weechat.look.highlight_disable_regex "" ---- Ceci peut aussi être défini avec la propriété de tampon "highlight_disable_regex". Même exemple, spécifique au tampon courant : ---- /buffer set highlight_disable_regex ---- [NOTE] La propriété de tampon "highlight_disable_regex" n'est pas sauvegardée dans la configuration. + Vous pouvez facilement la sauvegarder avec le script _buffer_autoset.py_ : vous pouvez l'installer avec `+/script install buffer_autoset.py+` et obtenir de l'aide avec `+/help buffer_autoset+`. [[highlights_words]] ==== Ajouter des mots pour le « highlight » Par défaut, WeeChat met en valeur les messages des autres utilisateurs qui contiennent votre pseudo, par conséquent le highlight dépend du tampon (le pseudo peut être différent d'un tampon à l'autre). Vous pouvez ajouter d'autres mots à mettre en valeur avec l'option <>, par exemple pour mettre en valeur votre pseudo, "mot1", "mot2" et tous les mots commençants par "test" : ---- /set weechat.look.highlight "mot1,mot2,test*" ---- Si vous avez besoin d'une règle plus spécifique pour un mot, vous pouvez utiliser des expressions régulières avec l'option <>, par exemple pour mettre en valeur les mots "flashcode", "flashcöde" et "flashy" : ---- /set weechat.look.highlight_regex "flashc[oö]de|flashy" ---- Les délimiteurs autour des mots à mettre en valeur peuvent être paramétrés avec l'option <>. [[highlights_tags]] ==== Ajouter des étiquettes pour le « highlight » Les lignes affichées contiennent des étiquettes (« tags »), qui donnent des informations sur l'origine du message ou le message lui-même. + Vous pouvez afficher les étiquettes avec la commande `/debug tags` (même commande pour les cacher). Vous pouvez ajouter des étiquettes à mettre en valeur avec l'option <>. Les étiquettes sont séparées par des virgules, et plusieurs étiquettes peuvent être séparées par `+++` pour faire un "et" logique entre elles. Par exemple pour mettre en valeur tous les messages du pseudo "FlashCode" et toutes les notices des pseudos commençant par "toto" : ---- /set weechat.look.highlight_tags "nick_flashcode,irc_notice+nick_toto*" ---- [[highlights_regex_buffer]] ==== Définir des highlights supplémentaires sur le tampon Vous pouvez forcer le highlight en utilisant une expression regulière avec la propriété de tampon "highlight_regex". Par exemple pour forcer le highlight sur tous les messages dans le canal courant : ---- /buffer set highlight_regex .* ---- [NOTE] La propriété de tampon "highlight_regex" n'est pas sauvegardée dans la configuration. + Vous pouvez facilement la sauvegarder avec le script _buffer_autoset.py_ : vous pouvez l'installer avec `+/script install buffer_autoset.py+` et obtenir de l'aide avec `+/help buffer_autoset+`. [[buffer_logging]] === Enregistrement des tampons L'extension Logger permet de sauvegarder le contenu des tampons dans des fichiers, avec des options sur comment et quoi sauvegarder. [[logger_log_levels]] ==== Niveaux d'enregistrement L'enregistrement est fait selon un niveau pour chaque tampon. Le niveau par défaut est 9 (enregistrer tous les messages affichés dans le tampon). Vous pouvez changer ce niveau pour un tampon, ou un groupe de tampons. Les niveaux possibles vont de 0 à 9. Zéro signifie "ne rien enregistrer" et 9 signifie "enregistrer tous les messages". Les extensions utilisent différent niveaux pour les messages affichés. L'extension IRC utilise les niveaux suivants : * niveau 1 : message d'un utilisateur (sur un canal ou en privé) * niveau 2 : changement de pseudo (vous ou quelqu'un d'autre) * niveau 3 : tout message du serveur (sauf join/part/quit) * niveau 4 : message join/part/quit du serveur Donc si vous affectez le niveau 3 pour un canal IRC, WeeChat enregistrera tous les messages sauf les join/part/quit. Quelques exemples : * Affecter le niveau 3 pour le canal IRC #weechat : ---- /set logger.level.irc.libera.#weechat 3 ---- * Affecter le niveau 3 pour le tampon serveur libera : ---- /set logger.level.irc.server.libera 3 ---- * Affecter le niveau 3 pour tous les canaux sur le serveur libera : ---- /set logger.level.irc.libera 3 ---- * Affecter le niveau 2 pour tous les tampons IRC : ---- /set logger.level.irc 2 ---- [[logger_filenames_masks]] ==== Masques de noms de fichiers Il est possible de définir un masque de nom de fichier pour chaque tampon, et d'utiliser les variables locales du tampon pour construire le nom de fichier. Pour voir les variables disponibles sur le tampon courant : ---- /buffer listvar ---- Les masques seront utilisés par ordre de priorité descendante sur `logger.mask.$plugin.*`, avec `logger.file.mask` comme option par défaut. Par exemple, sur le tampon "irc.libera.#weechat", WeeChat cherchera un masque avec le nom de l'option, dans cet ordre : ---- logger.mask.irc.libera.#weechat logger.mask.irc.libera logger.mask.irc logger.file.mask ---- Cela signifie que vous pouvez avoir un masque spécifique pour certaines serveurs IRC ("logger.mask.irc.libera") ou pour une extension ("logger.mask.irc"). [[logger_files_by_date]] ===== Fichiers de log par date Pour avoir des fichiers de log par date, vous pouvez utiliser des marqueurs dans le masque (voir `man strftime` pour le format), par exemple : ---- /set logger.file.mask "%Y/%m/$plugin.$name.weechatlog" ---- Vous obtiendrez les fichiers suivants : .... ~/.local/share/weechat └── logs ├── 2010 │ ├── 11 │ │ ├── irc.server.libera.weechatlog │ │ └── irc.libera.#weechat.weechatlog │ └── 12 │ ├── irc.server.libera.weechatlog │ └── irc.libera.#weechat.weechatlog ├── 2011 │ ├── 01 │ │ ├── irc.server.libera.weechatlog │ │ └── irc.libera.#weechat.weechatlog │ ├── 02 ... .... [[logger_irc_files_by_server_channel]] ===== Fichiers de log IRC par serveur et canal Si vous voulez un répertoire par serveur IRC et un fichier par canal dedans : ---- /set logger.mask.irc "irc/$server/$channel.weechatlog" ---- Vous obtiendrez les fichiers suivants : .... ~/.local/share/weechat └── logs └── irc ├── libera │ ├── libera.weechatlog │ ├── #weechat.weechatlog │ └── #moncanal.weechatlog ├── oftc │ ├── oftc.weechatlog │ ├── #canal1.weechatlog │ └── #canal2.weechatlog ... .... [[logger_rotation_compression]] ==== Rotation et compression Il est possible de définir une taille maximale pour les fichiers de logs, et lorsqu'elle est atteinte, il y a une rotation automatique du fichier de log. Les fichiers de logs qui ont tourné peuvent être compressés avec gzip ou https://facebook.github.io/zstd/[zstd ^↗^,window=_blank]. [NOTE] La compression du fichier pouvant prendre du temps, elle est exécutée en tâche de fond. Exemple avec une taille maximale de 2 Go et la compression avec gzip, en utilisant un bon niveau de compression (plus lent que celui par défaut) : ---- /set logger.file.rotation_compression_type gzip /set logger.file.rotation_compression_level 80 /set logger.file.rotation_size_max "2g" ---- Si vous voulez utiliser un nombre décimal, vous pouvez utiliser l'unité en dessous et multiplier par 1000, par exemple pour une taille maximale de 2,5 Go : ---- /set logger.file.rotation_size_max "2500m" ---- Avec cette configuration, vous aurez des fichiers comme ceux-ci (dans cet exemple il y a eu une rotation seulement pour le log du canal "#weechat"): .... ~/.local/share/weechat └── logs ├── core.weechat.weechatlog ├── irc.server.libera.weechatlog ├── irc.libera.#weechat.weechatlog ├── irc.libera.#weechat.weechatlog.1.gz ├── irc.libera.#weechat.weechatlog.2.gz └── irc.libera.#weechat.weechatlog.3.gz .... [[logger_commands]] ==== Commandes include::includes/autogen_user_commands.fr.adoc[tag=logger_commands] [[logger_options]] ==== Options Sections dans le fichier _logger.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | look | /set logger.look.* | Aspect/présentation. | color | /set logger.color.* | Couleurs. | file | /set logger.file.* | Options pour les fichiers de log. | level | /set logger.level.* | Niveau de log par tampon (les options peuvent être ajoutées/supprimées dans la section). | mask | /set logger.mask.* | Masque de nom de fichier par tampon (les options peuvent être ajoutées/supprimées dans la section). |=== Options : include::includes/autogen_user_options.fr.adoc[tag=logger_options] [[mouse]] === Support souris WeeChat supporte les clics et mouvements avec la souris. Cela fonctionne avec un terminal local, et à distance via une connexion ssh, avec ou sans screen/tmux. [[mouse_enable]] ==== Activer la souris Pour activer la souris au démarrage : ---- /set weechat.look.mouse on ---- Pour activer la souris maintenant, appuyez sur kbd:[Alt+m] ou lancez la commande suivante : ---- /mouse enable ---- Il est possible de désactiver temporairement la souris, et associer ça à une touche. Par exemple la touche kbd:[Alt+%] pour désactiver la souris pendant 10 secondes : ---- /key bind meta-% /mouse toggle 10 ---- [IMPORTANT] Lorsque la souris est activée dans WeeChat, tous les évènements souris sont capturés par WeeChat, donc les actions comme le copier/coller et les clics sur les URLs ne sont pas envoyées au terminal. + Utiliser la touche kbd:[Shift] permet d'envoyer directement les évènements au terminal, comme si la souris était désactivée (sous certains terminaux comme iTerm, vous devez utiliser kbd:[Alt] au lieu de kbd:[Shift]). [NOTE] Pour tout problème avec la souris, merci de consulter la link:weechat_faq.fr.html#mouse[FAQ WeeChat / Souris ^↗^,window=_blank]. [[mouse_bind_events]] ==== Associer des évènements souris à des commandes De nombreux évènements souris sont déjà définis par WeeChat (voir <>). Vous pouvez modifier ou ajouter des associations avec la commande `/key` en utilisant le contexte "mouse" (pour la syntaxe voir la commande <>). Un nom d'évènement consiste en un modificateur (facultatif), un bouton/roulette et un geste (facultatif). Les différents éléments sont séparés par `+-+`. Liste des modificateurs : [width="100%",cols="1m,4",options="header"] |=== | Modificateur | Description | ctrl | Touche kbd:[Ctrl] | alt | Touche kbd:[Alt] | ctrl-alt | Touches kbd:[Ctrl] + kbd:[Alt] |=== Liste des boutons/roulette : [width="100%",cols="1m,4",options="header"] |=== | Bouton/roulette | Description | button1 | Clic sur le bouton gauche | button2 | Clic sur le bouton droit | button3 | Clic sur le bouton du milieu (souvent clic sur la roulette) | button4 ... button9 | Clic sur un bouton additionnel | wheelup | Roulette (haut) | wheeldown | Roulette (bas) |=== Liste des gestes (seulement pour les boutons, pas la roulette) : [width="100%",cols="1m,4",options="header"] |=== | Geste | Distance | gesture-up | 3 ... 19 | gesture-up-long | ≥ 20 | gesture-down | 3 ... 19 | gesture-down-long | ≥ 20 | gesture-left | 3 ... 39 | gesture-left-long | ≥ 40 | gesture-right | 3 ... 39 | gesture-right-long | ≥ 40 |=== Liste des évènements incomplets (seulement pour les boutons, pratique pour les extensions/scripts) : [width="100%",cols="1m,4",options="header"] |=== | Évènement | Description | event-down | Le bouton a été pressé mais pas encore relâché | event-drag | La souris a bougé avec le bouton pressé |=== Exemples d'évènements : * `button1` * `ctrl-button1` * `button1-gesture-right` * `button1-event-down` * `button1-event-drag` * `alt-button2-gesture-down-long` * `wheelup` * `ctrl-alt-wheeldown` * ... [TIP] Lors de l'association d'une touche dans le contexte "mouse", il est possible d'adresser plusieurs évènements en utilisant `+*+` au début ou la fin du nom, par exemple `+button1-gesture-*+` qui correspond à n'importe quel geste effectué avec le bouton gauche. [TIP] Vous pouvez trouver le nom de l'évènement avec la commande `+/input grab_mouse+` puis en faisant l'action avec la souris. Cela insérera le nom de l'évènement sur la ligne de commande. [[spell_checking]] === Vérification orthographique L'extension Spell permet de vérifier l'orthographe de la ligne de commande. Il est possible d'utiliser plusieurs langages par tampon. La vérification de l'orthographe est désactivée par défaut et peut être activée/désactivée avec la touche kbd:[Alt+s]. [[spell_dictionaries]] ==== Dictionnaires Avant d'utiliser la vérification de l'orthographe, les dictionnaires doivent être définis soit globalement, soit spécifiquement sur un tampon. Plusieurs dictionnaires peuvent être utilisés en même temps : WeeChat vérifiera les mots dans tous les dictionnaires. Par exemple pour utiliser l'anglais et le français : ---- /set spell.check.default_dict "en,fr" ---- Il est possible d'utiliser un dictionnaire différent sur un tampon spécifique, par exemple sur un canal allemand : ---- /spell setdict de ---- Vous pouvez aussi spécifier un dictionnaire pour un groupe de tampons, par exemple l'anglais pour tous les canaux du serveur IRC libera : ---- /set spell.dict.irc.libera en ---- Pour plus d'informations, voir la commande <>. [[spell_speller_options]] ==== Options du vérificateur d'orthographe Les options du vérificateur d'orthographe peuvent être définies en ajoutant des options dans la section "option" de la configuration aspell. Le nom de l'option est une option de configuration aspell. La liste des options peut être trouvée par la commande suivante sous le shell : ---- $ aspell config ---- Par exemple, pour activer l'option "ignore-case" : ---- /set spell.option.ignore-case "true" ---- [[spell_suggestions]] ==== Suggestions Les suggestions sont affichées dans un objet de barre appelé "spell_suggest". Le nombre de suggestions est défini dans l'option _spell.check.suggestions_. Pour activer les suggestions, vous devez modifier l'option _spell.check.suggestions_ avec un entier ≥ 0 et ajouter l'objet de barre "spell_suggest" à une barre, par exemple _status_. Exemple de suggestions avec un dictionnaire anglais (`en`) : .... │[12:55] [6] [irc/libera] 3:#test(+n){4} [print,prone,prune] │ │[@Flashy] prinr █ │ └─────────────────────────────────────────────────────────────────────────────────┘ .... Exemple de suggestions avec des dictionnaires anglais et français (`en,fr`) : .... │[12:55] [6] [irc/libera] 3:#test(+n){4} [print,prone,prune/prime,primer,primé] │ │[@Flashy] prinr █ │ └─────────────────────────────────────────────────────────────────────────────────┘ .... [[spell_commands]] ==== Commandes include::includes/autogen_user_commands.fr.adoc[tag=spell_commands] [[spell_options]] ==== Options Sections dans le fichier _spell.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | color | /set spell.color.* | Couleurs. | check | /set spell.check.* | Options pour contrôler la vérification orthographique. | dict | <> + /set spell.dict.* | Dictionnaires utilisés par tampon (les options peuvent être ajoutées/supprimées dans la section). | look | /set spell.look.* | Aspect/présentation. | option | /set spell.option.* | <> (les options peuvent être ajoutées/supprimées dans la section). |=== Options : include::includes/autogen_user_options.fr.adoc[tag=spell_options] [[bars]] === Barres Une _barre_ est une zone à côté de la discussion qui peut contenir tout type de texte. Les options de barre sont définies avec les options `weechat.bar.nom.option` où `nom` et le nom de la barre et `option` l'option pour cette barre. Liste des options de barre : [width="100%",cols="2m,2,10",options="header"] |=== | Option | Valeurs | Description | type | `root`, `window` | Une barre avec le type `root` est affichée exactement une fois à l'écran, en dehors de toutes les fenêtres. La barre par défaut _buflist_ est de type `root`. + Une barre avec le type `window` est affichée dans chaque fenêtre, par exemple si vous découpez l'écran (avec `/window splith` ou `/window splitv`), vous aurez une barre dans chaque fenêtre. Les barres par défaut _title_, _status_, _input_ et _nicklist_ sont de type `window`. | position | `top`, `bottom`, `left`, `right` | Position de la barre : au dessus/en dessous de la discussion, sur la gauche/droite. | priority | entier ≥ 0 | Priorité de la barre : elle est utilisée pour ordonner les barres à l'écran, quand plusieurs barres utilisent le même type et position. + Les barres sont affichées depuis le bord de l'écran vers le centre. Une priorité plus haute affichera la barre au début, donc près du bord. + Exemple : la barre _input_ a une priorité de 1000, donc elle est affichée avant la barre _status_, qui a une priorité de 500. | size | entier ≥ 0 | La taille de la barre : nombre de colonnes pour une position left/right, nombre de lignes pour une position top/bottom. Une taille de `0` signifie automatique, donc la taille sera calculée en fonction du contenu affiché dans la barre. | size_max | entier ≥ 0 | La taille maximum pour la barre, `0` = pas de limite (cette option est utilisée seulement si `size` = `0`). | color_bg | couleur | La couleur par défaut du fond de la barre. | color_fg | couleur | La couleur par défaut du texte dans la barre. | color_delim | couleur | La couleur des délimiteurs dans la barre. | hidden | `on`, `off` | Lorsque l'option est `on`, la barre est cachée. + Note : plutôt que de changer cette option, il est préférable d'utiliser la commande `/bar`, par exemple : `/bar toggle nicklist` (voir la commande <>). | separator | `on`, `off` | Lorsque l'option est `on`, un séparateur (ligne) est affiché entre la barre et les autres barres (ou la discussion). | items | chaîne | Une liste d'objets (voir <> pour plus d'infos). | filling_left_right | `+horizontal+`, `+vertical+`, `+columns_horizontal+`, `+columns_vertical+` | Type de remplissage pour la barre lorsqu'elle a une position `left` ou `right` (voir <> pour plus d'infos). | filling_top_bottom | `+horizontal+`, `+vertical+`, `+columns_horizontal+`, `+columns_vertical+` | Type de remplissage pour la barre lorsqu'elle a une position `top` ou `bottom` (voir <> pour plus d'infos). | conditions | chaîne | Les conditions pour afficher la barre (voir <> pour plus d'infos). |=== [[bar_items]] ==== Objets L'option _items_ est une chaîne avec une liste d'objets de barre, séparés par une virgule (espace entre les objets à l'écran) ou un `+++` (objets collés). La liste des objets de barre est affichée avec la commande `/bar listitems`. Avant ou après l'objet de barre, vous pouvez utiliser des caractères (qui ne sont pas alphanumériques, `+-+` ou `+_+`). Ils seront affichés avant/après l'objet de barre avec la couleur des délimiteurs définie dans la barre (option _color_delim_). Exemple de barre avec les objets "[time],buffer_number+:+buffer_plugin+.+buffer_name,[buffer_last_number]" : .... ┌───────────────────────────────────────────────────────────────────────────┐ │[12:55] 3:irc/libera.#weechat [9] │ └───────────────────────────────────────────────────────────────────────────┘ .... [[item_spacer]] ===== Objet d'espacement Un objet appelé `spacer` peut être utilisé pour aligner les objets (gauche, centre, droite). Lorsqu'au moins un objet `spacer` est utilisé dans une barre, la largeur totale de la barre est utilisée : les espacements sont automatiquement étendus avec la même taille (ou presque). + Lorsque la barre n'est pas assez large pour afficher tous les objets, les espacements ne sont pas affichés. [NOTE] L'objet de barre `spacer` ne peut être utilisé que dans les barres avec position `top` ou `bottom`, remplissage `horizontal` et taille `1`. Exemple de barre avec les objets "[time],spacer,buffer_number+:+buffer_plugin+.+buffer_name,spacer,[buffer_last_number]" : .... ┌───────────────────────────────────────────────────────────────────────────┐ │[12:55] 3:irc/libera.#weechat [9]│ └───────────────────────────────────────────────────────────────────────────┘ .... [[item_force_buffer]] ===== Tampon forcé Une syntaxe spéciale peut être utilisée pour forcer le tampon utilisé lors de l'affichage de l'objet de barre : "@tampon:objet" (où "tampon" est le nom complet du tampon et "objet" est le nom d'un objet de barre). Ceci peut être pratique dans les barres "root", pour afficher un objet de barre pour un tampon qui n'est pas affiché dans la fenêtre courante (ou même pas affiché du tout). Exemple : liste de pseudos de bitlbee dans une barre "root" (si la barre s'appelle _bitlist_ et si le serveur bitlbee s'appelle _bitlbee_) : ---- /set weechat.bar.bitlist.items "@irc.bitlbee.&bitlbee:buffer_nicklist" ---- [[custom_bar_items]] ===== Objets de barre personnalisés Des objets de barre personnalisés peuvent être ajoutés avec la commande <>, chaque nouvel objet ayant deux propriétés définies via des options de configuration : * `conditions` : conditions évaluées pour afficher l'objet de barre, par exemple pour restreindre l'objet de barre à certains tampons (si vide, l'objet de barre est affiché partout) * `content` : contenu évalué de l'objet de barre. Dans chacune des options, les variables suivantes peuvent être utilisées : * `window` : pointeur vers la fenêtre où la barre est affichée (`NULL` pour une barre de type "root") * `buffer` : pointeur vers le tampon où la barre est affichée (tampon courant pour les barres de type "root"). Exemples de conditions : [width="100%",cols="3,10",options="header"] |=== | Condition | Description | `${window}` | Affiché seulement dans les barres de type "window" | `${buffer.number} == 1` | Affiché dans tous les tampons avec "number" = 1 | `${buffer.plugin.name} == irc` | Affiché dans tous les tampons IRC | `${type} == channel` | Affiché dans tous les tampons où la variable locale `type` est `channel` (exemple : tous les canaux IRC) | `${type} == private` | Affiché dans tous les tampons où la variable locale `type` est `private` (exemple : tous les tampons privés IRC) |=== [NOTE] Il n'y a pas de moyen intégré de rafraîchir les objets de barre personnalisés. Vous pouvez utiliser l'extension <> pour forcer un rafraîchissement, par exemple sur un ou plusieurs signaux reçus. Pour plus d'informations et des exemples, voir la commande <>. [[bar_filling]] ==== Remplissage Il y a quatre types de remplissage : * `+horizontal+` : les objets sont affichés horizontalement, de gauche à droite. S'il y a des retours à la ligne dans les objets, un espace est utilisé pour séparer les lignes. * `+vertical+` : les objets sont affichés de haut en bas. S'il y a des retours à la ligne dans les objets, une nouvelle ligne est utilisée pour séparer les lignes. * `+columns_horizontal+` : les objets sont affichés en utilisant des colonnes, où le texte est aligné à gauche. Le premier objet est en haut à gauche, le second est sur la même ligne, sur la droite. * `+columns_vertical+` : les objets sont affichés en utilisant des colonnes, où le texte est aligné à gauche. Le premier objet est en haut à gauche, le second est sur la ligne en dessous. Les barres par défaut _title_, _status_ et _input_ ont un remplissage _horizontal_, et la barre par défaut _nicklist_ a un remplissage _vertical_. Quelques exemples de remplissage pour la barre _nicklist_ : .... ┌───────────────────────────────────────────────────────────────────────┐ │Welcome to #test, this is a test channel │ │12:54:15 peter | hey! │@carl │ │12:55:01 +Max | hello │@jessika│ │ │@maddy │ │ │%Diego │ │ │%Melody │ │ │+Max │ │ │ celia │ │ │ Eva │ │ │ freddy │ │ │ Harold^│ │ │ henry4 │ │ │ jimmy17│ │ │ jodie ▼│ │[12:55] [6] [irc/libera] 3:#test(+n){24} │ │[@carl] █ │ └───────────────────────────────────────────────────────────────────────┘ filling_left_right = vertical ▲ ┌───────────────────────────────────────────────────────────────────────┐ │Welcome to #test, this is a test channel │ │12:54:15 peter | hey! │@carl lee │ │12:55:01 +Max | hello │@jessika louise │ │ │@maddy mario │ │ │%Diego mark │ │ │%Melody peter │ │ │+Max Rachel │ │ │ celia richard│ │ │ Eva sheryl │ │ │ freddy Vince │ │ │ Harold^ warren │ │ │ henry4 zack │ │ │ jimmy17 │ │ │ jodie │ │[12:55] [6] [irc/libera] 3:#test(+n){24} │ │[@carl] █ │ └───────────────────────────────────────────────────────────────────────┘ filling_left_right = columns_vertical ▲ ┌───────────────────────────────────────────────────────────────────────┐ │@carl %Diego celia Harold^ jodie mario Rachel Vince │ │@jessika %Melody Eva henry4 lee mark richard warren │ │@maddy +Max freddy jimmy17 louise peter sheryl zack │ │───────────────────────────────────────────────────────────────────────│ │ │ filling_top_bottom = columns_vertical ▲ ┌───────────────────────────────────────────────────────────────────────┐ │@carl @jessika @maddy %Diego %Melody +Max celia Eva │ │ freddy Harold^ henry4 jimmy17 jodie lee louise mario │ │ mark peter Rachel richard sheryl Vince warren zack │ │───────────────────────────────────────────────────────────────────────│ │ │ filling_top_bottom = columns_horizontal ▲ .... [[bar_conditions]] ==== Conditions L'option _conditions_ est une chaîne qui est évaluée pour savoir si la barre doit être affichée ou non. La chaîne peut être : * _active_ : la fenêtre doit être active * _inactive_ : la fenêtre doit être inactive * _nicklist_ : le tampon affiché dans la fenêtre doit avoir une liste de pseudos * une expression : elle est évaluée comme booléen (voir la commande <>) Pour une expression, les variables suivantes sont disponibles : * `+${active}+` : vrai si la fenêtre est active * `+${inactive}+` : vrai si la fenêtre est inactive * `+${nicklist}+` : vrai si le tampon affiché dans la fenêtre a une liste de pseudos Les pointeurs suivants sont disponibles : * `+${window}+` : la fenêtre où la condition est évaluée * `+${buffer}+` : le tampon de la fenêtre où la condition est évaluée Exemple pour afficher la liste de pseudos dans tous les tampons possédant une liste de pseudos, et seulement si la largeur du terminal est supérieure à 100 : ---- /set weechat.bar.nicklist.conditions "${nicklist} && ${info:term_width} > 100" ---- Même condition, mais afficher toujours la liste de pseudos sur le tampon _&bitlbee_ (même si le terminal est petit) : ---- /set weechat.bar.nicklist.conditions "${nicklist} && (${info:term_width} > 100 || ${buffer.full_name} == irc.bitlbee.&bitlbee)" ---- [[secured_data]] === Données sécurisées [[secured_data_storage]] ==== Stockage WeeChat peut chiffrer les mots de passe ou les données sensibles en utilisant des données sécurisées, stockées dans le fichier _sec.conf_. Ce fichier de configuration est lu avant tout autre fichier, et les valeurs ici stockées peuvent être utilisées dans diverses options de WeeChat ou des extensions/scripts. Vous pouvez définir une phrase secrète pour chiffrer les données dans le fichier _sec.conf_. Ce n'est pas obligatoire, mais fortement recommandé, sinon les données sont stockées sous forme de texte en clair dans le fichier. ---- /secure passphrase ceci est ma phrase secrète ---- [[secured_data_passphrase_on_startup]] ===== Phrase secrète au démarrage Lorsqu'une phrase secrète est définie, WeeChat vous demandera de la saisir lors du démarrage (mais pas sur `/upgrade`). Si vous utilisez un gestionnaire de mots de passe, vous pouvez lancer un programme externe pour lire la phrase secrète au lieu d'avoir à l'entrer manuellement au démarrage de WeeChat. + Par exemple avec password-store (command `pass`) : ---- /set sec.crypt.passphrase_command "/usr/bin/pass show weechat/passphrase" ---- Le programme peut vous demander de déverrouiller votre clé GPG ou d'entrer une autre phrase secrète. WeeChat attendra la fin de la commande pour lire la phrase secrète sur la sortie standard (elle doit être sur la première ligne et sans caractère supplémentaire). + Si la sortie ne contient pas de phrase secrète ou si celle-ci est erronée, WeeChat vous demandera alors de la saisir. [[secured_data_encryption]] ===== Chiffrement Le chiffrement des données se fait en 3 étapes : . Dériver une clé de la phrase secrète (avec du salage en option). . Calculer la somme de contrôle des données à chiffrer. . Chiffrer la somme de contrôle + les données (la sortie est : sel + somme de contrôle et données chiffrées). [NOTE] Le mode de chiffrement par bloc est _CFB_. Le résultat est stocké sous forme d'une chaîne hexadécimale dans le fichier _sec.conf_, par exemple : ---- [data] __passphrase__ = on libera = "53B1C86FCDA28FC122A95B0456ABD79B5AB74654F21C3D099A6CCA8173239EEA59533A1D83011251F96778AC3F5166A394" ---- [[secured_data_decryption]] ===== Déchiffrement Le déchiffrement des données se fait en 3 étapes : . Dériver une clé en utilisant le sel et la phrase secrète. . Déchiffrer la somme de contrôle et les données. . Vérifier que la somme de contrôle déchiffrée correspond à la somme de contrôle des données. [[secured_data_manage]] ==== Gérer les données sécurisées Pour ajouter une donnée sécurisée, utilisez la commande `/secure set`, par exemple un mot de passe pour le serveur IRC _libera_ : ---- /secure set libera motdepasse ---- Pour plus de confort, les données sécurisées peuvent être affichées dans un tampon dédié (touche kbd:[Alt+v] sur le tampon pour voir les valeurs), faites simplement : ---- /secure ---- Les données sécurisées peuvent être utilisées dans quelques options qui peuvent contenir des données sensibles comme un mot de passe, en utilisant ce format : "${sec.data.xxx}" où "xxx" est le nom de la donnée sécurisée (utilisé dans la commande `/secure set xxx ...`). + Pour une liste complète des options supportées, voir `/help secure`. Pour utiliser le mot de passe _libera_, par exemple avec <> : ---- /set irc.server.libera.sasl_password "${sec.data.libera}" ---- [[command_aliases]] === Alias de commandes L'extension Alias permet de définir des alias pour des commandes (WeeChat ou d'autres extensions). Des alias sont créés par défaut, avec le nom en lettres majuscules (pour les différencier des commandes standard) ; les commandes ne sont pas sensibles à la casse dans WeeChat, donc par exemple `/close` lance l'alias `/CLOSE`. Liste des alias par défaut : include::includes/autogen_user_default_aliases.fr.adoc[tag=default_aliases] [[alias_commands]] ==== Commandes include::includes/autogen_user_commands.fr.adoc[tag=alias_commands] [[alias_options]] ==== Options Sections dans le fichier _alias.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | cmd | <> + /set alias.cmd.* | Commandes pour les alias. | completion | <> + /set alias.completion.* | Complétions pour les alias. |=== [[commands_and_options]] === Commandes et options [[weechat_commands]] ==== Commandes WeeChat include::includes/autogen_user_commands.fr.adoc[tag=weechat_commands] [[sec_options]] ==== Options des données sécurisées Sections dans le fichier _sec.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | crypt | /set sec.crypt.* | Options pour le chiffrement. | data | <> | Données sécurisées. |=== Options : include::includes/autogen_user_options.fr.adoc[tag=sec_options] [[weechat_options]] ==== Options WeeChat Sections dans le fichier _weechat.conf_ : [width="100%",cols="3m,6m,16",options="header"] |=== | Section | Commande de contrôle | Description | debug | <> + /set weechat.debug.* | Niveau de debug, pour le cœur et les extensions (les options peuvent être ajoutées/supprimées dans la section). | startup | /set weechat.startup.* | Options de démarrage. | look | /set weechat.look.* | Aspect/présentation. | palette | <> + /set weechat.palette.* | Alias de couleurs (les options peuvent être ajoutées/supprimées dans la section). | color | /set weechat.color.* | Couleurs. | completion | /set weechat.completion.* | Options de complétion. | history | /set weechat.history.* | Options d'historique (commandes et tampons). | proxy | <> + /set weechat.proxy.* | Options des proxies. | network | /set weechat.network.* | Options réseau/SSL. | plugin | /set weechat.plugin.* | Options sur les extensions. | signal | /set weechat.signal.* | Options sur les signaux. | bar | <> + /set weechat.bar.* | Options des barres. | layout | <> | Dispositions. | notify | <> | Niveaux de notification des tampons (les options peuvent être ajoutées/supprimées dans la section). | filter | <> | Filtres. | key | <> | Touches pour le contexte "default". | key_search | <> | Touches pour le contexte "search". | key_cursor | <> | Touches pour le contexte "cursor". | key_mouse | <> | Touches pour le contexte "mouse". |=== Options : include::includes/autogen_user_options.fr.adoc[tag=weechat_options] [[irc]] == IRC L'extension IRC permet de dialoguer avec d'autres personnes via le protocole IRC. Elle est multi-serveurs, et offre toutes les commandes IRC supportées, y compris la discussion directe (DCC chat) et le transfert de fichier DCC (via l'extension xfer, voir <>). [[irc_command_line_options]] === Options de ligne de commande Il est possible de passer une URL pour un ou plusieurs serveurs, comme suit : ---- irc[6][s]://[pseudo[:mot_passe]@]irc.example.org[:port][/canal][,canal[...]] ---- Exemple pour rejoindre _#weechat_ et _#weechat-fr_ sur le serveur _irc.libera.chat_, port par défaut (6667), avec le pseudo _alice_ : ---- $ weechat irc://alice@irc.libera.chat/#weechat,#weechat-fr ---- [[irc_servers]] === Serveurs [[irc_servers_add]] ==== Ajout d'un serveur Par défaut aucun serveur n'est défini. Vous pouvez ajouter autant de serveurs que vous le souhaitez avec la commande <>. Par exemple pour vous connecter à https://libera.chat/[libera.chat ^↗^,window=_blank] avec SSL (communications chiffrées) : ---- /server add libera irc.libera.chat/6697 -ssl ---- Vous pouvez demander à WeeChat de se connecter automatiquement à ce serveur au démarrage : ---- /set irc.server.libera.autoconnect on ---- Pour vous authentifier, il est recommandé d'utiliser SASL (si le serveur le supporte), avec le mot de passe stocké sous forme de donnée sécurisée (voir aussi le chapitre sur <>) : ---- /set irc.server.libera.sasl_username "alice" /secure set libera xxxxxxx /set irc.server.libera.sasl_password "${sec.data.libera}" ---- Si SASL n'est pas supporté, vous pouvez utiliser une commande pour envoyer un message à nickserv : ---- /set irc.server.libera.command "/msg nickserv identify ${sec.data.libera}" ---- [NOTE] En envoyant une commande à nickserv, vous pourriez être authentifié après avoir rejoint les canaux, ce qui peut être un problème sur certains canaux qui vous obligent à être authentifié pour les rejoindre. Dans ce cas, vous pouvez définir un délai après la commande : `/set irc.server.libera.command_delay 5`. [[irc_servers_options]] ==== Options du serveur Les options du serveur sont nommées `irc.server..