Translators:

Questo manuale documenta il client di chat WeeChat, ed è parte del programma stesso.

È possibile trovare l’ultima versione di questo documento qui: https://weechat.org/doc

1. Introduzione

WeeChat (Wee Enhanced Environment for Chat) è un client di chat libero, veloce e leggero, realizzato per diversi sistemi operativi.

1.1. Caratteristiche

Le principali caratteristiche:

  • multi-protocollo (mainly IRC)

  • connessione a server multipli (con SSL, IPv6, proxy)

  • piccolo, veloce e leggero

  • personalizzabile ed estensibile con plugin e script

  • conforme alle RFC di IRC 1459, 2810, 2811, 2812 e 2813

  • IRC proxy and relay for remote interfaces

  • multi-piattaforma (GNU/Linux, *BSD, MacOS X, Windows ed altre)

  • 100% GPL, software libero

La home page di WeeChat si trova qui: https://weechat.org/

1.2. Requisiti

Per poter installare WeeChat, è necessario:

  • un sistema GNU/Linux in esecuzione (con gli strumenti di compilazione per i sorgenti), oppure OS compatibile

  • privilegi di root (per installare WeeChat in una directory di sistema)

  • some libraries (see dependencies).

2. Installazione

2.1. Pacchetti binari

I pacchetti binari sono disponibili per molte distribuzioni, incluse:

  • Arch Linux: pacman -S weechat

  • Cygwin (Windows): select WeeChat packages in setup.exe

  • Debian/Ubuntu (o qualunque distribuzione compatibile): apt-get install weechat-curses weechat-plugins

  • Fedora Core: dnf install weechat

  • Gentoo: emerge weechat

  • Mandriva/RedHat (o qualunque distribuzione compatibile con RPM): rpm -i /path/per/weechat-x.y.z-1.i386.rpm

  • openSUSE: zypper in weechat

  • Sourcemage: cast weechat

Potrebbero risultare utili alcuni pacchetti addizionali, come weechat-plugins.

Per altre distribuzioni, consultare il manuale per le istruzioni di installazione.

2.2. Sorgenti

WeeChat può essere compilato con cmake oppure autotools (tuttavia si raccomanda cmake).

On OS X, you can use Homebrew: brew install weechat --with-python --with-perl (for help: brew info weechat).

2.2.1. Dipendenze

La seguente tabella mostra l’elenco di pacchetti richiesti o opzionali per compilare WeeChat.

Pacchetto (1) Versione Richiesto Caratteristica

C compiler (gcc, clang, …​)

Build.

C++ compiler

Build and run tests, plugin Javascript.

cmake

Compilazione (ancora possibile con autotools, ma si raccomanda cmake).

pkg-config

Detect installed libraries.

libncursesw5-dev (2)

Interfaccia ncurses.

libcurl4-gnutls-dev

Trasferimento URL.

zlib1g-dev

Compression of packets in relay plugin (weechat protocol), script plugin.

libgcrypt20-dev

Secured data, IRC SASL authentication (DH-BLOWFISH/DH-AES), script plugin.

libgnutls28-dev

≥ 2.2.0 (3)

Connessione SSL al server IRC, support of SSL in relay plugin, IRC SASL authentication (ECDSA-NIST256P-CHALLENGE).

gettext

Internazionalizzazione (traduzione dei messaggi; la lingua base è l’inglese).

ca-certificates

Certificati per le connessioni SSL.

libaspell-dev ∥ libenchant-dev

Plugin aspell.

python-dev

≥ 2.5 (4)

Plugin python.

libperl-dev

Plugin perl.

ruby-2.3, ruby2.3-dev

≥ 1.8

Plugin ruby.

liblua5.3-dev

Plugin lua.

tcl-dev

≥ 8.5

Plugin tcl.

guile-2.0-dev

≥ 2.0

Plugin guile (scheme).

libv8-dev

≤ 3.24.3

Plugin Javascript.

asciidoctor

≥ 1.5.4

Build man page and documentation.

libcpputest-dev

≥ 3.4

Build and run tests.

(1) Il nome viene dalla distribuzione Debian GNU/Linux, nomi e versioni dei pacchetti potrebbero essere differenti in versioni e distribuzioni differenti.
(2) WeeChat può essere compilato con libncurses5-dev, ma NON è raccomandato (potrebbero verificarsi bug di visualizzazione).
(3) Gnutls ≥ 3.0.21 is required for IRC SASL authentication with mechanism ECDSA-NIST256P-CHALLENGE.
(4) La versione raccomandata di Python è la 2.7 (tutti gli script funzionano correttamente con la versione 2.7, ma non con le versioni ≤ 2.6 o ≥ 3.0).

If you are using a Debian/Ubuntu based distribution, and if you have some "deb-src" source entries in your file /etc/apt/sources.list, you can install all dependencies with the command:

# apt-get build-dep weechat

2.2.2. Compilazione con cmake

  • Installazione nelle directory di sistema (richiede privilegi di root):

$ mkdir build
$ cd build
$ cmake ..
$ make
% make install    (come root)
  • Installazione in una directory personalizzata:

$ mkdir build
$ cd build
$ cmake .. -DCMAKE_INSTALL_PREFIX=/path/della/directory
$ make
$ make install

Options can be used for cmake, with format: "-DOPTION=VALUE".

List of commonly used options:

Option Values Default value Description

CMAKE_BUILD_TYPE

Debug, Release, RelWithDebInfo, MinSizeRel

The type of build: Debug (or RelWithDebInfo) is recommended if you are running development version of WeeChat.

CMAKE_INSTALL_PREFIX

directory

/usr/local

The directory where WeeChat will be installed.

WEECHAT_HOME

directory

~/.weechat

The default home directory when running WeeChat.

CA_FILE

file

/etc/ssl/certs/ca-certificates.crt

File containing the certificate authorities. This is the default value of option weechat.network.gnutls_ca_file.

ENABLE_ALIAS

ON, OFF

ON

Compile Alias plugin.

ENABLE_ASPELL

ON, OFF

ON

Compile Aspell plugin.

ENABLE_CHARSET

ON, OFF

ON

Compile Charset plugin.

ENABLE_MAN

ON, OFF

OFF

Compile man page.

ENABLE_DOC

ON, OFF

OFF

Compile documentation (it takes a long time, recommended only if you build a binary package embedding documentation or if you can’t browse documentation online).

ENABLE_ENCHANT

ON, OFF

OFF

Compile Aspell plugin with Enchant.

ENABLE_EXEC

ON, OFF

ON

Compile Exec plugin.

ENABLE_FIFO

ON, OFF

ON

Compile Fifo plugin.

ENABLE_GNUTLS

ON, OFF

ON

Enable Gnutls (for SSL).

ENABLE_GUILE

ON, OFF

ON

Compile Guile plugin (Scheme).

ENABLE_IRC

ON, OFF

ON

Compile IRC plugin.

ENABLE_JAVASCRIPT

ON, OFF

ON

Compile Javascript plugin.

ENABLE_LARGEFILE

ON, OFF

ON

Support of large files.

ENABLE_LOGGER

ON, OFF

ON

Compile Logger plugin.

ENABLE_LUA

ON, OFF

ON

Compile Lua plugin.

ENABLE_NCURSES

ON, OFF

ON

Compile Ncurses interface.

ENABLE_NLS

ON, OFF

ON

Enable NLS (translations).

ENABLE_PERL

ON, OFF

ON

Compile Perl plugin.

ENABLE_PYTHON

ON, OFF

ON

Compile Python plugin.

ENABLE_PYTHON3

ON, OFF

OFF

Compile Python plugin using Python 3 (NOT recommended because many scripts are not compatible with Python 3).

ENABLE_RELAY

ON, OFF

ON

Compile Relay plugin.

ENABLE_RUBY

ON, OFF

ON

Compile Ruby plugin.

ENABLE_SCRIPT

ON, OFF

ON

Compile Script plugin.

ENABLE_SCRIPTS

ON, OFF

ON

Compile script plugins (Python, Perl, Ruby, Lua, Tcl, Guile, Javascript).

ENABLE_TCL

ON, OFF

ON

Compile Tcl plugin.

ENABLE_TRIGGER

ON, OFF

ON

Compile Trigger plugin.

ENABLE_XFER

ON, OFF

ON

Compile Xfer plugin.

ENABLE_TESTS

ON, OFF

OFF

Compile tests.

The other options can be displayed with this command:

$ cmake -LA

Or with Curses interface:

$ ccmake ..

2.2.3. Compilazione con autotools

Only cmake is officially supported to build WeeChat. You should use autotools only if you are not able to use cmake.
Build with autotools requires more dependencies and is slower than with cmake.
  • Installazione nelle directory di sistema (richiede privilegi di root):

$ ./autogen.sh
$ mkdir build
$ cd build
$ ../configure
$ make
% make install    (come root)
  • Installazione in una directory personalizzata:

$ ./autogen.sh
$ mkdir build
$ cd build
$ ../configure --prefix=/path/to/directory
$ make
$ make install

Options can be used for configure script, they can be displayed with this command:

$ ./configure --help

2.3. Sorgenti git

Attenzione: i sorgenti git sono per gli utenti avanzati: potrebbero non compilare o essere instabili. Siete avvisati!

Per ottenere i sorgenti git, dare il comando:

$ git clone https://github.com/weechat/weechat.git

Poi seguire le istruzioni per i sorgenti (consultare sorgenti).

2.4. Segnalare gli errori

Nel caso in cui si verifichino errori, o si desideri segnalare qualsiasi errore futuro di WeeChat, è necessario:

  • compilarlo con informazioni di debug (o installare il pacchetto binario con le informazioni di debug)

  • abilitare i file core sul proprio sistema

  • installare gdb

2.4.1. Informazioni di debug

Se si compila con cmake:

$ cmake .. -DCMAKE_BUILD_TYPE=Debug

Se compilato con gli autotools, il debug è attivato automaticamente (--with-debug=1).

Se è stato installato il pacchetto binario, installare il pacchetto weechat-gdb.

2.4.2. File core

To enable core files, you can use option weechat.startup.sys_rlimit:

/set weechat.startup.sys_rlimit "core:-1"

For WeeChat ≤ 0.3.8 or if you want to enable core files even before WeeChat starts, you can use ulimit command.

Ad esempio su Linux con la shell bash, aggiungere questa riga al proprio ~/.bashrc:

ulimit -c unlimited

Oppure impostare una dimensione massima:

ulimit -c 200000

2.4.3. Ottenere un backtrace con gdb

In caso di errore di WeeChat, il sistema creerà un file core oppure core.12345 (12345 è l’id del processo). Questo file viene creato nella directory in cui è in esecuzione WeeChat (e non la directory dove WeeChat è installato!).

Ad esempio, se weechat è installato in /usr/bin/ ed il file core si trova in /home/xxx/, allora eseguire gdb con questo comando:

gdb /usr/bin/weechat /home/xxx/core

All’interno di gdb, usare il comando bt full per visualizzare il backtrace. Verrà mostrato qualcosa di simile a questo:

(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  <signal handler called>
#4  0x000000000044cb24 in hook_process_timer_cb (arg_hook_process=0x254eb90,
    remaining_calls=<value optimized out>) at /some_path/src/core/wee-hook.c:1364
        hook_process = 0x254eb90
        status = <value optimized out>
#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 <repeats 16 times>}}
        write_fds = {fds_bits = {0 <repeats 16 times>}}
        except_fds = {fds_bits = {0 <repeats 16 times>}}
        max_fd = <value optimized out>

Bisogna riportare l’errore agli sviluppatori, e specificare quale azione ha causato l’errore.

Grazie per il vostro aiuto!

2.4.4. Debug di WeeChat durante l’esecuzione

Per eseguire il debug di un’istanza di WeeChat in esecuzione (ad esempio se WeeChat sembra sia bloccato), è possibile usare gdb con l’id del processo (sostituire 12345 con il PID del processo weechat):

gdb /usr/bin/weechat 12345

Poi, come per un crash, usare il comando bt full:

(gdb) bt full

3. Utilizzo

3.1. Esecuzione di WeeChat

Argomenti a riga di comando:

-a, --no-connect

Disabilita la connessione automatica ai server all’avvio di WeeChat.

-c, --colors

Mostra i colori prefefiniti nel terminale.

-d, --dir <path>

Imposta una directory come home per WeeChat (utilizzata per i file di configurazione, log, plugin e script dell’utente), il valore predefinito è "~/.weechat" (nota: directory viene creata se non trovata da WeeChat). If this option is not given, the environment variable WEECHAT_HOME is used (if not empty).

-h, --help

Mostra l’aiuto.

-l, --license

Mostra la licenza di WeeChat.

-p, --no-plugin

Disabilita il caricamento automatico dei plugin.

-r, --run-command <command>

Esegue un comando(i) dopo l’avvio (più comandi possono essere separati da punto e virgola).

-s, --no-script

Disabilita il caricamento automatico dei script.

--upgrade

Upgrade WeeChat using session files generated with command /upgrade -quit.

-v, --version

Mostra la versione di WeeChat.

plugin:option

Opzione per il plugin.

Per avviare WeeChat, digitare questo comando:

$ weechat

Alla prima esecuzione di WeeChat, viene creato un file di configurazione predefinito. Il file di configurazione viene creato nella directory: ~/.weechat/weechat.conf.

È possibile modificare questo file per configurare WeeChat a seconda delle proprie esigenze, oppure impostando i parametri con il comando /set all’interno di WeeChat (consultare comandi di WeeChat).

3.2. Files and directories

WeeChat writes configuration files and other data in directory ~/.weechat by default.

The directories are:

Path/file Description

~/.weechat/

WeeChat home directory (can be changed, see Running WeeChat).

   logs/

Log files (one file per buffer).

   python/

Python scripts.

      autoload/

Python scripts auto-loaded on startup (1).

   perl/

Perl scripts.

      autoload/

Perl scripts auto-loaded on startup (1).

   ruby/

Ruby scripts.

      autoload/

Ruby scripts auto-loaded on startup (1).

   lua/

Lua scripts.

      autoload/

Lua scripts auto-loaded on startup (1).

   tcl/

Tcl scripts.

      autoload/

Tcl scripts auto-loaded on startup (1).

   guile/

Guile scripts.

      autoload/

Guile scripts auto-loaded on startup (1).

   javascript/

Javascript scripts.

      autoload/

Javascript scripts auto-loaded on startup (1).

(1) This directory often contains only symbolic links to scripts in parent directory.

The files in home directory are:

File Description Sensitive data

weechat.conf

Main WeeChat configuration file

Possible (example: list of channels in a saved buffers layout).

sec.conf

Configuration file with secured data

Yes, highly sensitive: this file must never be shared with anyone.

plugins.conf

Plugins configuration file

Possible, depends on plugins/scripts.

alias.conf

Configuration file for alias plugin

Possible, depends on aliases.

aspell.conf

Configuration file for aspell plugin

No.

charset.conf

Configuration file for charset plugin

No.

exec.conf

Configuration file for exec plugin

No.

irc.conf

Configuration file for irc plugin

Yes: it can contain passwords for servers, nickserv and channels (if not stored in sec.conf).

logger.conf

Configuration file for logger plugin

No.

relay.conf

Configuration file for relay plugin

No.

script.conf

Configuration file for script plugin

No.

trigger.conf

Configuration file for trigger plugin

Possible, depends on triggers.

xfer.conf

Configuration file for xfer plugin

No.

weechat.log

WeeChat log file

No.

It is not recommended to edit configuration files by hand because WeeChat may write them at any time (for example on /quit) and after any change you must run the command /reload (with the risk of losing other changes that were not yet saved with /save).
You can use the command /set, which checks the value and applies immediately the changes.

3.3. Layout dello schermo

Esempio di terminale con WeeChat:

 ▼ bar "title"
┌───────────────────────────────────────────────────────────────────────────┐
│Welcome to #test, this is a test channel                                   │
│12:52:27   --> | Flashy (flashcode@weechat.org) has joined #test   │@Flashy│
│12:52:27    -- | Nicks #test: [@Flashy @joe +weebot peter]         │@joe   │
│12:52:27    -- | Channel #test: 4 nicks (2 ops, 1 voice, 1 normal) │+weebot│
│12:52:27    -- | Channel created on Tue Jan 27 06:30:17 2009       │peter  │
│12:54:15 peter | hey!                                              │       │
│12:55:01  @joe | hello                                             │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│[12:55] [6] [irc/freenode] 3:#test(+n){4}* [H: 4:#abc(2,5), 6]             │
│[@Flashy(i)] hi peter!█                                                    │
└───────────────────────────────────────────────────────────────────────────┘
 ▲ bars "status" and "input"                               bar "nicklist" ▲

Lo schermo è composto dalle seguenti aree:

  • area di chat (centro dello schermo) con le righe di chat, e per ogni riga:

    • ora

    • prefisso (prima di "|")

    • messaggio (dopo di "|")

  • barre che circondano l’area di chat, quelle predefinite sono:

    • barra titolo, in alto rispetto all’area di chat

    • barra stato, in basso rispetto all’area di chat

    • barra input, in basso rispetto alla barra di stato

    • barra nicklist, sulla destra

La barra stato ha i seguenti elementi predefiniti:

Elemento Esempio Descrizione

time

[12:55]

Ora.

buffer_last_number

[6]

Number of last buffer in list.

buffer_plugin

[irc/freenode]

Plugin del buffer attivo (il plugin irc può aggiungere il nome del server irc usato dal buffer).

buffer_number

3

Numero del buffer corrente.

buffer_name

#test

Nome del buffer attivo.

buffer_modes

+n

Modalità canale IRC.

buffer_nicklist_count

{4}

Numero di nick nella lista nick.

buffer_zoom

!

! means the merged buffer is zoomed (only this one is displayed), empty value means all merged buffers are displayed.

buffer_filter

*

Indicatore filtraggio: * significa che alcune righe sono filtrate (nascoste), valori vuoti indicano che tutte le righe sono visualizzate.

scroll

-ANCORA(50)-

Indicatore di scorrimento, con il numero di righe sotto l’ultima riga visualizzata.

lag

[Ritardo: 2.5]

Indicatore ritardo, in secondi (nascosto se il ritardo è basso).

hotlist

[H: 4:#abc(2,5), 6]

Elenco dei buffer con attività (messaggi non letti) (nell’esempio, 2 notifiche e 5 messaggi non letti su #abc, un messaggio non letto sul buffer #6).

completion

abc(2) def(5)

Elenco di parole per il completamento, con il numero di completamenti possibili per ogni parola.

La barra input ha i seguenti elementi predefiniti:

Elemento Esempio Descrizione

input_prompt

[@Flashy(i)]

Prompt per l’input, for irc: nick and modes (mode "+i" means invisible on freenode).

away

(assente)

Indicatore di assenza.

input_search

[Search (~ str,msg)]

Search indicator (“~”: case insensitive, “==”: case sensitive, “str”: search string, “regex”: search regular expression, “msg”: search in messages, “pre”: search in prefixes, “pre|msg”: search in prefixes and messages).

input_paste

[Incollare 7 righe ? [ctrl-Y] Sì [ctrl-N] No]

Chiede all’utente se incollare le righe.

input_text

ciao peter!

Testo in input.

Other items available (not used in bars by default):

Item Example Description

aspell_dict

fr,en

Spelling dictionaries used on current buffer.

aspell_suggest

print,prone,prune

Spelling suggestions for word under cursor (if misspelled).

buffer_count

10

Total number of buffers opened.

buffer_short_name

#test

Current buffer short name.

irc_channel

#test

Current IRC channel name.

irc_nick_modes

@

IRC modes for self nick.

mouse_status

M

Mouse status (empty if mouse is disabled).

window_number

2

Current window number.

3.4. Riga di comando

La riga di comando di WeeChat (nella parte inferiore della finestra) consente di inserire i comandi o di inviare del testo sul buffer.

3.4.1. Sintassi

I comandi iniziano con il carattere "/", seguito dal nome del comando. Ad esempio, per consultare un elenco di opzioni:

/set

Il testo inviato ad un buffer è qualsiasi testo che non comincia con il carattere "/". Per esempio, per inviare il testo ciao sul buffer attivo:

ciao

Ad ogni modo, è possibile iniziare con il carattere "/", aggiungendone poi un altro. Ad esempio, per inviare il testo /set sul buffer attivo:

//set

3.4.2. Codici colore

Per alcuni plugin come IRC, è possibile usare codici colori ed attributi, come segue (digitare Ctrl+c poi la lettera che segue, con il valore opzionale):

Key Description

Ctrl+c, b

testo in grassetto.

Ctrl+c, c, xx

colore del testo xx (consultare la lista di colori che segue).

Ctrl+c, c, xx, ,, yy

colore del testo xx e di sfondo yy (consultare la lista di colori che segue).

Ctrl+c, i

italic text.

Ctrl+c, o

disabilita colori ed attributi.

Ctrl+c, v

video inverso (inverte il colore del testo con quello di sfondo).

Ctrl+c, _

testo sottolineato.

Lo stesso codice (senza numero per Ctrl+c, c) può essere usato per terminare l’attributo.

I codici colore per Ctrl+c, c sono:

IRC color WeeChat color

00

white

01

black

02

blue

03

green

04

lightred

05

red

06

magenta

07

brown

08

yellow

09

lightgreen

10

cyan

11

lightcyan

12

lightblue

13

lightmagenta

14

darkgray

15

gray

16

52

17

94

18

100

19

58

20

22

21

29

22

23

23

24

24

17

25

54

26

53

27

89

28

88

29

130

30

142

31

64

32

28

33

35

34

30

35

25

36

18

37

91

38

90

39

125

40

124

41

166

42

184

43

106

44

34

45

49

46

37

47

33

48

19

49

129

50

127

51

161

52

196

53

208

54

226

55

154

56

46

57

86

58

51

59

75

60

21

61

171

62

201

63

198

64

203

65

215

66

227

67

191

68

83

69

122

70

87

71

111

72

63

73

177

74

207

75

205

76

217

77

223

78

229

79

193

80

157

81

158

82

159

83

153

84

147

85

183

86

219

87

212

88

16

89

233

90

235

91

237

92

239

93

241

94

244

95

247

96

250

97

254

98

231

99

default

To show all available colors in your terminal, you can do /color then Alt+c in WeeChat or run this command in terminal: weechat --colors.

Esempio: visualizza "ciao a tutti!" con "ciao" scritto in blu chiaro grassetto e "a tutti" in rosso chiaro sottolineato:

^Cc12^Cbciao ^Cb^Cc04^C_a tutti^C_^Cc !
Nel plugin irc, si possono riorganizzare i colori usando l’opzione irc.color.mirc_remap.

3.5. Colori

WeeChat può usare fino a 256 coppie di colore per visualizzare il testo nelle barre e nell’area di chat(il terminale deve supportare 256 colori per essere utilizzati in WeeChat).

In base al valore della variabile di ambiente TERM, potrebbero verificarsi i seguenti limiti per i colori in WeeChat:

$TERM Colori Coppie

"rxvt-unicode", "xterm", …​

88

256

"rxvt-256color", "xterm-256color", …​

256

256

"screen"

8

64

"screen-256color"

256

256

"tmux"

8

64

"tmux-256color"

256

256

È possibile eseguire weechat --colors o utilizzare il comando /color in WeeChat per visualizzare i limiti del proprio ambiente.

Alcuni valori raccomandati per TERM se si desiderano 256 colori:

  • con screen: screen-256color

  • under tmux: screen-256color or tmux-256color

  • outside screen/tmux: xterm-256color, rxvt-256color, putty-256color, …​

Potrebbe essere necessario installare il pacchetto "ncurses-term" per usare questi valori nella variabile TERM.

Se si sta utilizzando screen, è possibile aggiungere questa riga al proprio ~/.screenrc:

term screen-256color

If your TERM variable has wrong value and that WeeChat is already running, you can change it with these two commands:

/set env TERM screen-256color
/upgrade

3.5.1. Colori base

I colori base in WeeChat sono:

Nome Colore

default

Colore predefinito del terminale (trasparente per lo sfondo)

black

Nero

darkgray

Grigio scuro

red

Rosso scuro

lightred

Rosso chiaro

green

Verde scuro

lightgreen

Verde chiaro

brown

Marrone

yellow

Giallo

blue

Blu scuro

lightblue

Blu chiaro

magenta

Rosa scuro

lightmagenta

Rosa chiaro

cyan

Azzurro scuro

lightcyan

Azzurro chiaro

gray

Grigio

white

Bianco

3.5.2. Colori estesi

WeeChat alloca dinamicamente le coppie colore quando vengono usati i colori sullo schermo (per mostrare buffer e barre).

In aggiunta ai colori di base, si può usare un numero per il colore compreso tra 1 e il limite del proprio terminale.

Il comando /color mostra i colori attivi ed i limiti. Com Alt+c si può passare temporaneamente ai colori del terminale per sceglierne uno.

Se ad esempio si desidera visualizzare l’ora in arancione nel buffer:

/set weechat.color.chat_time 214

O se si desidera uno sfondo verde scuro per la barra di stato:

/set weechat.bar.status.color_bg 22

3.5.3. Alias

Si possono aggiungere degli alias ai colori con il comando /color alias e usarli in ogni opzione relativa al colore.

Ad esempio:

/color alias 214 orange
/set weechat.color.chat_delimiters orange

3.5.4. Attributi

Esistono alcuni attributi per i colori. Uno o più attributi vanno aggiunti prima del nome o del numero del colore:

  • * : testo in grassetto

  • ! : video inverso

  • / : testo in corsivo

  • _ : testo sottolineato

  • | : mantiene attributi: non ripristina grassetto/inverso/sottolineato al cambio di colore

Ad esempio se si vuole il proprio nick bianco e sottolineato:

/set weechat.color.chat_nick_self _white

O se si desidera l’ora nella barra di stato arancione sottolineata e in grassetto:

/set weechat.color.status_time *_214

Per usare un attributo con il colore predefinito del terminale (-1), bisogna usare un numero maggiore dell’ultimo colore del terminale, ad esempio il numero massimo in WeeChat: 99999.

Esempio di grassetto con il colore di primo piano del terminale:

/set weechat.color.status_time *99999

3.6. Buffer e finestre

Un buffer è composto da un numero, un nome, delle righe visualizzate (e altri dati).

Esempi di buffer:

  • buffer core (creato by WeeChat all’avvio, non può essere chiuso)

  • server irc (mostra i messaggi dal server)

  • canale irc

  • query irc

Una finestra (o window) è un’area dello schermo in cui viene visualizzato un buffer. È possibile dividere lo schermo in più finestre.

Ogni finestra visualizza un buffer. Un buffer può essere nascosto (non visualizzato da una finestra) o visualizzato da una o più finestre.

Esempio di split orizzontale (/window splith):

                          ▼ window #2 (buffer #4)
┌───────────────────────────────────────────────────────────────────────────┐
│Welcome to #abc                                                            │
│12:55:12     Max | hi                                              │@Flashy│
│12:55:20 @Flashy | hi Max!                                         │Max    │
│12:55:32     Max | how are you?                                    │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│[12:55] [6] [irc/freenode] 4:#abc(+n){2}                                   │
│[@Flashy]                                                                  │
│───────────────────────────────────────────────────────────────────────────│
│Welcome to #test                                                           │
│12:54:15 peter | hey!                                              │@Flashy│
│12:55:01  @joe | hello                                             │@joe   │
│                                                                   │+weebot│
│                                                                   │peter  │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│[12:55] [6] [irc/freenode] 3:#test(+n){4}                                  │
│[@Flashy] hi peter!█                                                       │
└───────────────────────────────────────────────────────────────────────────┘
                          ▲ window #1 (buffer #3)

Esempio di split verticale (/window splitv):

┌───────────────────────────────────────────────────────────────────────────┐
│Welcome to #test                     │Welcome to #abc                      │
│12:54:15 peter | hey!        │@Flashy│12:55:12     Max | hi        │@Flashy│
│12:55:01  @joe | hello       │@joe   │12:55:20 @Flashy | hi Max!   │Max    │
│                             │+weebot│                             │       │
│                             │peter  │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│[12:55] [irc/oftc] 3:#test(+n){4}    │[12:55] [irc/oftc] 4:#abc(+n){2}     │
│[@Flashy] hi peter!█                 │[@Flashy]                            │
└───────────────────────────────────────────────────────────────────────────┘
      ▲ window #1 (buffer #3)               ▲ window #2 (buffer #4)

Esempio di split orizzontale + verticale:

                                            ▼ window #3 (buffer #5)
┌───────────────────────────────────────────────────────────────────────────┐
│Welcome to #test                     │Welcome to #def                      │
│12:54:15 peter | hey!        │@Flashy│12:55:42 @Flashy | hi        │@Flashy│
│12:55:01  @joe | hello       │@joe   │12:55:56    alex | hi Flashy │alex   │
│                             │+weebot│                             │       │
│                             │peter  │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │[12:55] [irc/oftc] 5:#def(+n){2}     │
│                             │       │[@Flashy]                            │
│                             │       │─────────────────────────────────────│
│                             │       │Welcome to #abc                      │
│                             │       │12:55:12     Max | hi        │@Flashy│
│                             │       │12:55:20 @Flashy | hi Max!   │Max    │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│                             │       │                             │       │
│[12:55] [irc/oftc] 3:#test(+n){4}    │[12:55] [irc/oftc] 4:#abc(+n){2}     │
│[@Flashy] hi peter!█                 │[@Flashy]                            │
└───────────────────────────────────────────────────────────────────────────┘
      ▲ window #1 (buffer #3)               ▲ window #2 (buffer #4)

3.7. Buffers lines

3.7.1. Format of lines

Lines displayed in formatted buffers have following fields:

Field Displayed Description

date/time (message)

Yes

Date/time of message (may be past).

date/time (print)

No

Date/time when WeeChat prints the message.

prefix

Yes

Prefix of message, commonly a nick.

message

Yes

The message itself.

displayed

No

Boolean: true if line is displayed, false if line is filtered with command /filter.

highlight

No

Boolean: true if line has a highlight, false otherwise.

tags

With /debug tags

Tags associated with the line (see lines tags).

The display of lines can be customized with many look options (weechat.look.*) and color options (weechat.color.chat_*).

3.7.2. Lines tags

WeeChat uses tags in lines for different purposes:

  • highlight

  • notify level

  • logging

  • use of command /filter

Tags can be displayed with the command /debug tags (same command to hide them).

Tag usati di frequente (elenco non esaustivo):

Tag Descrizione

no_filter

La riga non può essere filtrata.

no_highlight

Evidenziazione non possibile sulla riga.

no_log

La riga non viene scritta nel file di log.

log0 …​ log9

Livello di log per la riga (consultare /help logger).

notify_none

Il buffer con la riga non viene aggiunto alla hotlist.

notify_message

Il buffer con la riga viene aggiunto alla hotlist con il livello "message".

notify_private

Il buffer con la riga viene aggiunto alla hotlist con il livello "private".

notify_highlight

Il buffer con la riga viene aggiunto alla hotlist con il livello "higlight".

self_msg

Self message.

nick_xxx

Il messaggio viene dal nick "xxx".

prefix_nick_ccc

Il prefisso è un nick con il colore "ccc".

host_xxx

Username and host in message.

irc_xxx

Messaggio IRC "xxx" (può essere un comando o un numero di 3 cifre).

irc_numeric

Messaggio IRC numerico.

irc_error

Errore dal server IRC.

irc_action

Azione da un nic (comando /me).

irc_ctcp

Messaggio CTCP.

irc_ctcp_reply

Risposta ad un messaggio CTCP.

irc_smart_filter

Messaggio IRC filtrabile tramite lo "smart filter" (filtro intelligente).

away_info

Messagio con informazioni sull’assenza.

3.8. Bars

A bar is an area beside the chat that can contain any type of text.

The bar options can be set with options weechat.bar.name.option where name is the name of the bar and option the option for this bar.

List of bar options:

Option Values Description

type

root, window

A bar with type root is displayed exactly one time on screen, outside all windows. There is no root bar by default, but an example is the bar buffers created by script buffers.pl (sidebar with list of buffers).
A bar with type window is displayed in each window, for example if you split one time the screen (with /window splith or /window splitv), you will have one bar in each window. The four default bars (title, status, input, nicklist) have type window.

position

top, bottom, left, right

Position of the bar: above/below chat, on the left/right.

priority

integer ≥ 0

Priority for display of bar: this is used for ordering the bars on screen when many bars have same type and position.
The bars are displayed from the edge of the screen to the center. A higher priority will display bar at the beginning, so closer to the edge.
Example: input bar has priority 1000, so it is displayed before the status bar, which has priority 500.

size

integer ≥ 0

The size of the bar: number of columns for position left/right, number of lines for position top/bottom. A size of 0 means automatic, so the size will be computed according to content displayed in bar.

size_max

integer ≥ 0

The maximum size for a bar, 0 = no limit (this option is used only if size = 0).

color_bg

color

The default background color for the bar.

color_fg

color

The default text color for the bar.

color_delim

color

The color for delimiters in bar.

hidden

on, off

When option is on, the bar is hidden.
Note: instead of changing this option, the command /bar is preferred, for example: /bar toggle nicklist (see command /bar).

separator

on, off

When option is on, a separator (line) is displayed between this bar and other bars (or chat).

items

string

A list of items (see items for more info).

filling_left_right

horizontal, vertical, columns_horizontal, columns_vertical

Type of filling for a bar which has position left or right (see filling for more info).

filling_top_bottom

horizontal, vertical, columns_horizontal, columns_vertical

Type of filling for a bar which has position top or bottom (see filling for more info).

conditions

string

The conditions to display the bar (see conditions for more info).

3.8.1. Items

The option items is a string with a list of bar items, separated by a comma (space between items on screen) or "+" (glued items).

The list of bar items is displayed with command /bar listitems.

Before or after item name, you can use chars (that are not alphanumeric, "-" or ""). They will be displayed before/after item with the delimiters color defined in bar (option _color_delim).

Example of bar with items "[time],buffer_number+:+buffer_plugin+.+buffer_name":

┌───────────────────────────────────────────────────────────────────────────┐
│[12:55] 3:irc/freenode.#weechat                                            │
└───────────────────────────────────────────────────────────────────────────┘

A special syntax can be used to force the buffer used when displaying the bar item: "@buffer:item" (where "buffer" is the full name of buffer and "item" is the name of a bar item).

This is useful in root bars, to display item for a specific buffer which is not displayed in the current window (or even not displayed at all).

Example: nicklist of bitlbee in a root bar (if the bar is called bitlist and if bitlbee server is called bitlbee):

/set weechat.bar.bitlist.items "@irc.bitlbee.&bitlbee:buffer_nicklist"

3.8.2. Filling

There are four types of filling:

  • horizontal: the items are displayed horizontally, from left to right. If there are new lines in items, a space is used to separate lines.

  • vertical: the items are displayed from top to bottom. If there are new lines in items, a new line is used to separate lines.

  • columns_horizontal: items are displayed using columns, where text is aligned on the left. The first item is on top left, the second is on same line, on the right.

  • columns_vertical: items are displayed using columns, where text is aligned on the left. The first item is on top left, the second is one line below.

Default bars title, status and input have horizontal filling, and default bar nicklist has vertical filling.

Some examples of filling for bar 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/freenode] 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/freenode] 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 ▲

3.8.3. Conditions

The option conditions is a string which is evaluated to know if the bar must be displayed or not.

The string can be:

  • active: the window must be active

  • inactive: the window must be inactive

  • nicklist: the buffer displayed in window must have a nicklist

  • an expression: it is evaluated as boolean (see command /eval)

For the expression, following variables are available:

  • ${active}: true if window is active

  • ${inactive}: true if window is inactive

  • ${nicklist}: true if buffer displayed in window has a nicklist

Following pointers are available:

  • ${window}: the window where condition is evaluated

  • ${buffer}: the buffer of window where condition is evaluated

Example to display nicklist bar in all buffers with a nicklist, and only if width of window is > 100 :

/set weechat.bar.nicklist.conditions "${nicklist} && ${window.win_width} > 100"

Same condition, but always display nicklist on buffer &bitlbee (even if window is small):

/set weechat.bar.nicklist.conditions "${nicklist} && (${window.win_width} > 100 || ${buffer.full_name} == irc.bitlbee.&bitlbee)"

3.9. Bare display

A special display, called "bare display" can be used for easy click on long URLs and selection of text (using the mouse).

The bare display has following features:

  • it displays only the content of current buffer: no window split neither bars (no title, nicklist, status, input, …​)

  • the WeeChat mouse support is disabled (if it was enabled): you can use your mouse like you do in the terminal to click on URLs and select text

  • ncurses is not used, therefore URLs are not cut at the end of lines.

The default key to enabled bare display is Alt+l, and same key to exit (or by default anything changing the input will exit the bare display, see option weechat.look.bare_display_exit_on_input).

The time format can be customized with the option weechat.look.bare_display_time_format.

The bare display can be enabled for a specific delay using the command /window.

If WeeChat looks like that:

┌───────────────────────────────────────────────────────────────────────────┐
│Welcome to #test, this is a test channel                                   │
│12:52:27   --> | Flashy (flashcode@weechat.org) has joined #test   │@Flashy│
│12:52:27    -- | Nicks #test: [@Flashy @joe +weebot peter]         │@joe   │
│12:52:27    -- | Channel #test: 4 nicks (2 ops, 1 voice, 1 normal) │+weebot│
│12:52:27    -- | Channel created on Tue Jan 27 06:30:17 2009       │peter  │
│12:54:15 peter | hey!                                              │       │
│12:55:01  @joe | peter: hook_process: https://weechat.org/files/do │       │
│               | c/devel/weechat_plugin_api.en.html#_weechat_hook_ │       │
│               | process                                           │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│                                                                   │       │
│[12:55] [6] [irc/freenode] 3:#test(+n){4}* [H: 4:#abc(2,5), 6]             │
│[@Flashy(i)] hi peter!█                                                    │
└───────────────────────────────────────────────────────────────────────────┘

The screen will look like that in bare display:

┌───────────────────────────────────────────────────────────────────────────┐
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│                                                                           │
│12:52 --> Flashy (flashcode@weechat.org) has joined #test                  │
│12:52 -- Nicks #test: [@Flashy @joe +weebot peter]                         │
│12:52 -- Channel #test: 4 nicks (2 ops, 1 voice, 1 normal)                 │
│12:52 -- Channel created on Tue Jan 27 06:30:17 2009                       │
│12:54 <peter> hey!                                                         │
│12:55 <@joe> peter: hook_process: https://weechat.org/files/doc/devel/weech│
│at_plugin_api.en.html#_weechat_hook_process                                │
└───────────────────────────────────────────────────────────────────────────┘

So you can click the URL from joe without any problem in your terminal (of course this supposes that your terminal supports click on URLs).

3.10. Livelli di notifica

3.10.1. Setup notify levels

Sono possibili quattro livelli per i messaggi mostrati nei buffer, dal più basso al più alto:

  • low: messaggio di bassa importanza (ad esempio entrata/uscita/disconnessione di irc)

  • message: messaggio da un utente

  • private: messaggio in un buffer privato

  • highlight: messaggio con notifica

Ogni buffer ha un livello di notifica, che viene usato per decidere quale messaggio il buffer andrà ad aggiungere nella hotlist.

Il livello predefinito di notifica può essere impostato usando l’opzione weechat.look.buffer_notify_default, il valore predefinito è all.

Livello di notifica Livello del messaggio aggiunto alla hotlist

none

(nessuno)

highlight

highlight + private

message

highlight + private + message

all

highlight + private + message + low

Il livello di notifica può essere definito per un set di buffer, ad esempio tutti i buffer per il server irc "freenode":

/set weechat.notify.irc.freenode message

Imposta il livello di notifica highlight solo sul canale #weechat:

/set weechat.notify.irc.freenode.#weechat highlight

Il livello di notifica per un buffer può essere impostato con il comando /buffer:

/buffer notify highlight

3.10.2. Max hotlist level for nicks

It is possible to set max hotlist level for some nicks, per buffer, or per group of buffers (like IRC servers).

The buffer property "hotlist_max_level_nicks" can be set with a list of nicks and for each nick the max hotlist level to trigger, possible levels are:

  • -1: no hotlist changes for nick

  • 0: low priority (like join/part messages)

  • 1: message

  • 2: private message

  • 3: highlight (in fact useless, since it’s already the default max for all messages)

For example to disable highlights from "joe" and "mike" on current buffer:

/buffer set hotlist_max_level_nicks_add joe:2,mike:2
The buffer property "hotlist_max_level_nicks" is not saved in configuration.
You can easily save it with the script buffer_autoset.py: you can install it with /script install buffer_autoset.py and get help with /help autosetbuffer.

3.11. Highlights

3.11.1. Add words to highlight

By default, WeeChat highlights messages from other users containing your nick, therefore the highlight depends on the buffer (the nick can be different from one buffer to another).

You can add other words to highlight with the option weechat.look.highlight, for example to highlight your nick and "word1", "word2" and all words beginning with "test":

/set weechat.look.highlight word1,word2,test*

If you need a more specific rule for the word, you can use regular expressions with the option weechat.look.highlight_regex, for example to highlight words "flashcode", "flashcöde" and "flashy":

/set weechat.look.highlight_regex flashc[oö]de|flashy

The delimiters around words to highlight can be customized with the option weechat.look.word_chars_highlight.

3.11.2. Add tags to highlight

Lines displayed can contain "tags", which give some info about the origin of message or the message itself.
You can display tags with the command /debug tags (same command to hide them).

You can add specific tags to highlight with the option weechat.look.highlight_tags. Tags are separated by commas, and multiple tags can be separated by "+" to do a logical "and" between them.

For example to highlight all messages from nick "FlashCode" and all notices from nicks beginning with "toto":

/set weechat.look.highlight_tags "nick_flashcode,irc_notice+nick_toto*"

3.11.3. Set extra highlights on buffer

You can force highlight using a regular expression with the buffer property "highlight_regex".

For example to force the highlight on all messages in the current buffer:

/buffer set highlight_regex .*
The buffer property "highlight_regex" is not saved in configuration.
You can easily save it with the script buffer_autoset.py: you can install it with /script install buffer_autoset.py and get help with /help autosetbuffer.

3.12. Associazione tasti predefinita

3.12.1. Tasti per la riga di comando

Tasti Descrizione Comando


Ctrl+b

Passa al carattere precedente nella riga di comando.

/input move_previous_char


Ctrl+f

Passa al carattere successivo nella riga di comando.

/input move_next_char

Ctrl+
Alt+b

Passa alla parola precedente nella riga di comando.

/input move_previous_word

Ctrl+
Alt+f

Passa alla parola successiva nella riga di comando.

/input move_next_word

Home
Ctrl+a

Si sposta all’inizio della riga di comando.

/input move_beginning_of_line

End
Ctrl+e

Si sposta alla fine della riga di comando.

/input move_end_of_line

Ctrl+c, b

Inserisce il codice per il testo in grassetto.

/input insert \x02

Ctrl+c, c

Inserisce il codice per il testo colorato.

/input insert \x03

Ctrl+c, i

Inserisce il codice per il testo in corsivo.

/input insert \x1D

Ctrl+c, o

Inserisce il codice per il reset dei colori.

/input insert \x0F

Ctrl+c, v

Inserisce il codice per l’inversione dei colori.

/input insert \x16

Ctrl+c, _

Inserisce il codice per il testo sottolineato.

/input insert \x1F

Del
Ctrl+d

Elimina il carattere successivo nella riga di comando.

/input delete_next_char

Backsp.
Ctrl+h

Elimina il carattere precedente nella riga di comando.

/input delete_previous_char

Ctrl+k

Elimina dal cursore fino alla fine della riga di comando (deleted string is copied to the internal clipboard).

/input delete_end_of_line

Ctrl+r

Cerca del testo nella cronologia del buffer (consultare tasti per il contesto search).

/input search_text_here

Ctrl+t

Inverti caratteri.

/input transpose_chars

Ctrl+u

Elimina dal cursore fino all’inizio della riga di comando (deleted string is copied to the internal clipboard).

/input delete_beginning_of_line

Ctrl+w

Elimina la parola precedente nella riga di comando (deleted string is copied to the internal clipboard).

/input delete_previous_word

Ctrl+y

Paste the internal clipboard content.

/input clipboard_paste

Ctrl+_

Annulla l’ultima azione sulla riga di comando.

/input undo

Alt+_

Ripete l’ultima azione sulla riga di comando.

/input redo

Tab

Completa comando o nick (Tab di nuovo: trova prossimo completamento).

/input complete_next

Shift+Tab

Senza completamento: effettua un completamento parziale, con completamento in sospeso: completa con il completamento precedente.

/input complete_previous

Invio
Ctrl+j
Ctrl+m

Esegue comando o invia messaggio (in modalità ricerca: ferma ricerca).

/input return

Chiama comando/messaggio precedente (in modalità ricerca: cerca in alto).

/input history_previous

Chiama comando/messaggio precedente (in modalità ricerca: cerca in basso).

/input history_next

Ctrl+

Chiama il comando/messaggio precedente nella cronologia globale (identico per tutti i buffer).

/input history_global_previous

Ctrl+

Chiama il comando/messaggio successivo nella cronologia globale (identico per tutti i buffer).

/input history_global_next

Alt+d

Elimina la parola successiva nella riga di comando (deleted string is copied to the internal clipboard).

/input delete_next_word

Alt+k

Cattura un tasto ed inserisce il suo codice (e il comando associato se il tasto esiste) nella riga di comando.

/input grab_key_command

Alt+r

Elimina l’intera riga di comando.

/input delete_line

Alt+s

Abilita/disabilita aspell.

/mute aspell toggle

3.12.2. Tasti per buffer / finestre

Tasti Descrizione Comando

Ctrl+l

Ridisegna l’intera finestra.

/window refresh

Ctrl+s, ctrl-u

Imposta l’evidenziatore dei messaggi non letti su tutti i buffer.

/input set_unread

Ctrl+x

Passa al buffer attivo se i buffer sono collegati con lo stesso numero.

/input switch_active_buffer

Alt+x

Zoom on merged buffer (Alt+x again: display all merged buffers).

/input zoom_merged_buffer

PgUp

Scorre in alto di una pagina nella cronologia del buffer.

/window page_up

PgDn

Scorre di una pagina in basso nella cronologia del buffer.

/window page_down

Alt+PgUp

Scorre di qualche riga in alto nella cronologia del buffer.

/window scroll_up

Alt+PgDn

Scorre di qualche riga in basso nella cronologia del buffer.

/window scroll_down

Alt+Home

Scorre in cima al buffer.

/window scroll_top

Alt+End

Scorre alla fine del del buffer.

/window scroll_bottom

Alt+
Alt+
Ctrl+p
F5

Passa al buffer precedente.

/buffer -1

Alt+
Alt+
Ctrl+n
F6

Passa al buffer successivo.

/buffer +1

F7

Passa alla finestra precedente.

/window -1

F8

Passa alla finestra successiva.

/window +1

F9

Scorre il titolo del buffer sulla sinistra.

/bar scroll title * -30%

F10

Scorre il titolo del buffer sulla destra.

/bar scroll title * +30%

F11

Scorre di una pagina in alto nella lista nick.

/bar scroll nicklist * -100%

F12

Scorre di una pagina in basso nella lista nick.

/bar scroll nicklist * +100%

Alt+F11

Sposta all’inizio della lista nick.

/bar scroll nicklist * b

Alt+F12

Sposta alla fine della lista nick.

/bar scroll nicklist * e

Alt+a

Passa al buffer successivo con attività (con priorità: highligh, messagge, altro).

/input jump_smart

Alt+h

Pulisce hotlist (notifica di attività su altri buffer).

/input hotlist_clear

Alt+j, alt-f

Switch to first buffer.

/buffer -

Alt+j, alt-l

Passa all’ultimo buffer.

/buffer +

Alt+j, alt-r

Passa al buffer raw IRC.

/server raw

Alt+j, alt-s

Passa al buffer server IRC.

/server jump

Alt+0…​9

Passa al buffer numero (0 = 10).

/buffer *N

Alt+j, 01…​99

Passa al buffer numero.

/buffer *NN

Alt+l

Toggle bare display on/off.

/window bare

Alt+m

Abilita/disabilita.

/mouse toggle

Alt+n

Scorre fino alla notifica successiva.

/window scroll_next_highlight

Alt+p

Scorre fino alla notifica precedente.

/window scroll_previous_highlight

Alt+u

Scorre fino alla prima riga non letta nel buffer.

/window scroll_unread

Alt+w, alt-↑

Passa alla finestra in alto.

/window up

Alt+w, alt-↓

Passa alla finestra in basso.

/window down

Alt+w, alt-←

Passa alla finestra sulla sinistra.

/window left

Alt+w, alt-→

Passa alla finestrs sulla destra.

/window right

Alt+w, alt-b

Bilancia le dimensioni di tutte le finestre.

/window balance

Alt+w, alt-s

Scambia i buffer di due finestra.

/window swap

Alt+z

Ingrandimento sulla finestra attiva (Alt+z di nuovo: ripristina lo stato iniziale della finestra, prima dell’ingrandimento).

/window zoom

Alt+<

Passa al buffer precedente nella lista dei buffer visitati.

/input jump_previously_visited_buffer

Alt+>

Passa al buffer successivo nella lista dei buffer visitati.

/input jump_next_visited_buffer

Alt+/

Passa all’ultimo buffer mostrato (prima dell’ultimo passaggio ad un buffer).

/input jump_last_buffer_displayed

Alt+=

Attiva/disattiva filtri.

/filter toggle

Alt+-

Toggle filters on/off in current buffer.

/filter toggle @

3.12.3. Tasti per il contesto "search"

Questi tasti sono usati nel contesto "search" (quando viene digitato Ctrl+r per cercare del testo nel buffer).

Key Descrizione Comando

Ctrl+r

Switch search type: string (default), regular expression.

/input search_switch_regex

Alt+c

Passa alla ricerca esatta.

/input search_switch_case

Tab

Switch search in: messages (default), prefixes, prefixes + messages.

/input search_switch_where

Cerca riga precedente.

/input search_previous

Cerca riga successiva.

/input search_next

Enter
Ctrl+j
Ctrl+m

Stop search at current position.

/input search_stop_here

Ctrl+q

Stop search and scroll to bottom of buffer.

/input search_stop

3.12.4. Tasti per il contesto "cursor"

Questi tasti sono usati nel contesto "cursor" (movimento libero del cursore sullo schermo.

Tasto Zona Descrizione Comando

-

Sposta il cursore di una riga in alto.

/cursor move up

-

Sposta il cursore di una riga in basso.

/cursor move down

-

Sposta il cursore di una colonna a sinistra.

/cursor move left

-

Sposta il cursore di una colonna a destra.

/cursor move right

Alt+

-

Sposta il cursore nell’area in alto.

/cursor move area_up

Alt+

-

Sposta il cursore nell’area in basso.

/cursor move area_down

Alt+

-

Sposta il cursore nell’area a sinistra.

/cursor move area_left

Alt+

-

Sposta il cursore nell’area a destra.

/cursor move area_right

m

chat

Cita messaggio.

hsignal:chat_quote_message;/cursor stop

q

chat

Cita prefisso + messaggio.

hsignal:chat_quote_prefix_message;/cursor stop

Q

chat

Cita ora + prefisso + messaggio.

hsignal:chat_quote_time_prefix_message;/cursor stop

b

lista nick

Ban di un nick.

/window ${_window_number};/ban ${nick}

k

lista nick

Kick di un nick.

/window ${_window_number};/kick ${nick}

K

lista nick

Kick e ban di un nick.

/window ${_window_number};/kickban ${nick}

q

lista nick

Apri query con il nick.

/window ${_window_number};/query ${nick};/cursor stop

w

lista nick

Effettua un whois sul nick.

/window ${_window_number};/whois ${nick}

Enter
Ctrl+j
Ctrl+m

-

Ferma la modalità cursore.

/cursor stop

3.12.5. Tasti per il contesto "mouse"

Questi tasti sono usati nel contesto "mouse", ovvero quando si verifica un evento del mouse.

Tasto (1) Azione Zona Descrizione Comando

◾◽◽

-

chat

Passa alla finestra.

/window ${_window_number}

◾◽◽

sinistra

chat

Passa al buffer precedente.

/window ${_window_number};/buffer +1

◾◽◽

destra

chat

Passa al buffer successivo.

/window ${_window_number};/buffer +1

◾◽◽

sinistra (lungo)

chat

Switch to first buffer.

/window ${_window_number};/buffer 1

◾◽◽

destra (lungo)

chat

Passa all’ultimo buffer.

/window ${_window_number};/input jump_last_buffer

◾◽◽

-

chat (script buffer)

Select line in script buffer.

/script go ${_chat_line_y}

◽◽◾

-

chat (script buffer)

Install/remove script.

/script go ${_chat_line_y};/script installremove -q ${script_name_with_extension}

-

chat

Scorre di qualche riga in alto nella cronologia del buffer.

/window scroll_up -window ${_window_number}

-

chat

Scorre di qualche riga in basso nella cronologia del buffer.

/window scroll_down -window ${_window_number}

-

chat (script buffer)

Move 5 lines up in script buffer.

/script up 5

-

chat (script buffer)

Move 5 lines down in script buffer.

/script down 5

Ctrl+

-

chat

Scroll horizontally to the left.

/window scroll_horiz -window ${_window_number} -10%

Ctrl+

-

chat

Scroll horizontally to the right.

/window scroll_horiz -window ${_window_number} +10%

◾◽◽

su

lista nick

Scorre di una pagina in alto nella lista nick.

/bar scroll nicklist ${_window_number} -100%

◾◽◽

giù

lista nick

Scorre di una pagina in basso nella lista nick.

/bar scroll nicklist ${_window_number} +100%

◾◽◽

up (lungo)

lista nick

Sposta all’inizio della lista nick.

/bar scroll nicklist ${_window_number} b

◾◽◽

giù (lungo)

lista nick

Sposta alla fine della lista nick.

/bar scroll nicklist ${_window_number} e

◾◽◽

-

lista nick

Apre una query con un nick.

/window ${_window_number};/query ${nick}

◽◽◾

-

lista nick

Effettua un whois su un nick.

/window ${_window_number};/whois ${nick}

◾◽◽

sinistra

lista nick

Kick di un nick.

/window ${_window_number};/kick ${nick}

◾◽◽

sinistra (lungo)

lista nick

Kick e ban di un nick.

/window ${_window_number};/kickban ${nick}

◽◽◾

sinistra

lista nick

Ban di un nick.

/window ${_window_number};/ban ${nick}

◽◽◾

-

input

Cattura un evento del mouse e inserisce il codice nella riga di comando.

/input grab_mouse_area

-

ogni barra

Scorre la barra del -20%.

/bar scroll ${_bar_name} ${_window_number} -20%

-

ogni barra

Scorre la barra del +20%.

/bar scroll ${_bar_name} ${_window_number} +20%

◽◾◽

-

ovunque

Avvia la modalità cursore in questo punto.

/cursor go ${_x},${_y}

(1) "⇑" and "⇓" are wheel up and down.

3.13. Supporto del mouse

WeeChat supporta i click e le azioni del mouse. Funziona con il terminale locale, e da remoto via connessione ssh con o senza screen/tmux.

3.13.1. Abilitare il mouse

Per abilitare il mouse all’avvio:

/set weechat.look.mouse on

Per abilitarlo subito, digitare Alt+m oppure eseguire il seguente comando:

/mouse enable

È possibile disabilitarlo temporaneamente, e associare il comando ad un tasto. Ad esempio il tasto Alt+% per disabilitare il mouse per 10 secondi:

/key bind meta-% /mouse toggle 10
When mouse is enabled in WeeChat, all mouse events are caught by WeeChat, so actions such as copy/paste or clicks on URLs are not sent to the terminal.
Using Shift key causes the events to be sent directly to the terminal, as if the mouse was disabled (on some terminals like iTerm, you have to use Alt instead of Shift).
Per qualunque problema con il mouse, consultare FAQ di WeeChat.

3.13.2. Associare gli eventi del mouse a comandi

Molti eventi del mouse predefiniti sono già definiti da WeeChat (consultare tasti per il contesto "mouse").

È possibile cambiare o aggiungere combinazioni con il comando /key usando il contesto "mouse" (per la sintassi, consultare comando /key).

Il nome dell’evento consiste di un modificatore (opzionale), il nome di un pulsante/rotellina e un’azione (opzionale). Elementi diversi sono separati da "-".

Elenco di modificatori

Modificatore Descrizione

ctrl

Tasto Ctrl

alt

Tasto Alt

ctrl-alt

Tasto Ctrl + Alt

Elenco di pulsanti/rotellina:

Pulsante/rotellina Descrizione

button1

Click sul tasto sinistro

button2

Click sul tasto destro

button3

Click sul tasto centrale (spesso click sulla rotellina)

button4 …​ button9

Click sui pulsanti extra

wheelup

Rotellina (su)

wheeldown

Rotellina (giù)

Elenco di azioni (solo per i pulsanti, non la rotellina):

Azione Distanza

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

List of incomplete events (only for buttons, useful for plugins/scripts):

Event Description

event-down

Button was pressed but not released yet

event-drag

Mouse was moved with button pressed down

Esempio di eventi:

  • button1

  • ctrl-button1

  • button1-gesture-right

  • button1-event-down

  • button1-event-drag

  • alt-button2-gesture-down-long

  • wheelup

  • ctrl-alt-wheeldown

  • …​

Quando si associa un tasto nel contesto "mouse", è possibile far corrispondere più eventi usando * all’inizio o alla fine del nome, ad esempio button1-gesture-* corrisponderà ad ogni azione compiuta col tasto sinistro.
È possibile trovare il nome di un evento con il comando /input grab_mouse poi eseguire l’evento col mouse. Il comando inserisce il nome dell’evento nella riga di comando.

3.14. Secured data

3.14.1. Storage

WeeChat can encrypt passwords or private data using secured data, stored in file sec.conf.

This configuration file is read before any other file, and the values stored inside can be used in various WeeChat or plugins/scripts options.

You can set a passphrase to encrypt data in sec.conf. This is not mandatory but highly recommended, otherwise data is stored as plain text in file.

/secure passphrase this is my passphrase

When a passphrase is set, WeeChat will ask you to enter it on startup (but not on /upgrade).

You can change this behavior and use a file with the passphrase (see option sec.crypt.passphrase_file).

Encryption

The encryption of data is made in 3 steps:

  1. Derive a key from the passphrase (with optional salt).

  2. Compute hash of data to encrypt.

  3. Encrypt the hash + data (output is: salt + encrypted hash/data).

The cipher block mode is CFB.

The result is put as hexadecimal string in file sec.conf, for example:

[data]
__passphrase__ = on
freenode = "53B1C86FCDA28FC122A95B0456ABD79B5AB74654F21C3D099A6CCA8173239EEA59533A1D83011251F96778AC3F5166A394"
Decryption

The decryption of data is made in 3 steps:

  1. Derive a key using salt and passphrase.

  2. Decrypt hash + data.

  3. Check that decrypted hash == hash of data.

3.14.2. Manage secured data

To add secured data, use /secure set, for example a password for freenode IRC server:

/secure set freenode mypassword

For comfort, secured data can be displayed in a dedicated buffer (Alt+v on buffer to see values), just do:

/secure

Secured data can be used in some options that can contain private data like password, using this format: "${sec.data.xxx}" where "xxx" is the name of secured data (used with /secure set xxx …​).
For a complete list of supported options, see /help secure.

To use the freenode password, for example with SASL authentication:

/set irc.server.freenode.sasl_password "${sec.data.freenode}"

3.15. Options and commands

3.15.1. Secured data options (sec.conf)

Sections:

Section Control command Description

crypt

/set sec.crypt.*

Options for encryption.

data

/secure

Secured data.

Options:

  • sec.crypt.cipher

    • descrizione: cipher used to crypt data (the number after algorithm is the size of the key in bits)

    • tipo: intero

    • valori: aes128, aes192, aes256

    • valore predefinito: aes256

  • sec.crypt.hash_algo

    • descrizione: hash algorithm used to check the decrypted data

    • tipo: intero

    • valori: sha224, sha256, sha384, sha512

    • valore predefinito: sha256

  • sec.crypt.passphrase_file

    • descrizione: path to a file containing the passphrase to encrypt/decrypt secured data; this option is used only when reading file sec.conf; only first line of file is used; this file is used only if the environment variable "WEECHAT_PASSPHRASE" is not set (the environment variable has higher priority); security note: it is recommended to keep this file readable only by you and store it outside WeeChat home (for example in your home); example: "~/.weechat-passphrase"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • sec.crypt.salt

    • descrizione: use salt when generating key used in encryption (recommended for maximum security); when enabled, the content of crypted data in file sec.conf will be different on each write of the file; if you put the file sec.conf in a version control system, then you can turn off this option to have always same content in file

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

3.15.2. Opzioni di WeeChat (weechat.conf)

Sections:

Section Control command Description

debug

/debug set
/set weechat.debug.*

Debug level, for core and plugins (options can be added/removed in section).

startup

/set weechat.startup.*

Startup options.

look

/set weechat.look.*

Look and feel.

palette

/color alias
/set weechat.palette.*

Color aliases (options can be added/removed in section).

color

/set weechat.color.*

Colors.

completion

/set weechat.completion.*

Completion options.

history

/set weechat.history.*

History options (commands and buffers).

proxy

/proxy
/set weechat.proxy.*

Proxy options.

network

/set weechat.network.*

Network/SSL options.

bar

/bar
/set weechat.bar.*

Bar options.

layout

/layout

Layouts.

notify

/buffer notify

Notify levels for buffers (options can be added/removed in section).

filter

/filter

Filters.

key

/key

Keys in default context.

key_search

/key

Keys in search context.

key_cursor

/key

Keys in cursor context.

key_mouse

/key

Keys in mouse context.

Options:

  • weechat.color.bar_more

    • descrizione: text color for "+" when scrolling bars

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • weechat.color.chat

    • descrizione: colore del testo per la chat

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_bg

    • descrizione: colore di sfondo per la chat

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_buffer

    • descrizione: colore del testo per i nomi dei buffer

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • weechat.color.chat_channel

    • descrizione: colore del testo per i nomi dei canali

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • weechat.color.chat_day_change

    • descrizione: colore del testo per i messaggi mostrati al cambio di data

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • weechat.color.chat_delimiters

    • descrizione: colore del testo per i delimitatori

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.chat_highlight

    • descrizione: colore del testo per il prefisso di notifica

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.chat_highlight_bg

    • descrizione: colore di sfondo per il prefisso di notifica

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: magenta

  • weechat.color.chat_host

    • descrizione: colore del testo per i nomi host

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • weechat.color.chat_inactive_buffer

    • descrizione: colore del testo per la chat quando la riga è inattiva (il buffer è unito con altri buffer e non è selezionato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_inactive_window

    • descrizione: colore del testo per la chat quando la finestra è inattiva (nessuna finestra attiva selezionata)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_nick

    • descrizione: text color for nicks in chat window: used in some server messages and as fallback when a nick color is not found; most of times nick color comes from option weechat.color.chat_nick_colors

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightcyan

  • weechat.color.chat_nick_colors

    • descrizione: colore del testo per i nick (elenco separato da virgole di colori, quello di sfondo è consentito con il formato "fg:bg", ad esempio: "lightred:blue")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "cyan,magenta,green,brown,lightblue,default,lightcyan,lightmagenta,lightgreen,blue"

  • weechat.color.chat_nick_offline

    • descrizione: text color for offline nick (not in nicklist any more); this color is used only if option weechat.look.color_nick_offline is enabled

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_nick_offline_highlight

    • descrizione: text color for offline nick with highlight; this color is used only if option weechat.look.color_nick_offline is enabled

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_nick_offline_highlight_bg

    • descrizione: background color for offline nick with highlight; this color is used only if option weechat.look.color_nick_offline is enabled

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: blue

  • weechat.color.chat_nick_other

    • descrizione: colore del testo per gli altri nick nel buffer privato

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • weechat.color.chat_nick_prefix

    • descrizione: colore per il prefisso del nick (stringa visualizzata prima del nick nel prefisso)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.chat_nick_self

    • descrizione: colore del testo per il nick locale nella finestra di chat

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • weechat.color.chat_nick_suffix

    • descrizione: colore per il prefisso del nick (stringa visualizzata dopo il nick nel prefisso)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.chat_prefix_action

    • descrizione: colore del testo per il prefisso di azione

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • weechat.color.chat_prefix_buffer

    • descrizione: colore del testo per il nome del buffer (prima del prefisso, quando più buffer sono uniti con lo stesso nome)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: brown

  • weechat.color.chat_prefix_buffer_inactive_buffer

    • descrizione: colore del testo per il nome del buffer inattivo (prima del prefisso, quando più buffer sono uniti con lo stesso numero e il buffer non è selezionato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_prefix_error

    • descrizione: colore del testo per il prefisso di errore

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.chat_prefix_join

    • descrizione: colore del testo per il prefisso di entrata

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • weechat.color.chat_prefix_more

    • descrizione: text color for "+" when prefix is too long

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • weechat.color.chat_prefix_network

    • descrizione: colore del testo per il prefisso di rete

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: magenta

  • weechat.color.chat_prefix_quit

    • descrizione: colore del testo per il prefisso di uscita

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • weechat.color.chat_prefix_suffix

    • descrizione: colore del testo per il suffisso (dopo il prefisso)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.chat_read_marker

    • descrizione: colore del testo per l'evidenziatore di dati non letti

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: magenta

  • weechat.color.chat_read_marker_bg

    • descrizione: colore di sfondo per l'evidenziatore di dati non letti

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_server

    • descrizione: colore del testo per i nomi dei server

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: brown

  • weechat.color.chat_tags

    • descrizione: colore del testo per i tago dopo i messaggi (mostrati con il comando /debug tags)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: red

  • weechat.color.chat_text_found

    • descrizione: colore del testo per l'evidenziatore sulle righe per il testo trovato

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.chat_text_found_bg

    • descrizione: colore di sfondo per l'evidenziatore sulle righe per il testo trovato

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • weechat.color.chat_time

    • descrizione: colore del testo per l'orario nella finestra di chat

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.chat_time_delimiters

    • descrizione: colore del testo per i delimitator dell'orario

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: brown

  • weechat.color.chat_value

    • descrizione: colore del testo per i valori

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • weechat.color.chat_value_null

    • descrizione: text color for null values (undefined)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: blue

  • weechat.color.emphasized

    • descrizione: text color for emphasized text (for example when searching text); this option is used only if option weechat.look.emphasized_attributes is an empty string (default value)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.emphasized_bg

    • descrizione: background color for emphasized text (for example when searching text); used only if option weechat.look.emphasized_attributes is an empty string (default value)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: magenta

  • weechat.color.input_actions

    • descrizione: colore del testo per le azioni sulla riga di input

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • weechat.color.input_text_not_found

    • descrizione: colore del testo per la ricerca del testo fallita nella riga di input

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: red

  • weechat.color.item_away

    • descrizione: text color for away item

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.nicklist_away

    • descrizione: colore del testo per i nick assenti

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • weechat.color.nicklist_group

    • descrizione: colore del testo per i gruppi nella lista nick

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.separator

    • descrizione: colore per i separatori delle finestre (quando divise) e dei separatori tra le barre (come la lista nick)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: blue

  • weechat.color.status_count_highlight

    • descrizione: colore del testo per il conteggio dei messaggi di notifica nella hotlist (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: magenta

  • weechat.color.status_count_msg

    • descrizione: colore del testo per il conteggio dei messaggi nella hotlist (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: brown

  • weechat.color.status_count_other

    • descrizione: colore del testo per il conteggio di altri messaggi nella hotlist (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.status_count_private

    • descrizione: colore del testo per il conteggio dei messaggi privati nella hotlist (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.status_data_highlight

    • descrizione: colore del testo per il buffer con notifica (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • weechat.color.status_data_msg

    • descrizione: colore del testo per il buffer con nuovi messaggi (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.status_data_other

    • descrizione: colore del testo per il buffer con nuovi dati (non messaggi) (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.status_data_private

    • descrizione: colore del testo per il buffer con un messaggio privato (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • weechat.color.status_filter

    • descrizione: colore del testo per l'indicatore di filtro nella barra di stato

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.status_more

    • descrizione: colore del testo per il buffer con nuovi dati (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.status_mouse

    • descrizione: text color for mouse indicator in status bar

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • weechat.color.status_name

    • descrizione: colore del testo per il nome del buffer corrente nella barra di stato

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • weechat.color.status_name_ssl

    • descrizione: colore del testo per il nome del buffer corrente nella barra di stato, se i dati sono messi al sicuro con un protocollo come SSL

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • weechat.color.status_nicklist_count

    • descrizione: text color for number of nicks in nicklist (status bar)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.color.status_number

    • descrizione: colore del testo per il numero del buffer corrente nella barra di stato

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • weechat.color.status_time

    • descrizione: colore del testo per l'ora (barra di stato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • weechat.completion.base_word_until_cursor

    • descrizione: se abilitata, la parola base da completare termina al carattere prima del cursore; altrimenti la parola base termina al primo spazio dopo il cursore

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.completion.command_inline

    • descrizione: if enabled, the commands inside command line are completed (the command at beginning of line has higher priority and is used first); note: when this option is enabled, there is no more automatic completion of paths beginning with "/" (outside commands arguments)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.completion.default_template

    • descrizione: modello di completamento predefinito (per favore, consulta la documentazione per codici e valori del template: Referenze API per Plugin, funzione "weechat_hook_command")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%(nicks)|%(irc_channels)"

  • weechat.completion.nick_add_space

    • descrizione: aggiungi uno spazio al completamento del nick (quando non è la prima parola sulla riga di comando)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.completion.nick_completer

    • descrizione: stringa inserita dopo il completamento del nick (quando il nick è la prima parola sulla riga di comando)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ":"

  • weechat.completion.nick_first_only

    • descrizione: completa solo con il primo nick trovato

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.completion.nick_ignore_chars

    • descrizione: caratteri ignorati per il completamento dei nick

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "[]`_-^"

  • weechat.completion.partial_completion_alert

    • descrizione: avvisa l'utente quando si verifica un completamento parziale

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.completion.partial_completion_command

    • descrizione: completa parzialmente i nomi dei comandi (arresta quando vengono trovati più comandi con le stesse lettere)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.completion.partial_completion_command_arg

    • descrizione: completa parzialmente gli argomenti dei comandi (arresta quando vengono trovati più argomenti con lo stesso prefisso)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.completion.partial_completion_count

    • descrizione: mostra contatore per ogni completamento parziale nella barra degli oggetti

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.completion.partial_completion_other

    • descrizione: completa parzialmente comandi esterni (arresta quando vengono trovate più parole che iniziano con le stesse lettere)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.history.display_default

    • descrizione: numero massimo predefinito di comandi da visualizzare nella cronologia (0 = nessun limite)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 5

  • weechat.history.max_buffer_lines_minutes

    • descrizione: maximum number of minutes in history per buffer (0 = unlimited); examples: 1440 = one day, 10080 = one week, 43200 = one month, 525600 = one year; use 0 ONLY if option weechat.history.max_buffer_lines_number is NOT set to 0

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 0

  • weechat.history.max_buffer_lines_number

    • descrizione: maximum number of lines in history per buffer (0 = unlimited); use 0 ONLY if option weechat.history.max_buffer_lines_minutes is NOT set to 0

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 4096

  • weechat.history.max_commands

    • descrizione: maximum number of user commands in history (0 = unlimited, NOT RECOMMENDED: no limit in memory usage)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 100

  • weechat.history.max_visited_buffers

    • descrizione: numero massimo di buffer visitati da memorizzare

    • tipo: intero

    • valori: 0 .. 1000

    • valore predefinito: 50

  • weechat.look.align_end_of_lines

    • descrizione: allineamento per la fine delle righe (tutte le righe tranne la prima): iniziano al di sotto di questi dati (data, buffer, prefissio, suffisso, messaggio (predefinito))

    • tipo: intero

    • valori: time, buffer, prefix, suffix, message

    • valore predefinito: message

  • weechat.look.align_multiline_words

    • descrizione: alignment for multiline words according to option weechat.look.align_end_of_lines; if disabled, the multiline words will not be aligned, which can be useful to not break long URLs

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.bar_more_down

    • descrizione: stringa visualizzata quando si può effettuare lo scroll della barra il basso (per le barre che hanno il riempimento "horizontal")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "+"+

  • weechat.look.bar_more_left

    • descrizione: stringa visualizzata quando si può effettuare lo scroll della barra verso sinistra (per le barre che hanno il riempimento "horizontal")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "<<"

  • weechat.look.bar_more_right

    • descrizione: stringa visualizzata quando si può effettuare lo scroll della barra verso destra (per le barre che hanno il riempimento "horizontal")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ">>"

  • weechat.look.bar_more_up

    • descrizione: stringa visualizzata quando si può effettuare lo scroll della barra verso l'alto (per le barre che hanno il riempimento "horizontal")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "--"

  • weechat.look.bare_display_exit_on_input

    • descrizione: exit the bare display mode on any changes in input

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.bare_display_time_format

    • descrizione: time format in bare display mode (see man strftime for date/time specifiers)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%H:%M"

  • weechat.look.buffer_auto_renumber

    • descrizione: automatically renumber buffers to have only consecutive numbers and start with number 1; if disabled, gaps between buffer numbers are allowed and the first buffer can have a number greater than 1

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.buffer_notify_default

    • descrizione: livello predefinito di notifica per i buffer (usato per comunicare a WeeChat se il buffer deve essere visualizzato nella hotlist oppure no, a seconda dell'importanza del messaggio): all: tutti i messaggi (predefinito), message=messaggi+notifiche, highlight=solo notifiche, none=non viene mai visualizzato nella hotlist

    • tipo: intero

    • valori: none, highlight, message, all

    • valore predefinito: all

  • weechat.look.buffer_position

    • descrizione: position of a new buffer: end = after the end of list (number = last number + 1) (default), first_gap = at first available number in the list (after the end of list if no number is available); this option is used only if the buffer has no layout number

    • tipo: intero

    • valori: end, first_gap

    • valore predefinito: end

  • weechat.look.buffer_search_case_sensitive

    • descrizione: default text search in buffer: case sensitive or not

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.buffer_search_force_default

    • descrizione: force default values for text search in buffer (instead of using values from last search in buffer)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.buffer_search_regex

    • descrizione: default text search in buffer: if enabled, search POSIX extended regular expression, otherwise search simple string

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.buffer_search_where

    • descrizione: default text search in buffer: in message, prefix, prefix and message

    • tipo: intero

    • valori: prefix, message, prefix_message

    • valore predefinito: prefix_message

  • weechat.look.buffer_time_format

    • descrizione: time format for each line displayed in buffers (see man strftime for date/time specifiers) (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval); for example time using grayscale (requires support of 256 colors): "${color:252}%H${color:245}%M${color:240}%S"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%H:%M:%S"

  • weechat.look.color_basic_force_bold

    • descrizione: forza l'attributo "bold" per i colori chiari e "darkgray" nei colori di base (questa opzione è disabilitata per default: il grassetto è usato solo se il terminale ha meno di 16 colori)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.color_inactive_buffer

    • descrizione: usa un colore diverso per le righe nel buffer inattivo (quando la riga viene da un buffer unito non selezionato)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.color_inactive_message

    • descrizione: usa un colore diverso per un messaggio inattivo (quando la finestra non è quella corrente, o se la riga viene da un buffer unito non selezionato)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.color_inactive_prefix

    • descrizione: usa un colore diverso per il prefisso inattivo (quando la finestra non è quella corrente, o se la riga viene da un buffer unito non selezionato)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.color_inactive_prefix_buffer

    • descrizione: usa un colore diverso per il nome del buffer inattivo nel prefisso (quando la finestra non è quella corrente, o se la riga viene da un buffer unito non selezionato)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.color_inactive_time

    • descrizione: usa un colore diverso per il tempo di inattività (quando la finestra non è quella corrente, o se la riga viene da un buffer unito non selezionato)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.color_inactive_window

    • descrizione: usa un colore diverso per le righe nella finestra inattiva (quando la finestra non è quella corrente)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.color_nick_offline

    • descrizione: usa un colore diverso per i nick non in linea (non più in lista nick)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.color_pairs_auto_reset

    • descrizione: ripristina automaticamente la tabella delle coppie colore quando il numero di coppie disponibili è minore o uguale a questo numero (-1 = disabilita il ripristino automatico, dunque è necessario "/color reset" quando la tabella è al completo)

    • tipo: intero

    • valori: -1 .. 256

    • valore predefinito: 5

  • weechat.look.color_real_white

    • descrizione: se impostato, usa il colore bianco reale, disabilitato sui terminali con lo sfondo bianco (se non usato, l'opzione dovrebbe essere attivata per visualizzare il bianco reale invece del colore di primo piano predefinito del terminale)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.command_chars

    • descrizione: caratteri usati per determinare se la stringa in input è un comando oppure no: l'input deve iniziare con uno di questi caratteri: la barra ("/") è sempre considerata come prefisso per comando (esempio: ".$")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.command_incomplete

    • descrizione: if set, incomplete and unambiguous commands are allowed, for example /he for /help

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.confirm_quit

    • descrizione: se impostata, il comando /quit deve essere confermato con l'argomento extra "-yes" (consultare /help quit)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.confirm_upgrade

    • descrizione: if set, /upgrade command must be confirmed with extra argument "-yes" (see /help upgrade)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.day_change

    • descrizione: mostra un messaggio speciale al cambio di data

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.day_change_message_1date

    • descrizione: message displayed when the day has changed, with one date displayed (for example at beginning of buffer) (see man strftime for date/time specifiers) (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "-- %a, %d %b %Y --"

  • weechat.look.day_change_message_2dates

    • descrizione: message displayed when the day has changed, with two dates displayed (between two messages); the second date specifiers must start with two "%" because strftime is called two times on this string (see man strftime for date/time specifiers) (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "-- %%a, %%d %%b %%Y (%a, %d %b %Y) --"

  • weechat.look.eat_newline_glitch

    • descrizione: se attivo, eat_newline_glitch verrà impostato a 0; viene usato per non aggiungere il carattere a capo alla fine di ogni riga, al fine di non danneggiare il testo quando viene copiato/incollato da WeeChat in un'altra applicazione (l'opzione è disabilitata per default, dato che può causare seri errori di visualizzazione)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.emphasized_attributes

    • descrizione: attributes for emphasized text: one or more attribute chars ("*" for bold, "!" for reverse, "/" for italic, "_" for underline); if the string is empty, the colors weechat.color.emphasized* are used

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.highlight

    • descrizione: elenco separato da virgole di parole da notificare; confronto non sensibile alle maiuscole (usare "(?-i)" all'inizio delle parole per renderle sensibili alle maiuscole), le parole possono iniziare o terminare con "*" per la corrispondenza parziale; ad esempio: "test,(?-i)*tizio*,flash*"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.highlight_regex

    • descrizione: POSIX extended regular expression used to check if a message has highlight or not, at least one match in string must be surrounded by delimiters (chars different from: alphanumeric, "-", "_" and "|"), regular expression is case insensitive (use "(?-i)" at beginning to make it case sensitive), examples: "flashcode|flashy", "(?-i)FlashCode|flashy"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.highlight_tags

    • descrizione: comma separated list of tags to highlight; case insensitive comparison; wildcard "*" is allowed in each tag; many tags can be separated by "+" to make a logical "and" between tags; examples: "nick_flashcode" for messages from nick "FlashCode", "irc_notice+nick_toto*" for notices from a nick starting with "toto"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.hotlist_add_conditions

    • descrizione: conditions to add a buffer in hotlist (if notify level is OK for the buffer); you can use in these conditions: "window" (current window pointer), "buffer" (buffer pointer to add in hotlist), "priority" (0 = low, 1 = message, 2 = private, 3 = highlight); by default a buffer is added to hotlist if you are away, or if the buffer is not visible on screen (not displayed in any window)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "${away} || ${buffer.num_displayed} == 0"

  • weechat.look.hotlist_buffer_separator

    • descrizione: stringa mostrata tra i buffer nella hotlist

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ", "

  • weechat.look.hotlist_count_max

    • descrizione: numero massimo del conteggio di messaggi da mostrare nella hotlist per un buffer (0 = non mostrare mai il contatore messaggi)

    • tipo: intero

    • valori: 0 .. 4

    • valore predefinito: 2

  • weechat.look.hotlist_count_min_msg

    • descrizione: mostra il conteggio dei messaggi se il numero di messaggi è maggiore o uguale a questo valore

    • tipo: intero

    • valori: 1 .. 100

    • valore predefinito: 2

  • weechat.look.hotlist_names_count

    • descrizione: numero massimo di nomi nella hotlist (0 = nessun nome visualizzato, solo numeri dei buffer)

    • tipo: intero

    • valori: 0 .. 10000

    • valore predefinito: 3

  • weechat.look.hotlist_names_length

    • descrizione: lunghezza massima dei nomi nella hotlist (0 = nessun limite)

    • tipo: intero

    • valori: 0 .. 32

    • valore predefinito: 0

  • weechat.look.hotlist_names_level

    • descrizione: livello per la visualizzazione dei nomi nella hotlist (combinazione di: 1=entrata/uscita, 2=messaggio, 4=privato, 8=notifica, per esempio: 12=privato+notifica)

    • tipo: intero

    • valori: 1 .. 15

    • valore predefinito: 12

  • weechat.look.hotlist_names_merged_buffers

    • descrizione: se impostato, forza la visualizzazione dei nomi nella hotlist per i buffer uniti

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.hotlist_prefix

    • descrizione: testo mostrato in cima alla hotlist

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "H: "

  • weechat.look.hotlist_remove

    • descrizione: remove buffers in hotlist: buffer = remove buffer by buffer, merged = remove all visible merged buffers at once

    • tipo: intero

    • valori: buffer, merged

    • valore predefinito: merged

  • weechat.look.hotlist_short_names

    • descrizione: if set, uses short names to display buffer names in hotlist (start after first "." in name)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.hotlist_sort

    • descrizione: sort of hotlist: group_time_*: group by notify level (highlights first) then sort by time, group_number_*: group by notify level (highlights first) then sort by number, number_*: sort by number; asc = ascending sort, desc = descending sort

    • tipo: intero

    • valori: group_time_asc, group_time_desc, group_number_asc, group_number_desc, number_asc, number_desc

    • valore predefinito: group_time_asc

  • weechat.look.hotlist_suffix

    • descrizione: testo mostrato in fondo alla hotlist

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.hotlist_unique_numbers

    • descrizione: mantiene solo numeri univoci nella hotlist (vale solo per gli elementi della hotlist per cui il nome NON viene visualizzato dopo il numero)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.input_cursor_scroll

    • descrizione: numero di caratteri mostrati dopo la fine della riga di input quando si scorre per mostrare la fine riga

    • tipo: intero

    • valori: 0 .. 100

    • valore predefinito: 20

  • weechat.look.input_share

    • descrizione: condivide comandi, testo o entrambi nell'input per tutti i buffer (resta tuttavia la cronologia locale per ogni buffer)

    • tipo: intero

    • valori: none, commands, text, all

    • valore predefinito: none

  • weechat.look.input_share_overwrite

    • descrizione: se impostato e con l'input condiviso, sovrascrive sempre l'input nel buffer di destinazione

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.input_undo_max

    • descrizione: numero massimo di righe nella cronologia per buffer (0 = nessun limite)

    • tipo: intero

    • valori: 0 .. 65535

    • valore predefinito: 32

  • weechat.look.item_away_message

    • descrizione: mostra il messaggio di assenza del server nell'elemento barra di away

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.item_buffer_filter

    • descrizione: stringa usata per mostrare che alcune righe sono state filtrate nel buffer corrente (elemento barra "buffer_filter")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "*"

  • weechat.look.item_buffer_zoom

    • descrizione: string used to show zoom on merged buffer (bar item "buffer_zoom")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "!"

  • weechat.look.item_mouse_status

    • descrizione: string used to show if mouse is enabled (bar item "mouse_status")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "M"

  • weechat.look.item_time_format

    • descrizione: time format for "time" bar item (see man strftime for date/time specifiers) (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%H:%M"

  • weechat.look.jump_current_to_previous_buffer

    • descrizione: passa al buffer visualizzato in precedenza al passaggio del numero di buffer corrente con /buffer *N (dove N è un numero di buffer), per passare facilmente ad un altro buffer, e poi tornare a quello attuale

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.jump_previous_buffer_when_closing

    • descrizione: passa al buffer visitato in precedenza alla chiusura di un buffer (se disabilitato, allora passa al buffer numero -1)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.jump_smart_back_to_buffer

    • descrizione: torna al buffer iniziale dopo aver raggiunto la fine della hotlist

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.key_bind_safe

    • descrizione: consente solo l'associazione di tasti "sicuri" (che iniziano con ctrl o alt)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.key_grab_delay

    • descrizione: default delay (in milliseconds) to grab a key (using default key alt-k); this delay can be overridden in the /input command (see /help input)

    • tipo: intero

    • valori: 1 .. 10000

    • valore predefinito: 800

  • weechat.look.mouse

    • descrizione: abilita il supporto del mouse

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.mouse_timer_delay

    • descrizione: ritardo (in millisecondi) per catturare un evento del mouse: WeeChat attende questo ritardo prima di analizzare l'evento

    • tipo: intero

    • valori: 1 .. 10000

    • valore predefinito: 100

  • weechat.look.nick_color_force

    • descrizione: force color for some nicks: hash computed with nickname to find color will not be used for these nicks (format is: "nick1:color1;nick2:color2"); look up for nicks is with exact case then lower case, so it's possible to use only lower case for nicks in this option

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.nick_color_hash

    • descrizione: hash algorithm used to find the color for a nick: djb2 = variant of djb2 (position of letters matters: anagrams of a nick have different color), sum = sum of letters

    • tipo: intero

    • valori: djb2, sum

    • valore predefinito: djb2

  • weechat.look.nick_color_stop_chars

    • descrizione: caratteri usati per interrompere il calcolo del colore con le lettere del nick (almeno un carattere al di fuori di questa lista deve essere nella lista prima di interromperlo) (esempio: nick "|nick|away" con "|" nei caratteri restituisce il colore del nick "|nick")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "_|["

  • weechat.look.nick_prefix

    • descrizione: testo da visualizzare prima del nick nel prefisso del messaggio, esempio: "<"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.nick_suffix

    • descrizione: testo da visualizzare dopo il nick nel prefisso del messaggio, esempio: ">"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.paste_auto_add_newline

    • descrizione: automatically add a newline at the end of pasted text if there are at least two lines and if a confirmation is asked

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.paste_bracketed

    • descrizione: abilita la modalità "bracketed paste" per il terminale (non supportata da tutti i terminali/multiplexer): in questa modalità, il testo incollato viene racchiuso da sequenze di controllo in modo che WeeChat possa differenziare il testo incollato dal testo digitato ("ESC[200~", seguito dal testo incollato, seguito da "ESC[201~")

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.paste_bracketed_timer_delay

    • descrizione: forza la fine della modalità "bracketed paste" dopo questo ritardo (in secondi) se la sequenza di controllo per la fine del "bracketed paste" ("ESC[201~") non è stata ricevuta in tempo

    • tipo: intero

    • valori: 1 .. 60

    • valore predefinito: 10

  • weechat.look.paste_max_lines

    • descrizione: numero massimo di righe da incollare senza conferma dell'utente (-1 = disabilita questa caratteristica)

    • tipo: intero

    • valori: -1 .. 2147483647

    • valore predefinito: 1

  • weechat.look.prefix_action

    • descrizione: prefix for action messages (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: " *"

  • weechat.look.prefix_align

    • descrizione: allineamento prefisso (none, left, right (predefinito))

    • tipo: intero

    • valori: none, left, right

    • valore predefinito: right

  • weechat.look.prefix_align_max

    • descrizione: dimensione massima prefisso (0 = nessuna dimensione massima)

    • tipo: intero

    • valori: 0 .. 128

    • valore predefinito: 0

  • weechat.look.prefix_align_min

    • descrizione: dimensione minima per il prefisso

    • tipo: intero

    • valori: 0 .. 128

    • valore predefinito: 0

  • weechat.look.prefix_align_more

    • descrizione: carattere da mostrare se il prefisso è troncato (deve essere esattamente un carattere sullo schermo)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""+

  • weechat.look.prefix_align_more_after

    • descrizione: display the truncature char (by default "+") after the text (by replacing the space that should be displayed here); if disabled, the truncature char replaces last char of text

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.prefix_buffer_align

    • descrizione: prefisso di allineamento per il nome del buffer, quando più buffer vengono uniti con lo stesso numero (none (nessuno), left(sinistra), right(destra - predefinito)

    • tipo: intero

    • valori: none, left, right

    • valore predefinito: right

  • weechat.look.prefix_buffer_align_max

    • descrizione: allineamento del prefisso per nome buffer, quando più buffer sono uniti con lo stesso numero (0 = nessuna dimensione massima)

    • tipo: intero

    • valori: 0 .. 128

    • valore predefinito: 0

  • weechat.look.prefix_buffer_align_more

    • descrizione: carattere da mostrare se il nome del buffer è troncato (quando più buffer vengono uniti con lo stesso numero) (deve essere esattamente un carattere su schermo)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""+

  • weechat.look.prefix_buffer_align_more_after

    • descrizione: display the truncature char (by default "+") after the text (by replacing the space that should be displayed here); if disabled, the truncature char replaces last char of text

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.prefix_error

    • descrizione: prefisso per i messaggi di errore (nota: il contenuto viene valutato, per cui è possibile usare colori con il formato "${color:xxx}", consultare /help eval

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "=!="

  • weechat.look.prefix_join

    • descrizione: prefix for join messages (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "-->"

  • weechat.look.prefix_network

    • descrizione: prefix for network messages (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "--"

  • weechat.look.prefix_quit

    • descrizione: prefix for quit messages (note: content is evaluated, so you can use colors with format "${color:xxx}", see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "<--"

  • weechat.look.prefix_same_nick

    • descrizione: prefisso mostrato per un messaggio con lo stesso nick del messaggio precedente: usare uno spazio " " per nascondere il prefisso, un'altra stringa per mostrare la stringa invece del prefisso, o una stringa vuota per disabilitare questa funzionalità (mostra prefisso)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.prefix_suffix

    • descrizione: stringa visualizzata dopo il prefisso

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "|"

  • weechat.look.quote_nick_prefix

    • descrizione: text to display before nick when quoting a message (see /help cursor)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "<"

  • weechat.look.quote_nick_suffix

    • descrizione: text to display after nick when quoting a message (see /help cursor)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ">"

  • weechat.look.quote_time_format

    • descrizione: time format when quoting a message (see /help cursor)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%H:%M:%S"

  • weechat.look.read_marker

    • descrizione: usa segnalibro (riga o carattere) sui buffer per mostrare la prima riga non letta

    • tipo: intero

    • valori: none, line, char

    • valore predefinito: line

  • weechat.look.read_marker_always_show

    • descrizione: mostra sempre il segnalibro, anche se si trova dopo l'ultima riga del buffer

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.read_marker_string

    • descrizione: stringa usata per tracciare il segnalibro (la stringa viene ripetuta fino a fine riga)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "- "

  • weechat.look.save_config_on_exit

    • descrizione: salva file di configurazione all'uscita

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.save_layout_on_exit

    • descrizione: save layout on exit (buffers, windows, or both)

    • tipo: intero

    • valori: none, buffers, windows, all

    • valore predefinito: none

  • weechat.look.scroll_amount

    • descrizione: le righe da scorrere con scroll_up e scroll_down

    • tipo: intero

    • valori: 1 .. 2147483647

    • valore predefinito: 3

  • weechat.look.scroll_bottom_after_switch

    • descrizione: scorri verso il fondo della finestra dopo essere passati ad un altro buffer non ricordare la posizione di scorrimento nelle finestre); lo scorrimento viene eseguito solo per i buffer con contenuto formattato (contenuto non libero)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.scroll_page_percent

    • descrizione: percentuale della schermata da scorrere in alto o in basso (per esempio 100 indica una pagina intera, 50 metà)

    • tipo: intero

    • valori: 1 .. 100

    • valore predefinito: 100

  • weechat.look.search_text_not_found_alert

    • descrizione: avvisa l'utente quando il testo cercato non viene trovato nel buffer

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.separator_horizontal

    • descrizione: char used to draw horizontal separators around bars and windows (empty value will draw a real line with ncurses, but may cause bugs with URL selection under some terminals); width on screen must be exactly one char

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "-"

  • weechat.look.separator_vertical

    • descrizione: char used to draw vertical separators around bars and windows (empty value will draw a real line with ncurses); width on screen must be exactly one char

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.look.tab_width

    • descrizione: number of spaces used to display tabs in messages

    • tipo: intero

    • valori: 1 .. 64

    • valore predefinito: 1

  • weechat.look.time_format

    • descrizione: formato dell'ora per le date convertite in stringhe e mostrate nei messaggi(consultare man strftime per i dettagli su data/ora)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%a, %d %b %Y %T"

  • weechat.look.window_auto_zoom

    • descrizione: automatically zoom on current window if the terminal becomes too small to display all windows (use alt-z to unzoom windows when the terminal is big enough)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.look.window_separator_horizontal

    • descrizione: mostra un separatore orizzontale tra le finestre

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.window_separator_vertical

    • descrizione: mostra un separatore verticale tra le finestre

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.look.window_title

    • descrizione: title for window (terminal for Curses GUI), set on startup; an empty string will keep title unchanged (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "WeeChat ${info:version}"

  • weechat.look.word_chars_highlight

    • descrizione: comma-separated list of chars (or range of chars) that are considered part or words for highlights; each item can be a single char, a range of chars (format: a-z), a class of wide character (for example "alnum", see man wctype); a "!" before the item makes it negative (ie the char is NOT considered part of words); the value "*" matches any char; unicode chars are allowed with the format \u1234, for example \u00A0 for unbreakable space (see /help print for supported formats)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "!\u00A0,-,_,|,alnum"

  • weechat.look.word_chars_input

    • descrizione: comma-separated list of chars (or range of chars) that are considered part or words for command line; each item can be a single char, a range of chars (format: a-z), a class of wide character (for example "alnum", see man wctype); a "!" before the item makes it negative (ie the char is NOT considered part of words); the value "*" matches any char; unicode chars are allowed with the format \u1234, for example \u00A0 for unbreakable space (see /help print for supported formats)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "!\u00A0,-,_,|,alnum"

  • weechat.network.connection_timeout

    • descrizione: timeout (in secondi) per la connessione ad un host remoto (eseguita in un processo figlio)

    • tipo: intero

    • valori: 1 .. 2147483647

    • valore predefinito: 60

  • weechat.network.gnutls_ca_file

    • descrizione: file contenente le autorità certificative ("%h" sarà sostituito dalla home di WeeChat, predefinita: "~/.weechat)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "/etc/ssl/certs/ca-certificates.crt"

  • weechat.network.gnutls_handshake_timeout

    • descrizione: timeout (in secondi) per l'handshake di gnutls

    • tipo: intero

    • valori: 1 .. 2147483647

    • valore predefinito: 30

  • weechat.network.proxy_curl

    • descrizione: name of proxy used for download of URLs with Curl (used to download list of scripts and in scripts calling function hook_process); the proxy must be defined with command /proxy

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.plugin.autoload

    • descrizione: comma separated list of plugins to load automatically at startup, "*" means all plugins found, a name beginning with "!" is a negative value to prevent a plugin from being loaded, wildcard "*" is allowed in names (examples: "*" or "*,!lua,!tcl")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "*"

  • weechat.plugin.debug

    • descrizione: abilita come predefinito il debug per tutti i plugin (opzione disabilita di default, caldamente raccomandato)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • weechat.plugin.extension

    • descrizione: elenco separato da virgole di estensioni dei nomi file per i plugin

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ".so,.dll"

  • weechat.plugin.path

    • descrizione: path per la ricerca dei plugin ("%h" sarà sostituito dalla home di WeeChat, "~/.weechat come predefinita)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%h/plugins"

  • weechat.plugin.save_config_on_unload

    • descrizione: salva i file di configurazione allo scaricamento dei plugin

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.startup.command_after_plugins

    • descrizione: comando eseguito all'avvio di WeeChat, dopo il caricamento dei plugin (nota: il contenuto viene valutato, consultare /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.startup.command_before_plugins

    • descrizione: comando eseguito all'avvio di WeeChat, prima del caricamento dei plugin (nota: il contenuto viene valutato, consultare /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • weechat.startup.display_logo

    • descrizione: mostra il logo di WeeChat all'avvio

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.startup.display_version

    • descrizione: mostra la versione di WeeChat all'avvio

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • weechat.startup.sys_rlimit

    • descrizione: imposta limite delle risorse per il processo WeeChat, il formato è: "res1:limit1,res2,limit2"; il nome della risorsa è il componente finale della costante (RLIMIT_XXX) in caratteri minuscoli (consultare man setrlimit per i valori); il limite -1 vuol dire "illimitato"; esempio: imposta dimensione illimitata per il file core e 1GB massimo di memoria virtuale: "core:-1,as:1000000000"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

3.15.3. Comandi di WeeChat

  • away: imposta o elimina lo stato di assenza

/away  [-all] [<messaggio>]

     -all: imposta o elimina lo stato di assenza su tutti i server connessi
messaggio: messaggio di assenza (se non specificato, lo stato di assenza viene rimosso)
  • bar: gestione delle barre

/bar  list|listfull|listitems
      add <name> <type>[,<conditions>] <position> <size> <separator> <item1>[,<item2>...]
      default [input|title|status|nicklist]
      del <name>|-all
      set <name> <option> <value>
      hide|show|toggle <name>
      scroll <name> <window> <scroll_value>

         list: list all bars
     listfull: list all bars (verbose)
    listitems: list all bar items
          add: add a new bar
         name: name of bar (must be unique)
         type:   root: outside windows,
               window: inside windows, with optional conditions (see below)
   conditions: the conditions to display the bar:
                 active: on active window
               inactive: on inactive windows
               nicklist: on windows with nicklist
               other condition: see /help weechat.bar.xxx.conditions and /help eval
               without conditions, the bar is always displayed
     position: bottom, top, left or right
         size: size of bar (in chars)
    separator: 1 for using separator (line), 0 or nothing means no separator
    item1,...: items for this bar (items can be separated by comma (space between items) or "+" (glued items))
      default: create a default bar (all default bars if no bar name is given)
          del: delete a bar (or all bars with -all)
          set: set a value for a bar property
       option: option to change (for options list, look at /set weechat.bar.<barname>.*)
        value: new value for option
         hide: hide a bar
         show: show an hidden bar
       toggle: hide/show a bar
       scroll: scroll bar
       window: window number (use '*' for current window or for root bars)
 scroll_value: value for scroll: 'x' or 'y' (optional), followed by '+', '-', 'b' (beginning) or 'e' (end), value (for +/-), and optional % (to scroll by % of width/height, otherwise value is number of chars)

Examples:
  create a bar with time, buffer number + name, and completion:
    /bar add mybar root bottom 1 0 [time],buffer_number+:+buffer_name,completion
  hide a bar:
    /bar hide mybar
  scroll nicklist 10 lines down on current buffer:
    /bar scroll nicklist * y+10
  scroll to end of nicklist on current buffer:
    /bar scroll nicklist * ye
  • buffer: gestione dei buffer

/buffer  list
         clear [<number>|<name>|-merged|-all [<number>|<name>...]]
         move <number>|-|+
         swap <number1>|<name1> [<number2>|<name2>]
         cycle <number>|<name> [<number>|<name>...]]
         merge <number>
         unmerge [<number>|-all]
         hide [<number>|<name>|-all [<number>|<name>...]]
         unhide [<number>|<name>|-all [<number>|<name>...]]
         renumber [<number1> [<number2> [<start>]]]
         close [<n1>[-<n2>]|<name>]
         notify <level>
         localvar
         set <property> <value>
         get <property>
         <number>|-|+|<name>

    list: list buffers (without argument, this list is displayed)
   clear: clear buffer content (number for a buffer, -merged for merged buffers, -all for all buffers, or nothing for current buffer)
    move: move buffer in the list (may be relative, for example -1); "-" = move to first buffer number, "+" = move to last buffer number + 1
    swap: swap two buffers (swap with current buffer if only one number/name given)
   cycle: jump loop between a list of buffers
   merge: merge current buffer to another buffer (chat area will be mix of both buffers)
          (by default ctrl-x switches between merged buffers)
 unmerge: unmerge buffer from other buffers which have same number
    hide: hide the buffer
  unhide: unhide the buffer
renumber: renumber buffers (works only if option weechat.look.buffer_auto_renumber is off)
   close: close buffer (number/range or name is optional)
  notify: set notify level for current buffer: this level determines whether buffer will be added to hotlist or not:
               none: never
          highlight: for highlights only
            message: for messages from users + highlights
                all: all messages
              reset: reset to default value (all)
localvar: display local variables for current buffer
     set: set a property for current buffer
     get: display a property of current buffer
  number: jump to buffer by number, possible prefix:
          '+': relative jump, add number to current
          '-': relative jump, sub number to current
          '*': jump to number, using option "weechat.look.jump_current_to_previous_buffer"
       -: jump to first buffer number
       +: jump to last buffer number
    name: jump to buffer by (partial) name

Examples:
  clear current buffer:
    /buffer clear
  move buffer to number 5:
    /buffer move 5
  swap buffer 1 with 3:
    /buffer swap 1 3
  swap buffer #weechat with current buffer:
    /buffer swap #weechat
  jump on #chan1, #chan2, #chan3 and loop:
    /buffer cycle #chan1 #chan2 #chan3
  merge with core buffer:
    /buffer merge 1
  unmerge buffer:
    /buffer unmerge
  close current buffer:
    /buffer close
  close buffers 5 to 7:
    /buffer close 5-7
  jump to #weechat:
    /buffer #weechat
  jump to next buffer:
    /buffer +1
  jump to last buffer number:
    /buffer +
  • color: definisce gli alias dei colori e visualizza la tavolozza dei colori

/color  alias <color> <name>
        unalias <color>
        reset
        term2rgb <color>
        rgb2term <rgb> [<limit>]
        -o

   alias: add an alias for a color
 unalias: delete an alias
   color: color number (greater than or equal to 0, max depends on terminal, commonly 63 or 255)
    name: alias name for color (for example: "orange")
   reset: reset all color pairs (required when no more color pairs are available if automatic reset is disabled, see option "weechat.look.color_pairs_auto_reset")
term2rgb: convert a terminal color (0-255) to RGB color
rgb2term: convert a RGB color to terminal color (0-255)
   limit: number of colors to use in terminal table (starting from 0); default is 256
      -o: send terminal/colors info to current buffer as input

Without argument, this command displays colors in a new buffer.

Examples:
  add alias "orange" for color 214:
    /color alias 214 orange
  delete color 214:
    /color unalias 214
  • command: esegui comando o plugin di WeeChat esplicito

/command  [-buffer <name>] <plugin> <command>

-buffer: execute the command on this buffer
 plugin: execute the command from this plugin; 'core' for a WeeChat command, '*' for automatic plugin (it depends on the buffer where the command is executed)
command: command to execute (a '/' is automatically added if not found at beginning of command)
  • cursor: movimento libero del cursore sullo schermo per eseguire azioni su aree specifiche dello schermo

/cursor  go chat|<barra>|<x>,<y>
         move up|down|left|right|area_up|area_down|area_left|area_right
         stop

  go: move cursor to chat area, a bar (using bar name) or coordinates "x,y"
move: move cursor with direction
stop: stop cursor mode

Without argument, this command toggles cursor mode.

When mouse is enabled (see /help mouse), by default a middle click will start cursor mode at this point.

Default keys in cursor mode on chat messages:
  m  quote message
  q  quote prefix + message
  Q  quote time + prefix + message

Default keys in cursor mode on nicklist:
  b  ban nick (/ban)
  k  kick nick (/kick)
  K  kick and ban nick (/kickban)
  q  open query with nick (/query)
  w  query information about user (/whois)

Examples:
  go to nicklist:
    /cursor go nicklist
  go to coordinates x=10, y=5:
    /cursor go 10,5
  • debug: debug functions

/debug  list
        set <plugin> <level>
        dump [<plugin>]
        buffer|color|infolists|memory|tags|term|windows
        mouse|cursor [verbose]
        hdata [free]
        time <command>

     list: list plugins with debug levels
      set: set debug level for plugin
   plugin: name of plugin ("core" for WeeChat core)
    level: debug level for plugin (0 = disable debug)
     dump: save memory dump in WeeChat log file (same dump is written when WeeChat crashes)
   buffer: dump buffer content with hexadecimal values in log file
    color: display infos about current color pairs
   cursor: toggle debug for cursor mode
     dirs: display directories
    hdata: display infos about hdata (with free: remove all hdata in memory)
    hooks: display infos about hooks
infolists: display infos about infolists
     libs: display infos about external libraries used
   memory: display infos about memory usage
    mouse: toggle debug for mouse
     tags: display tags for lines
     term: display infos about terminal
  windows: display windows tree
     time: measure time to execute a command or to send text to the current buffer
  • eval: evaluate expression

/eval  [-n|-s] <expression>
       [-n] -c <expression1> <operator> <expression2>

        -n: display result without sending it to buffer (debug mode)
        -s: split expression before evaluating it (many commands can be separated by semicolons)
        -c: evaluate as condition: use operators and parentheses, return a boolean value ("0" or "1")
expression: expression to evaluate, variables with format ${variable} are replaced (see below); many commands can be separated by semicolons
  operator: a logical or comparison operator:
            - logical operators:
                &&  boolean "and"
                ||  boolean "or"
            - comparison operators:
                ==  equal
                !=  not equal
                <=  less or equal
                <   less
                >=  greater or equal
                >   greater
                =~  is matching POSIX extended regex
                !~  is NOT matching POSIX extended regex

An expression is considered as "true" if it is not NULL, not empty, and different from "0".
The comparison is made using integers if the two expressions are valid integers.
To force a string comparison, add double quotes around each expression, for example:
  50 > 100      ==> 0
  "50" > "100"  ==> 1

Some variables are replaced in expression, using the format ${variable}, variable can be, by order of priority:
  1. an evaluated sub-string (format: "eval:xxx")
  2. a string with escaped chars (format: "esc:xxx" or "\xxx")
  3. a string with chars to hide (format: "hide:char,string")
  4. a color (format: "color:xxx")
  5. an info (format: "info:name,arguments", arguments are optional)
  6. current date/time (format: "date" or "date:format")
  7. an environment variable (format: "env:XXX")
  8. an option (format: "file.section.option")
  9. a local variable in buffer
  10. a hdata name/variable (the value is automatically converted to string), by default "window" and "buffer" point to current window/buffer.
Format for hdata can be one of following:
  hdata.var1.var2...: start with a hdata (pointer must be known), and ask variables one after one (other hdata can be followed)
  hdata[list].var1.var2...: start with a hdata using a list, for example:
    ${buffer[gui_buffers].full_name}: full name of first buffer in linked list of buffers
    ${plugin[weechat_plugins].name}: name of first plugin in linked list of plugins
  hdata[pointer].var1.var2...: start with a hdata using a pointer, for example:
    ${buffer[0x1234abcd].full_name}: full name of the buffer with this pointer (can be used in triggers)
For name of hdata and variables, please look at "Plugin API reference", function "weechat_hdata_get".

Examples (simple strings):
  /eval -n ${info:version}                     ==> 0.4.3
  /eval -n ${env:HOME}                         ==> /home/user
  /eval -n ${weechat.look.scroll_amount}       ==> 3
  /eval -n ${window}                           ==> 0x2549aa0
  /eval -n ${window.buffer}                    ==> 0x2549320
  /eval -n ${window.buffer.full_name}          ==> core.weechat
  /eval -n ${window.buffer.number}             ==> 1
  /eval -n ${\t}                               ==> <tab>
  /eval -n ${hide:-,${relay.network.password}} ==> --------
  /eval -n ${date:%H:%M:%S}                    ==> 07:46:40

Examples (conditions):
  /eval -n -c ${window.buffer.number} > 2 ==> 0
  /eval -n -c ${window.win_width} > 100   ==> 1
  /eval -n -c (8 > 12) || (5 > 2)         ==> 1
  /eval -n -c (8 > 12) && (5 > 2)         ==> 0
  /eval -n -c abcd =~ ^ABC                ==> 1
  /eval -n -c abcd =~ (?-i)^ABC           ==> 0
  /eval -n -c abcd =~ (?-i)^abc           ==> 1
  /eval -n -c abcd !~ abc                 ==> 0
  • filter: filtra messaggi nei buffer, per nascondere/mostrare in base a tag o regexp

/filter  list
         enable|disable|toggle [<name>|@]
         add <name> <buffer>[,<buffer>...] <tags> <regex>
         rename <name> <new_name>
         del <name>|-all

   list: list all filters
 enable: enable filters (filters are enabled by default)
disable: disable filters
 toggle: toggle filters
   name: filter name ("@" = enable/disable all filters in current buffer)
    add: add a filter
 rename: rename a filter
    del: delete a filter
   -all: delete all filters
 buffer: comma separated list of buffers where filter is active:
         - this is full name including plugin (example: "irc.freenode.#weechat" or "irc.server.freenode")
         - "*" means all buffers
         - a name starting with '!' is excluded
         - wildcard "*" is allowed
   tags: comma separated list of tags, for example "irc_join,irc_part,irc_quit"
         - logical "and": use "+" between tags (for example: "nick_toto+irc_action")
         - wildcard "*" is allowed
         - if tag starts with '!', then it is excluded and must NOT be in message
  regex: POSIX extended regular expression to search in line
         - use '\t' to separate prefix from message, special chars like '|' must be escaped: '\|'
         - if regex starts with '!', then matching result is reversed (use '\!' to start with '!')
         - two regular expressions are created: one for prefix and one for message
         - regex are case insensitive, they can start by "(?-i)" to become case sensitive

The default key alt+'=' toggles filtering on/off.

Tags most commonly used:
  no_filter, no_highlight, no_log, log0..log9 (log level),
  notify_none, notify_message, notify_private, notify_highlight,
  self_msg, nick_xxx (xxx is nick in message), prefix_nick_ccc (ccc is color of nick),
  host_xxx (xxx is username + host in message),
  irc_xxx (xxx is command name or number, see /server raw or /debug tags),
  irc_numeric, irc_error, irc_action, irc_ctcp, irc_ctcp_reply, irc_smart_filter, away_info.
To see tags for lines in buffers: /debug tags

Examples:
  use IRC smart filter on all buffers:
    /filter add irc_smart * irc_smart_filter *
  use IRC smart filter on all buffers except those with "#weechat" in name:
    /filter add irc_smart *,!*#weechat* irc_smart_filter *
  filter all IRC join/part/quit messages:
    /filter add joinquit * irc_join,irc_part,irc_quit *
  filter nicks displayed when joining channels or with /names:
    /filter add nicks * irc_366 *
  filter nick "toto" on IRC channel #weechat:
    /filter add toto irc.freenode.#weechat nick_toto *
  filter IRC join/action messages from nick "toto":
    /filter add toto * nick_toto+irc_join,nick_toto+irc_action *
  filter lines containing "weechat sucks" on IRC channel #weechat:
    /filter add sucks irc.freenode.#weechat * weechat sucks
  filter lines that are strictly equal to "WeeChat sucks" on all buffers:
    /filter add sucks2 * * (?-i)^WeeChat sucks$
  • help: visualizza l’aiuto su comandi e opzioni

/help  -list|-listfull [<plugin> [<plugin>...]]
       <comando>
       <opzione>

    -list: elenca i comandi, per plugin (senza argomento, viene mostrata questa lista)
-listfull: elenca i comandi con la relativa descrizione, per plugin
   plugin: elenca i comandi per questo plugin
  comando: nome di un comando
  opzione: nome di un'opzione (usare /set per consultare la lista)
  • history: mostra la cronologia dei comandi del buffer

/history  <clear
          valore>

 clear: pulisci cronologia
valore: numero delle voci nella cronologia da mostrare
  • input: funzioni per la riga di comando

/input  <azioni> [<argomenti>]

list of actions:
  return: simulate key "enter"
  complete_next: complete word with next completion
  complete_previous: complete word with previous completion
  search_text_here: search text in buffer at current position
  search_text: search text in buffer
  search_switch_case: switch exact case for search
  search_switch_regex: switch search type: string/regular expression
  search_switch_where: switch search in messages/prefixes
  search_previous: search previous line
  search_next: search next line
  search_stop_here: stop search at current position
  search_stop: stop search
  delete_previous_char: delete previous char
  delete_next_char: delete next char
  delete_previous_word: delete previous word
  delete_next_word: delete next word
  delete_beginning_of_line: delete from beginning of line until cursor
  delete_end_of_line: delete from cursor until end of line
  delete_line: delete entire line
  clipboard_paste: paste from the internal clipboard
  transpose_chars: transpose two chars
  undo: undo last command line action
  redo: redo last command line action
  move_beginning_of_line: move cursor to beginning of line
  move_end_of_line: move cursor to end of line
  move_previous_char: move cursor to previous char
  move_next_char: move cursor to next char
  move_previous_word: move cursor to previous word
  move_next_word: move cursor to next word
  history_previous: recall previous command in current buffer history
  history_next: recall next command in current buffer history
  history_global_previous: recall previous command in global history
  history_global_next: recall next command in global history
  jump_smart: jump to next buffer with activity
  jump_last_buffer_displayed: jump to last buffer displayed (before last jump to a buffer)
  jump_previously_visited_buffer: jump to previously visited buffer
  jump_next_visited_buffer: jump to next visited buffer
  hotlist_clear: clear hotlist (optional argument: "lowest" to clear only lowest level in hotlist, "highest" to clear only highest level in hotlist, or level mask: integer which is a combination of 1=join/part, 2=message, 4=private, 8=highlight)
  grab_key: grab a key (optional argument: delay for end of grab, default is 500 milliseconds)
  grab_key_command: grab a key with its associated command (optional argument: delay for end of grab, default is 500 milliseconds)
  grab_mouse: grab mouse event code
  grab_mouse_area: grab mouse event code with area
  set_unread: set unread marker for all buffers
  set_unread_current_buffer: set unread marker for current buffer
  switch_active_buffer: switch to next merged buffer
  switch_active_buffer_previous: switch to previous merged buffer
  zoom_merged_buffer: zoom on merged buffer
  insert: insert text in command line (escaped chars are allowed, see /help print)
  send: send text to the buffer
  paste_start: start paste (bracketed paste mode)
  paste_stop: stop paste (bracketed paste mode)

This command is used by key bindings or plugins.
  • key: associa/disassocia tasti

/key  list|listdefault|listdiff [<contesto>]
      bind <tasto> [<comando> [<arg>]]
      bindctxt <contesto> <tasto> [<comando> <arg>]]
      unbind <tasto>
      unbindctxt <contesto> <chiave>
      reset <tasto>
      resetctxt <contesto> <tasto>
      resetall -yes [<contesto>]
      missing [<contesto>]

       list: list all current keys (without argument, this list is displayed)
listdefault: list default keys
   listdiff: list differences between current and default keys (keys added, redefined or deleted)
    context: name of context ("default" or "search")
       bind: bind a command to a key or display command bound to key (for context "default")
   bindctxt: bind a command to a key or display command bound to key, for given context
    command: command (many commands can be separated by semicolons)
     unbind: remove a key binding (for context "default")
 unbindctxt: remove a key binding for given context
      reset: reset a key to default binding (for context "default")
  resetctxt: reset a key to default binding, for given context
   resetall: restore bindings to the default values and delete ALL personal bindings (use carefully!)
    missing: add missing keys (using default bindings), useful after installing new WeeChat version

When binding a command to a key, it is recommended to use key alt+k (or Esc then k), and then press the key to bind: this will insert key code in command line.

For context "mouse" (possible in context "cursor" too), key has format: "@area:key" or "@area1>area2:key" where area can be:
          *: any area on screen
       chat: chat area (any buffer)
  chat(xxx): char area for buffer with name "xxx" (full name including plugin)
     bar(*): any bar
   bar(xxx): bar "xxx"
    item(*): any bar item
  item(xxx): bar item "xxx"
Wildcard "*" is allowed in key to match many mouse events.
A special value for command with format "hsignal:name" can be used for context mouse, this will send the hsignal "name" with the focus hashtable as argument.
Another special value "-" can be used to disable key (it will be ignored when looking for keys).

Examples:
  key alt-t to toggle nicklist bar:
    /key bind meta-t /bar toggle nicklist
  key alt-r to jump to #weechat IRC channel:
    /key bind meta-r /buffer #weechat
  restore default binding for key alt-r:
    /key reset meta-r
  key "tab" to stop search in buffer:
    /key bindctxt search ctrl-I /input search_stop
  middle button of mouse on a nick to retrieve info on nick:
    /key bindctxt mouse @item(buffer_nicklist):button3 /msg nickserv info ${nick}
  • layout: manage buffers/windows layouts

/layout  store [<name>] [buffers|windows]
         apply [<name>] [buffers|windows]
         leave
         del [<name>] [buffers|windows]
         rename <name> <new_name>

  store: store current buffers/windows in a layout
  apply: apply stored layout
  leave: leave current layout (does not update any layout)
    del: delete buffers and/or windows in a stored layout
         (if neither "buffers" nor "windows" is given after the name, the layout is deleted)
 rename: rename a layout
   name: name for stored layout (default is "default")
buffers: store/apply only buffers (order of buffers)
windows: store/apply only windows (buffer displayed by each window)

Without argument, this command displays stored layouts.

The current layout can be saved on /quit command with the option "weechat.look.save_layout_on_exit".
  • mouse: controllo mouse

/mouse  enable|disable|toggle [<ritardo>]

 enable: abilita mouse
disable: disabilita mouse
 toggle: abilita/disabilita mouse
ritardo: ritardo (in secondi) dopo il quale viene ripristinato lo stato iniziale del mouse (utile per disattivarlo temporaneamente)

Lo stato del mouse viene salvato nell'opzione "weechat.look.mouse".

Esempi:
  abilita mouse:
    /mouse enable
  abilita/disabilita mouse per 5 secondi:
    /mouse toggle 5
  • mute: esegue un comando in silenzio

/mute  [-core | -current | -buffer <name>] <command>

   -core: no output on WeeChat core buffer
-current: no output on current buffer
 -buffer: no output on specified buffer
    name: full buffer name (examples: "irc.server.freenode", "irc.freenode.#weechat")
 command: command to execute silently (a '/' is automatically added if not found at beginning of command)

If no target is specified (-core, -current or -buffer), then default is to mute all buffers.

Examples:
  config save:
    /mute save
  message to current IRC channel:
    /mute -current msg * hi!
  message to #weechat channel:
    /mute -buffer irc.freenode.#weechat msg #weechat hi!
  • plugin: elenca/carica/scarica plugin

/plugin  list|listfull [<nome>]
         load <nome_file> [<argomenti>]
         autoload [<argomenti>]
         reload [<nome>|* [<argomenti>]]
         unload [<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente un plugin nella directory di sistema o utente
   reload: ricarica un plugin (se non specificato, scarica e poi ricarica tutti i plugin)
   unload: scarica un plugin (se non specificato, scarica tutti i plugin
 nomefile: plugin (file) da caricare
     nome: nome di un plugin
argomenti: argomenti passati al plugin durante il caricamento

Senza argomento, questo comando elenca i plugin caricati.
  • print: display text on a buffer

/print  [-buffer <number>|<name>] [-core] [-escape] [-date <date>] [-tags <tags>] [-action|-error|-join|-network|-quit] [<text>]
        -stdout|-stderr [<text>]
        -beep

 -buffer: display text in this buffer (default: buffer where command is executed)
   -core: alias of "-buffer core.weechat"
-current: display text on current buffer
 -escape: interpret escaped chars (for example \a, \07, \x07)
   -date: message date, format can be:
            -n: 'n' seconds before now
            +n: 'n' seconds in the future
             n: 'n' seconds since the Epoch (see man time)
            date/time (ISO 8601): yyyy-mm-ddThh:mm:ss, example: 2014-01-19T04:32:55
            time: hh:mm:ss (example: 04:32:55)
   -tags: comma-separated list of tags (see /help filter for a list of tags most commonly used)
    text: text to display (prefix and message must be separated by "\t", if text starts with "-", then add a "\" before)
 -stdout: display text on stdout (escaped chars are interpreted)
 -stderr: display text on stderr (escaped chars are interpreted)
   -beep: alias of "-stderr \a"

The options -action ... -quit use the prefix defined in options "weechat.look.prefix_*".

Following escaped chars are supported:
  \" \\ \a \b \e \f \n \r \t \v \0ooo \xhh \uhhhh \Uhhhhhhhh

Examples:
  display a reminder on core buffer with a highlight:
    /print -core -tags notify_highlight Reminder: buy milk
  display an error on core buffer:
    /print -core -error Some error here
  display message on core buffer with prefix "abc":
    /print -core abc\tThe message
  display a message on channel #weechat:
    /print -buffer irc.freenode.#weechat Message on #weechat
  display a snowman (U+2603):
    /print -escape \u2603
  send alert (BEL):
    /print -beep
  • proxy: gestione dei proxy

/proxy  list
        add <nome> <tipo> <indirizzo> <porta> [<nomeutente> [<password>]]
        del <nome>|-all
        set <nome> <opzione> <valore>

    list: list all proxies
     add: add a new proxy
    name: name of proxy (must be unique)
    type: http, socks4 or socks5
 address: IP or hostname
    port: port
username: username (optional)
password: password (optional)
     del: delete a proxy (or all proxies with -all)
     set: set a value for a proxy property
  option: option to change (for options list, look at /set weechat.proxy.<proxyname>.*)
   value: new value for option

Examples:
  add a http proxy, running on local host, port 8888:
    /proxy add local http 127.0.0.1 8888
  add a http proxy using IPv6 protocol:
    /proxy add local http ::1 8888
    /proxy set local ipv6 on
  add a socks5 proxy with username/password:
    /proxy add myproxy socks5 sample.host.org 3128 myuser mypass
  delete a proxy:
    /proxy del myproxy
  • quit: esce da WeeChat

/quit  [-yes] [<argomenti>]

     -yes: required if option "weechat.look.confirm_quit" is enabled
arguments: text sent with signal "quit"
           (for example irc plugin uses this text to send quit message to server)

By default when quitting the configuration files are saved (see option "weechat.look.save_config_on_exit") and the current layout can be saved (see option "weechat.look.save_layout_on_exit").
  • reload: ricarica i file di configurazione da disco

/reload  [<file> [<file....>]]

file: file di configurazione da ricaricare (senza estensione ".conf")

Senza argomento, vengono ricaricati tutti i file (WeeChat e plugin).
  • repeat: esegue un comando più volte

/repeat  [-interval <ritardo>] <numero> <comando>

ritardo: ritardo tra l'esecuzione dei comandi (in millisecondi)
 numero: numero di volte in cui eseguire il comando
comando: comando da eseguire (una '/' viene aggiunta automaticamente se non viene trovata all'inizio del comando)

Tutti i comandi sono eseguiti sul buffer su cui viene dato il comando.

Esempio:
  scorre due pagine in alto:
    /repeat 2 /window page_up
  • save: salva i file di configurazione su disco

/save  [<file> [<file....>]]

file: configuration file to save (without extension ".conf")

Without argument, all files (WeeChat and plugins) are saved.

By default all configuration files are saved to disk on /quit command (see option "weechat.look.save_config_on_exit").
  • secure: gestione dei dati sensibili (password o file privati cifrati nel file sec.conf)

/secure  passphrase <chiave di cifratura>|-delete
         decrypt <chiave di cifratura|-discard
         set <nome> <valore>
         del <nome>

passphrase: change the passphrase (without passphrase, data is stored as plain text in file sec.conf)
   -delete: delete passphrase
   decrypt: decrypt data still encrypted (it happens only if passphrase was not given on startup)
  -discard: discard all data still encrypted
       set: add or change secured data
       del: delete secured data

Without argument, this command displays secured data in a new buffer.

Keys on secure buffer:
  alt+v  toggle values

When a passphrase is used (data encrypted), it is asked by WeeChat on startup.
It is possible to set environment variable "WEECHAT_PASSPHRASE" to prevent the prompt (this same variable is used by WeeChat on /upgrade).

Secured data with format ${sec.data.xxx} can be used in:
  - command /eval
  - command line argument "--run-command"
  - options weechat.startup.command_{before|after}_plugins
  - other options that may contain a password or sensitive data (for example proxy, irc server and relay); see /help on the options to check if they are evaluated.

Examples:
  set a passphrase:
    /secure passphrase this is my passphrase
  encrypt freenode SASL password:
    /secure set freenode mypassword
    /set irc.server.freenode.sasl_password "${sec.data.freenode}"
  encrypt oftc password for nickserv:
    /secure set oftc mypassword
    /set irc.server.oftc.command "/msg nickserv identify ${sec.data.oftc}"
  alias to ghost the nick "mynick":
    /alias add ghost /eval /msg -server freenode nickserv ghost mynick ${sec.data.freenode}
  • set: set config options and environment variables

/set  [<option> [<value>]]
      diff [<option> [<option>...]]
      env [<variable> [<value>]]

option: name of an option (wildcard "*" is allowed)
 value: new value for option, according to type:
          boolean: on, off or toggle
          integer: number, ++number or --number
           string: any string ("" for empty string)
            color: color name, ++number or --number
        Note: for all types, you can use null to remove option value (undefined value). This works only for some special plugin variables.
  diff: display only changed options
   env: display or set an environment variable (use value "" to unset a variable)

Examples:
  display options about highlight:
    /set *highlight*
  add a word to highlight:
    /set weechat.look.highlight "word"
  display changed options:
    /set diff
  display changed options in irc plugin:
    /set diff irc.*
  display value of environment variable LANG:
    /set env LANG
  set environment variable LANG and use it:
    /set env LANG fr_FR.UTF-8
    /upgrade
  unset environment variable ABC:
    /set env ABC ""
  • unset: annulla/ripristina opzione

/unset  <option>
        -mask <option>

option: name of an option
 -mask: use a mask in option (wildcard "*" is allowed to mass-reset options, use carefully!)

According to option, it's reset (for standard options) or removed (for optional settings, like server values).

Examples:
  reset one option:
    /unset weechat.look.item_time_format
  reset all color options:
    /unset -mask weechat.color.*
  • upgrade: aggiorna WeeChat senza disconnettere dai server

/upgrade  [-yes] [<path_to_binary>|-quit]

          -yes: required if option "weechat.look.confirm_upgrade" is enabled
path_to_binary: path to WeeChat binary (default is current binary)
        -dummy: do nothing (option used to prevent accidental completion with "-quit")
         -quit: close *ALL* connections, save session and quit WeeChat, which makes possible a delayed restoration (see below)

This command upgrades and reloads a running WeeChat session. The new WeeChat binary must have been compiled or installed with a package manager before running this command.

Note: SSL connections are lost during upgrade, because reload of SSL sessions is currently not possible with GnuTLS. There is automatic reconnection after upgrade.

Upgrade process has 4 steps:
  1. save session into files for core and plugins (buffers, history, ..)
  2. unload all plugins (configuration files (*.conf) are written on disk)
  3. save WeeChat configuration (weechat.conf)
  4. execute new WeeChat binary and reload session.

With option "-quit", the process is slightly different:
  1. close *ALL* connections (irc, xfer, relay, ...)
  2. save session into files (*.upgrade)
  3. unload all plugins
  4. save WeeChat configuration
  5. quit WeeChat
Then later you can restore session with command: weechat --upgrade
IMPORTANT: you must restore the session with exactly same configuration (files *.conf).
It is possible to restore WeeChat session on another machine if you copy the content of directory "~/.weechat".
  • uptime: mostra l’uptime di WeeChat

/uptime  [-o | -ol]

 -o: invia l'uptime al buffer corrente come input (stringa in inglese)
-ol: invia l'uptime al buffer corrente come input (stringa tradotta)
  • version: mostra la versione e la data di compilazione di WeeChat

/version  [-o | -ol]

 -o: send version to current buffer as input (English string)
-ol: send version to current buffer as input (translated string)

The default alias /v can be used to execute this command on all buffers (otherwise the irc command /version is used on irc buffers).
  • wait: pianifica l’esecuzione di un comando

/wait  <numero>[<unità>] <comando>

 numero: tempo di attesa (numero intero)
  unità: valori opzionali sono:
           ms: millisecondi
            s: secondi (predefinito)
            m: minuti
            h: ore
comando: comando da eseguire (o testo da inviare al buffer se il comando non inizia con '/')

Nota: il comando viene eseguito sui buffer dove /wait è stato eseguito (se il buffer non viene trovato (per esempio se è stato chiuso prima dell'esecuzione), allora il comando verrà eseguito sul buffer core di WeeChat)

Esempi:
  entra nel canale tra 10 secondi:
    /wait 10 /join #test
  imposta assenza tra 15 minuti:
    /wait 15m /away -all Sono assente
  scrive 'ciao' tra 2 minuti:
    /wait 2m ciao
  • window: gestione delle finestre

/window  list
         -1|+1|b#|up|down|left|right [-window <number>]
         <number>
         splith|splitv [-window <number>] [<pct>]
         resize [-window <number>] [+/-]<pct>
         balance
         merge [-window <number>] [all]
         page_up|page_down [-window <number>]
         refresh
         scroll [-window <number>] [+/-]<value>[s|m|h|d|M|y]
         scroll_horiz [-window <number>] [+/-]<value>[%]
         scroll_up|scroll_down|scroll_top|scroll_bottom|scroll_beyond_end|scroll_previous_highlight|scroll_next_highlight|scroll_unread [-window <number>]
         swap [-window <number>] [up|down|left|right]
         zoom [-window <number>]
         bare [<delay>]

         list: list opened windows (without argument, this list is displayed)
           -1: jump to previous window
           +1: jump to next window
           b#: jump to next window displaying buffer number #
           up: switch to window above current one
         down: switch to window below current one
         left: switch to window on the left
        right: switch to window on the right
       number: window number (see /window list)
       splith: split current window horizontally (to undo: /window merge)
       splitv: split current window vertically (to undo: /window merge)
       resize: resize window size, new size is <pct> percentage of parent window
      balance: balance the sizes of all windows
        merge: merge window with another (all = keep only one window)
      page_up: scroll one page up
    page_down: scroll one page down
      refresh: refresh screen
       scroll: scroll a number of lines (+/-N) or with time: s=seconds, m=minutes, h=hours, d=days, M=months, y=years
 scroll_horiz: scroll horizontally a number of columns (+/-N) or percentage of window size (this scrolling is possible only on buffers with free content)
    scroll_up: scroll a few lines up
  scroll_down: scroll a few lines down
   scroll_top: scroll to top of buffer
scroll_bottom: scroll to bottom of buffer
scroll_beyond_end: scroll beyond the end of buffer
scroll_previous_highlight: scroll to previous highlight
scroll_next_highlight: scroll to next highlight
scroll_unread: scroll to unread marker
         swap: swap buffers of two windows (with optional direction for target window)
         zoom: zoom on window
         bare: toggle bare display (with optional delay in seconds for automatic return to standard display mode)

For splith and splitv, pct is a percentage which represents size of new window, computed with current window as size reference. For example 25 means create a new window with size = current_size / 4

Examples:
  jump to window displaying buffer #1:
    /window b1
  scroll 2 lines up:
    /window scroll -2
  scroll 2 days up:
    /window scroll -2d
  scroll to beginning of current day:
    /window scroll -d
  zoom on window #2:
    /window zoom -window 2
  split window horizontally using 30%% of space for the window on top:
    /window splith 30
  remove the split:
    /window merge
  enable bare display for 2 seconds:
    /window bare 2

4. Plugin

Un plugin è una libreria dinamica, scritta in C e compilata, che viene caricata da WeeChat. In GNU/Linux, il file ha estensione ".so", ".dll" in Windows.

I plugin trovati vengono caricati automaticamente all’avvio di WeeChat, ed è possibile caricare o scaricare i plugin durante l’esecuzione del programma.

È importante evidenziare la differenza tra un plugin ed uno script: un plugin è un file binario compilato e caricato con il comando /plugin, mentre uno script è un file di testo caricato con un plugin come python con il comando /python.

È possibile utilizzare il comando /plugin per caricare/scaricare un plugin, oppure elencare tutti i plugin caricati. Quando un plugin viene scaricato, tutti i buffer creati da questo plugin sono chiusi automaticamente.

Esempi per caricare, scaricare oppure elencare i plugin:

/plugin load irc
/plugin unload irc
/plugin list

I plugin predefiniti sono:

Plugin Descrizione

alias

Definisce gli alias per i comandi.

aspell

Controllo ortografico per la riga di comando.

charset

Set di caratteri per la codifica/decodifica nei buffer.

exec

Execution of external commands in WeeChat.

fifo

pipe FIFO utilizzata per inviare comandi da remoto su WeeChat.

irc

protocollo chat per IRC.

logger

Registra i buffer su file.

relay

Relay dei dati via rete.

script

Gestore script.

python

API per lo scripting in Python.

perl

API per lo scripting in Perl.

ruby

API per lo scripting in Ruby.

lua

API per lo scripting in Lua.

tcl

API per lo scripting in TCL.

guile

API per lo scripting in Guile (scheme).

javascript

API per lo scripting in Javascript.

trigger

Text replacement and command execution on events triggered by WeeChat/plugins.

xfer

Trasferimento file e chat diretta.

Per saperne di più riguardo lo sviluppo di plugin o script (tramite le API), per favore consultare Riferimento API dei Plugin per WeeChat oppure Guida allo Scripting di WeeChat.

4.1. Plugin Alias

Il plugin Alias consente di creare alias per i comandi (da WeeChat o altri plugin).

4.1.1. Comandi

  • alias: list, add or remove command aliases

/alias  list [<alias>]
        add <alias> [<command>[;<command>...]]
        addcompletion <completion> <alias> [<command>[;<command>...]]
        del <alias> [<alias>...]

         list: list aliases (without argument, this list is displayed)
          add: add an alias
addcompletion: add an alias with a custom completion
          del: delete an alias
   completion: completion for alias: by default completion is done with target command
               note: you can use %%command to use completion of an existing command
        alias: name of alias
      command: command name with arguments (many commands can be separated by semicolons)

Note: in command, special variables are replaced:
        $n: argument 'n' (between 1 and 9)
       $-m: arguments from 1 to 'm'
       $n-: arguments from 'n' to last
      $n-m: arguments from 'n' to 'm'
        $*: all arguments
        $~: last argument
      $var: where "var" is a local variable of buffer (see /buffer localvar)
            examples: $nick, $channel, $server, $plugin, $name

Examples:
  alias /split to split window horizontally:
    /alias add split /window splith
  alias /hello to say "hello" on all channels but not on #weechat:
    /alias add hello /allchan -exclude=#weechat msg * hello
  alias /forcejoin to send IRC command "forcejoin" with completion of /sajoin:
    /alias addcompletion %%sajoin forcejoin /quote forcejoin

4.2. Plugin Aspell

Il plugin Aspell consente di verificare l’ortografia nella riga di comando. È possibile utilizzare più lingue per buffer.

4.2.1. Opzioni (aspell.conf)

Sections:

Section Control command Description

color

/set aspell.color.*

Colors.

check

/set aspell.check.*

Options to control spell checking.

dict

/aspell setdict
/set aspell.dict.*

Dictionaries used by buffer (options can be added/removed in section).

option

/set aspell.option.*

Opzioni ortografiche (options can be added/removed in section).

Options:

  • aspell.check.commands

    • descrizione: elenco separato da virgole di comandi per cui il controllo ortografico è abilitato (il controllo ortografico è disabilitato per tutti gli altri comandi)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "ame,amsg,away,command,cycle,kick,kickban,me,msg,notice,part,query,quit,topic"

  • aspell.check.default_dict

    • descrizione: dizionario predefinito (o elenco separato da virgole di dizionari) da usare quando il buffer non ha alcun dizionario definito (vuoto per disabilitare il controllo ortografico sui buffer in cui non è stato esplicitamente abilitato)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • aspell.check.during_search

    • descrizione: controlla le parole durante la ricerca del testo nel buffer

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • aspell.check.enabled

    • descrizione: abilita il controllo aspell per la riga di comando

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • aspell.check.real_time

    • descrizione: controllo ortografico in tempo reale (più lento, disabilitato per default: le parole vengono controllate solo se seguite da un delimitatore)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • aspell.check.suggestions

    • descrizione: numero di suggerimenti da mostrare nell'elemento barra "aspell_suggest" per ogni dizionario impostato nel buffer (-1 = disattiva suggerimenti, 0 = mostra tutti i possibili suggerimenti in tutte le lingue)

    • tipo: intero

    • valori: -1 .. 2147483647

    • valore predefinito: -1

  • aspell.check.word_min_length

    • descrizione: lunghezza minima per una parola da controllare (0 per controllarle tutte)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 2

  • aspell.color.misspelled

    • descrizione: text color for misspelled words (input bar)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • aspell.color.suggestions

    • descrizione: text color for suggestions on a misspelled word (status bar)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

4.2.2. Comandi

  • aspell: configurazione del plugin aspell

/aspell  enable|disable|toggle
         listdict
         setdict <dizionario>[,<dizionario>...]
         deldict
         addword [<dizionario>] <parola>

  enable: enable aspell
 disable: disable aspell
  toggle: toggle aspell
listdict: show installed dictionaries
 setdict: set dictionary for current buffer (multiple dictionaries can be separated by a comma)
 deldict: delete dictionary used on current buffer
 addword: add a word in personal aspell dictionary

Input line beginning with a '/' is not checked, except for some commands (see /set aspell.check.commands).

To enable aspell on all buffers, use option "default_dict", then enable aspell, for example:
  /set aspell.check.default_dict "en"
  /aspell enable

To display a list of suggestions in a bar, use item "aspell_suggest".

Default key to toggle aspell is alt-s.

4.2.3. Opzioni ortografiche

Le opzioni ortografiche possono essere definite aggiungendo opzioni nella sezione "opzioni" della configurazione di aspell.

Il nome dell’opzione è un parametro di configurazione per aspell. L’elenco delle opzioni disponibili può essere trovato nel terminale col seguente comando:

$ aspell config

Ad esempio, per abilitare l’opzione "ignore-case":

/set aspell.option.ignore-case "true"

4.2.4. Suggestions

Suggestions are displayed in a bar item called "aspell_suggest". The number of suggestions is set in option aspell.check.suggestions.

To enable suggestions you must set option aspell.check.suggestions to an integer ≥ 0 and add the bar item "aspell_suggest" to a bar, like status.

Example of suggestions with English dictionary (en):

│[12:55] [6] [irc/freenode] 3:#test(+n){4} [print,prone,prune]                    │
│[@Flashy] prinr █                                                                │
└─────────────────────────────────────────────────────────────────────────────────┘

Example of suggestions with English and French dictionaries (en,fr):

│[12:55] [6] [irc/freenode] 3:#test(+n){4} [print,prone,prune/prime,primer,primé] │
│[@Flashy] prinr █                                                                │
└─────────────────────────────────────────────────────────────────────────────────┘

4.3. Plugin Charset

Il plugin Charset consente di decodificare o codificare dati utilizzando i set caratteri.

Esiste un set caratteri predefinito per la codifica/decodifica, e set caratteri specifici per i buffer (o gruppi di buffer).

Questo plugin è opzionale, ma raccomandato: se non caricato, WeeChat può leggere/scrivere soltanto dati UTF-8.

Il plugin Charset dovrebbe essere caricato automaticamente da WeeChat. Per essere sicuri che sia caricato, provare con:

/charset

Se non trovato, allora si deve caricare il plugin con il comando:

/plugin load charset

Se il plugin non viene trovato, allora è necessario ricompilare WeeChat con il supporto ai plugin e a Charset.

Quando viene avviato il plugin Charset, mostra i set caratteri del terminale e quello interno. Il set caratteri dipende dal proprio locale, mentre quello interno è UTF-8.

Per esempio:

set caratteri: terminale: ISO-8859-15, interno: UTF-8

4.3.1. Opzioni (charset.conf)

Sections:

Section Control command Description

default

/set charset.default.*

Default decoding/encoding charset.

decode

/charset decode
/set charset.decode.*

Decoding charset by buffer (options can be added/removed in section).

encode

/charset encode
/set charset.encode.*

Encoding charset by buffer (options can be added/removed in section).

Options:

  • charset.default.decode

    • descrizione: global decoding charset: charset used to decode incoming messages when they are not UTF-8 valid

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "iso-8859-1"

  • charset.default.encode

    • descrizione: global encoding charset: charset used to encode outgoing messages (if empty, default is UTF-8 because it is the WeeChat internal charset)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

4.3.2. Comandi

  • charset: modifica il set di caratteri per il buffer corrente

/charset  decode|encode <set_caratteri>
          reset

       decode: modifica il set di caratteri per la decodifica
       encode: modifica il set di caratteri per la codifica
set_caratteri: nuovo set di caratteri per il buffer corrente
        reset: resetta il set di caratteri per il buffer corrente

4.3.3. Impostare il set caratteri

Per impostare il set caratteri globale per la codifica e la decodifica, utilizzare il comando /set.

Per esempio:

/set charset.default.decode ISO-8859-15
/set charset.default.encode ISO-8859-15

Se il set caratteri globale per la decodifica non è impostato (ad esempio durante il primo caricamento del plugin Charset), verrà impostato automaticamente sul set caratteri del terminale (se diverso da UTF-8), oppure su ISO-8859-1.

Il valore di codifica predefinito è vuoto, perciò il testo viene inviato per default con il set caratteri interno (UTF-8).

Per impostare il set caratteri del server IRC, utilizzare il comando charset sul buffer del server. Se viene immesso solo il set caratteri, allora i valori di codifica e decodifica saranno gli stessi.

Ad esempio:

/charset ISO-8859-15

È l’equivalente di:

/charset decode ISO-8859-15
/charset encode ISO-8859-15

Per impostare il set caratteri per il canale IRC (o il privato), utilizzare gli stessi comandi per il server, ma sul buffer del canale (o quello privato).

To set charset for all channels/privates of an IRC server:

/set charset.encode.irc.freenode ISO-8859-15

Per visualizzare tutti i set caratteri utilizzati, utilizzare il comando seguente:

/set charset.*

4.3.4. Risoluzione problemi

Per qualunque problema con i set caratteri, per favore consultare le Domande Frequenti di WeeChat.

4.4. Exec plugin

The /exec command lets you execute external commands inside WeeChat and display the output locally, or send it to a buffer.

4.4.1. Options (exec.conf)

Sections:

Section Control command Description

command

/set exec.command.*

Options for commands.

color

/set exec.color.*

Colors.

Options:

  • exec.color.flag_finished

    • descrizione: text color for a finished command flag in list of commands

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • exec.color.flag_running

    • descrizione: text color for a running command flag in list of commands

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • exec.command.default_options

    • descrizione: default options for command /exec (see /help exec); example: "-nosh -bg" to run all commands in background (no output), and without using the shell

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • exec.command.purge_delay

    • descrizione: delay for purging finished commands (in seconds, 0 = purge commands immediately, -1 = never purge)

    • tipo: intero

    • valori: -1 .. 25920000

    • valore predefinito: 0

4.4.2. Commands

  • exec: execute external commands

/exec  -list
       [-sh|-nosh] [-bg|-nobg] [-stdin|-nostdin] [-buffer <name>] [-l|-o|-n|-nf] [-cl|-nocl] [-sw|-nosw] [-ln|-noln] [-flush|-noflush] [-color ansi|auto|irc|weechat|strip] [-rc|-norc] [-timeout <timeout>] [-name <name>] [-pipe <command>] [-hsignal <name>] <command>
       -in <id> <text>
       -inclose <id> [<text>]
       -signal <id> <signal>
       -kill <id>
       -killall
       -set <id> <property> <value>
       -del <id>|-all [<id>...]

   -list: list commands
     -sh: use the shell to execute the command (WARNING: use this option ONLY if all arguments are safe, see option -nosh)
   -nosh: do not use the shell to execute the command (required if the command has some unsafe data, for example the content of a message from another user) (default)
     -bg: run process in background: do not display process output neither return code (not compatible with options -o/-oc/-n/-nf/-pipe/-hsignal)
   -nobg: catch process output and display return code (default)
  -stdin: create a pipe for sending data to the process (with /exec -in/-inclose)
-nostdin: do not create a pipe for stdin (default)
 -buffer: display/send output of command on this buffer (if the buffer is not found, a new buffer with name "exec.exec.xxx" is created)
      -l: display locally output of command on buffer (default)
      -o: send output of command to the buffer without executing commands (not compatible with options -bg/-pipe/-hsignal)
     -oc: send output of command to the buffer and execute commands (lines starting with "/" or another custom command char) (not compatible with options -bg/-pipe/-hsignal)
      -n: display output of command in a new buffer (not compatible with options -bg/-pipe/-hsignal)
     -nf: display output of command in a new buffer with free content (no word-wrap, no limit on number of lines) (not compatible with options -bg/-pipe/-hsignal)
     -cl: clear the new buffer before displaying output
   -nocl: append to the new buffer without clear (default)
     -sw: switch to the output buffer (default)
   -nosw: don't switch to the output buffer
     -ln: display line numbers (default in new buffer only)
   -noln: don't display line numbers
  -flush: display output of command in real time (default)
-noflush: display output of command after its end
  -color: action on ANSI colors in output:
             ansi: keep ANSI codes as-is
             auto: convert ANSI colors to WeeChat/IRC (default)
              irc: convert ANSI colors to IRC colors
          weechat: convert ANSI colors to WeeChat colors
            strip: remove ANSI colors
     -rc: display return code (default)
   -norc: don't display return code
-timeout: set a timeout for the command (in seconds)
   -name: set a name for the command (to name it later with /exec)
   -pipe: send the output to a WeeChat/plugin command (line by line); if there are spaces in command/arguments, enclose them with double quotes; variable $line is replaced by the line (by default the line is added after the command, separated by a space) (not compatible with options -bg/-o/-oc/-n/-nf)
-hsignal: send the output as a hsignal (to be used for example in a trigger) (not compatible with options -bg/-o/-oc/-n/-nf)
 command: the command to execute; if beginning with "url:", the shell is disabled and the content of URL is downloaded and sent as output
      id: command identifier: either its number or name (if set with "-name xxx")
     -in: send text on standard input of process
-inclose: same as -in, but stdin is closed after (and text is optional: without text, the stdin is just closed)
 -signal: send a signal to the process; the signal can be an integer or one of these names: hup, int, quit, kill, term, usr1, usr2
   -kill: alias of "-signal <id> kill"
-killall: kill all running processes
    -set: set a hook property (see function hook_set in plugin API reference)
property: hook property
   value: new value for hook property
    -del: delete a terminated command
    -all: delete all terminated commands

Default options can be set in the option exec.command.default_options.

Examples:
  /exec -n ls -l /tmp
  /exec -sh -n ps xu | grep weechat
  /exec -n -norc url:http://pastebin.com/raw.php?i=xxxxxxxx
  /exec -nf -noln links -dump https://weechat.org/files/doc/devel/weechat_user.en.html
  /exec -o uptime
  /exec -pipe "/print Machine uptime:" uptime
  /exec -n tail -f /var/log/messages
  /exec -kill 0

4.5. Plugin Fifo

È possibile controllare da remoto WeeChat, inviando comandi o del testo ad una pipe FIFO (se l’opzione "fifo.file.enabled" è abilitata, e lo è per default).

The FIFO pipe is located in ~/.weechat/ and is called weechat_fifo by default.

La sintassi per i comandi/testo della pipe FIFO è una delle seguenti:

  plugin.buffer *testo o comando qui
  *testo o comando qui

Alcuni esempi:

  • Change nick on IRC server freenode to "newnick":

$ echo 'irc.server.freenode */nick newnick' >~/.weechat/weechat_fifo
  • Send a message on IRC #weechat channel:

$ echo 'irc.freenode.#weechat *hello!' >~/.weechat/weechat_fifo
  • Send a message on current buffer:

$ echo '*hello!' >~/.weechat/weechat_fifo
  • Inviare due comandi per scaricare/caricare gli script Python (è necessario separarli con "\n"):

$ printf '%b' '*/python unload\n*/python autoload\n' >~/.weechat/weechat_fifo

4.5.1. Opzioni (fifo.conf)

Sections:

Section Control command Description

file

/set fifo.file.*

FIFO pipe control.

Options:

  • fifo.file.enabled

    • descrizione: enable FIFO pipe

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • fifo.file.path

    • descrizione: path for FIFO file; "%h" at beginning of string is replaced by WeeChat home ("~/.weechat" by default); WeeChat PID can be used in path with ${info:pid} (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%h/weechat_fifo"

4.5.2. Comandi

  • fifo: fifo plugin configuration

/fifo  enable|disable|toggle

 enable: enable FIFO pipe
disable: disable FIFO pipe
 toggle: toggle FIFO pipe

FIFO pipe is used as remote control of WeeChat: you can send commands or text to the FIFO pipe from your shell.
By default the FIFO pipe is in ~/.weechat/weechat_fifo

The expected format is one of:
  plugin.buffer *text or command here
  *text or command here

For example to change your freenode nick:
  echo 'irc.server.freenode */nick newnick' >~/.weechat/weechat_fifo

Please read the user's guide for more info and examples.

Examples:
  /fifo toggle

4.6. Plugin IRC

Il plugin IRC è realizzato per chattare tramite protocollo IRC con altre persone.

È multi-server, ed offre tutti i comandi IRC supportati inclusi la chat DCC ed il trasferimento file (tramite plugin xfer, consultare plugin Xfer).

4.6.1. Opzioni a riga di comando

È possibile fornire un URL per uno o più server IRC, come segue:

irc[6][s]://[nick[:password]@]irc.esempio.org[:porta][/#canale][,#canale[...]]

Esempio per entrare in #weechat e #tizio sul server chat.freenode.net, porta predefinita (6667), con il nick caio:

$ weechat irc://caio@chat.freenode.net/#weechat,#tizio

4.6.2. Opzioni (irc.conf)

Sections:

Section Control command Description

look

/set irc.look.*

Look and feel.

color

/set irc.color.*

Colors.

network

/set irc.network.*

Network options.

msgbuffer

/set irc.msgbuffer.*

Buffer di destinazione per i messaggi IRC (options can be added/removed in section).

ctcp

/set irc.ctcp.*

Risposte CTCP (options can be added/removed in section).

ignore

/ignore

Ignore people.

server_default

/set irc.server_default.*

Default values for servers (used when options in server are not defined).

server

/server
/set irc.server.*

Servers.

Options:

  • irc.color.input_nick

    • descrizione: colore per il nick nella riga di input

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightcyan

  • irc.color.item_channel_modes

    • descrizione: colore per le modalità dei canali, vicino ai nomi dei canali

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • irc.color.item_lag_counting

    • descrizione: colore per l'indicatore del lag, durante il conteggio (pong non ricevuto dal server, lag in aumento)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • irc.color.item_lag_finished

    • descrizione: colore per l'indicatore di ritardo, quando il pong viene ricevuto dal server

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • irc.color.item_nick_modes

    • descrizione: color for nick modes in bar item "input_prompt"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • irc.color.message_join

    • descrizione: colore per il testo nei messaggi di entrata

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • irc.color.message_quit

    • descrizione: colore per il testo nei messaggi di uscita/abbandono

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: red

  • irc.color.mirc_remap

    • descrizione: remap mirc colors in messages using a hashtable: keys are "fg,bg" as integers between -1 (not specified) and 15, values are WeeChat color names or numbers (format is: "1,-1:color1;2,7:color2"), example: "1,-1:darkgray;1,2:white,blue" to remap black to "darkgray" and black on blue to "white,blue"; default WeeChat colors for IRC codes: 0=white, 1=black, 2=blue, 3=green, 4=lightred, 5=red, 6=magenta, 7=brown, 8=yellow, 9=lightgreen, 10=cyan, 11=lightcyan, 12=lightblue, 13=lightmagenta, 14=gray, 15=white

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "1,-1:darkgray"

  • irc.color.nick_prefixes

    • descrizione: colore per i prefissi dei nick usando il carattere di modalità (o=operatore, h=halfop, v=voice, ..), il formato è: "o:colore1;h:colore2;v:colore3" (se una modalità non viene trovata, WeeChat proverà con le modalità successive ricevute dal server ("PREFIX"); può essere usata una modalità speciale "*" come colore prefefinito se non viene trovata nessuna modalità nella lista)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "y:lightred;q:lightred;a:lightcyan;o:lightgreen;h:lightmagenta;v:yellow;*:lightblue"

  • irc.color.notice

    • descrizione: colore per il testo "Notifica" nelle notifiche

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • irc.color.reason_quit

    • descrizione: colore per il motivo nei messaggi di uscita/abbandono

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • irc.color.topic_current

    • descrizione: color for current channel topic (when joining a channel or using /topic)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • irc.color.topic_new

    • descrizione: colore del nuovo argomento del canale (quando viene cambiato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • irc.color.topic_old

    • descrizione: colore del precedente argomento del canale (quando viene cambiato)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • irc.look.buffer_open_before_autojoin

    • descrizione: open channel buffer before the JOIN is received from server when it is auto joined (with server option "autojoin"); this is useful to open channels with always the same buffer numbers on startup

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.buffer_open_before_join

    • descrizione: open channel buffer before the JOIN is received from server when it is manually joined (with /join command)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.buffer_switch_autojoin

    • descrizione: passa automaticamente al buffer del canale con l'ingresso automatico abilitato (con l'opzione del server "autojoin")

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.buffer_switch_join

    • descrizione: passa automaticamente al buffer del canale quando si entra manualmente (con il comando /join)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.color_nicks_in_names

    • descrizione: usa colore nick nell'output di /names (o l'elenco di nick mostrati all'ingresso di un canale)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.color_nicks_in_nicklist

    • descrizione: usa il colore del nick nella lista nick

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.color_nicks_in_server_messages

    • descrizione: usa i colori dei nick nei messaggi dal server

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.color_pv_nick_like_channel

    • descrizione: usa lo stesso colore del nick per canale e privato

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.ctcp_time_format

    • descrizione: formato dell'ora in risposta al messaggio CTCP TIME (consultare man strftime per i dettagli su data/ora)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%a, %d %b %Y %T %z"

  • irc.look.display_away

    • descrizione: mostra messaggio quando (non) si risulta assenti (off: non mostra/invia nulla, local: mostra localmente, channel: invia azioni ai canali)

    • tipo: intero

    • valori: off, local, channel

    • valore predefinito: local

  • irc.look.display_ctcp_blocked

    • descrizione: visualizza messaggio CTCP anche se bloccato

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_ctcp_reply

    • descrizione: visualizza risposta CTCP inviata da WeeChat

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_ctcp_unknown

    • descrizione: visualizza messaggio CTCP anche se è CTCP sconosciuto

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_host_join

    • descrizione: visualizza l'host nei messaggi di entrata

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_host_join_local

    • descrizione: visualizza l'host nei messaggi di entrata dal client locale

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_host_quit

    • descrizione: visualizza host nei messaggi di uscita/abbandono

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_join_message

    • descrizione: comma-separated list of messages to display after joining a channel: 324 = channel modes, 329 = channel creation date, 332 = topic, 333 = nick/date for topic, 353 = names on channel, 366 = names count

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "329,332,333,366"

  • irc.look.display_old_topic

    • descrizione: visualizza l'argomento del canale precedente quando viene cambiato

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_pv_away_once

    • descrizione: mostra il messaggio di assenza remota una sola volta in privato

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.display_pv_back

    • descrizione: mostra un messaggio in privato quando l'utente è tornato (dopo l'uscita dal server)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.highlight_channel

    • descrizione: comma separated list of words to highlight in channel buffers (case insensitive, use "(?-i)" at beginning of words to make them case sensitive; special variables $nick, $channel and $server are replaced by their value), these words are added to buffer property "highlight_words" only when buffer is created (it does not affect current buffers), an empty string disables default highlight on nick, examples: "$nick", "(?-i)$nick"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "$nick"

  • irc.look.highlight_pv

    • descrizione: comma separated list of words to highlight in private buffers (case insensitive, use "(?-i)" at beginning of words to make them case sensitive; special variables $nick, $channel and $server are replaced by their value), these words are added to buffer property "highlight_words" only when buffer is created (it does not affect current buffers), an empty string disables default highlight on nick, examples: "$nick", "(?-i)$nick"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "$nick"

  • irc.look.highlight_server

    • descrizione: comma separated list of words to highlight in server buffers (case insensitive, use "(?-i)" at beginning of words to make them case sensitive; special variables $nick, $channel and $server are replaced by their value), these words are added to buffer property "highlight_words" only when buffer is created (it does not affect current buffers), an empty string disables default highlight on nick, examples: "$nick", "(?-i)$nick"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "$nick"

  • irc.look.highlight_tags_restrict

    • descrizione: restrict highlights to these tags on irc buffers (to have highlight on user messages but not server messages); tags must be separated by a comma and "+" can be used to make a logical "and" between tags; wildcard "*" is allowed in tags; an empty value allows highlight on any tag

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "irc_privmsg,irc_notice"

  • irc.look.item_channel_modes_hide_args

    • descrizione: hide channel modes arguments if at least one of these modes is in channel modes ("*" to always hide all arguments, empty value to never hide arguments); example: "kf" to hide arguments if "k" or "f" are in channel modes

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "k"

  • irc.look.item_display_server

    • descrizione: nome dell'elemento barra dove è mostrato il server IRC (per la barra di stato)

    • tipo: intero

    • valori: buffer_plugin, buffer_name

    • valore predefinito: buffer_plugin

  • irc.look.item_nick_modes

    • descrizione: display nick modes in bar item "input_prompt"

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.item_nick_prefix

    • descrizione: display nick prefix in bar item "input_prompt"

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.join_auto_add_chantype

    • descrizione: automatically add channel type in front of channel name on command /join if the channel name does not start with a valid channel type for the server; for example: "/join weechat" will in fact send: "/join #weechat"

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.msgbuffer_fallback

    • descrizione: buffer di destinazione predefinito per le opzioni di msgbuffer quando la destinazione è privata ed il buffer privato non viene trovato

    • tipo: intero

    • valori: current, server

    • valore predefinito: current

  • irc.look.new_channel_position

    • descrizione: forza la posizione del nuovo canale nell'elenco dei buffer (none = posizione predefinita (dovrebbe essere l'ultimo buffer), next = buffer corrente + 1, near_server = dopo l'ultimo canale/privato del server)

    • tipo: intero

    • valori: none, next, near_server

    • valore predefinito: none

  • irc.look.new_pv_position

    • descrizione: forza la posizione del nuovo buffer privato nell'elenco dei buffer (none = posizione predefinita (dovrebbe essere l'ultimo buffer), next = buffer corrente + 1, near_server = dopo l'ultimo canale/privato del server)

    • tipo: intero

    • valori: none, next, near_server

    • valore predefinito: none

  • irc.look.nick_completion_smart

    • descrizione: completamento intelligente per i nick (completa il primo con gli ultimi a parlare sul canale): speakers = tutti i nick (notifiche comprese), speakers_highlight = solo i nick con le notifiche

    • tipo: intero

    • valori: off, speakers, speakers_highlights

    • valore predefinito: speakers

  • irc.look.nick_mode

    • descrizione: display nick mode (op, voice, ...) before nick (none = never, prefix = in prefix only (default), action = in action messages only, both = prefix + action messages)

    • tipo: intero

    • valori: none, prefix, action, both

    • valore predefinito: prefix

  • irc.look.nick_mode_empty

    • descrizione: display a space if nick mode is enabled but nick has no mode (not op, voice, ...)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.nicks_hide_password

    • descrizione: comma separated list of nicks for which passwords will be hidden when a message is sent, for example to hide password in message displayed by "/msg nickserv identify password", example: "nickserv,nickbot"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "nickserv"

  • irc.look.notice_as_pv

    • descrizione: visualizza notifiche come messaggi privati (se automatico, usa il buffer privato se viene trovato)

    • tipo: intero

    • valori: auto, never, always

    • valore predefinito: auto

  • irc.look.notice_welcome_redirect

    • descrizione: automatically redirect channel welcome notices to the channel buffer; such notices have the nick as target but a channel name in beginning of notice message, for example notices sent by freenode server which look like: "[#channel] Welcome to this channel..."

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.notice_welcome_tags

    • descrizione: comma separated list of tags used in a welcome notices redirected to a channel, for example: "notify_private"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.look.notify_tags_ison

    • descrizione: comma separated list of tags used in messages displayed by notify when a nick joins or quits server (result of command ison or monitor), for example: "notify_message", "notify_private" or "notify_highlight"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "notify_message"

  • irc.look.notify_tags_whois

    • descrizione: elenco separato da virgole di tag usati nei messaggi stampati dalle notifiche quando un nick cambia lo stato di assenza (risultato del comando whois), ad esempio: "notify_message", "notify_private" o "notify_highlight"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "notify_message"

  • irc.look.part_closes_buffer

    • descrizione: chiude buffer quando viene digitato /part nel canale

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.pv_buffer

    • descrizione: unisci i buffer privati

    • tipo: intero

    • valori: independent, merge_by_server, merge_all

    • valore predefinito: independent

  • irc.look.pv_tags

    • descrizione: elenco separato da virgole di tag usati nei messaggi privati, ad esempio: "notify_message", "notify_private" o "notify_highlight"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "notify_private"

  • irc.look.raw_messages

    • descrizione: numero di messaggi raw da salvare in memoria quando il buffer dei dati raw viene chiuso (i messaggi verranno visualizzati all'apertura del buffer dei dati raw)

    • tipo: intero

    • valori: 0 .. 65535

    • valore predefinito: 256

  • irc.look.server_buffer

    • descrizione: unisci i buffer dei server

    • tipo: intero

    • valori: merge_with_core, merge_without_core, independent

    • valore predefinito: merge_with_core

  • irc.look.smart_filter

    • descrizione: filtra i messaggi di entrata/uscita/abbandono/utente per un nick se inattivo per alcuni minuti sul canale (è necessario creare un filtro sul tag "irc_smart_filter")

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.smart_filter_delay

    • descrizione: delay for filtering join/part/quit messages (in minutes): if the nick did not speak during the last N minutes, the join/part/quit is filtered

    • tipo: intero

    • valori: 1 .. 10080

    • valore predefinito: 5

  • irc.look.smart_filter_join

    • descrizione: abilita filtro smart per i messaggi "join" (entrata)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.smart_filter_join_unmask

    • descrizione: delay for unmasking a join message that was filtered with tag "irc_smart_filter" (in minutes): if a nick has joined max N minutes ago and then says something on channel (message, notice or update on topic), the join is unmasked, as well as nick changes after this join (0 = disable: never unmask a join)

    • tipo: intero

    • valori: 0 .. 10080

    • valore predefinito: 30

  • irc.look.smart_filter_mode

    • descrizione: enable smart filter for "mode" messages: "*" to filter all modes, "+" to filter all modes in server prefixes (for example "ovh"), "xyz" to filter only modes x/y/z, "-xyz" to filter all modes but not x/y/z; examples: "ovh": filter modes o/v/h, "-bkl": filter all modes but not b/k/l

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""+

  • irc.look.smart_filter_nick

    • descrizione: abilita filtro smart per i messaggi "nick" (cambio nick)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.smart_filter_quit

    • descrizione: abilita filtro smart per i messaggi "part" (uscita) e "quit (disconnessione)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.look.temporary_servers

    • descrizione: enable automatic addition of temporary servers with command /connect

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.look.topic_strip_colors

    • descrizione: elimina colori nell'argomento (usato solo quando mostrato il titolo del buffer)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.network.autoreconnect_delay_growing

    • descrizione: fattore di crescita per il ritardo della riconnessione automatica al server (1 = sempre identico, 2 = ritardo*2 per ogni tentativo, ...)

    • tipo: intero

    • valori: 1 .. 100

    • valore predefinito: 2

  • irc.network.autoreconnect_delay_max

    • descrizione: ritardo massimo per la riconnessione automatica al server (in secondi, 0 = nessun massimo)

    • tipo: intero

    • valori: 0 .. 604800

    • valore predefinito: 600

  • irc.network.ban_mask_default

    • descrizione: default ban mask for commands /ban, /unban and /kickban; variables $nick, $user, $ident and $host are replaced by their values (extracted from "nick!user@host"); $ident is the same as $user if $user does not start with "~", otherwise it is set to "*"; this default mask is used only if WeeChat knows the host for the nick

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "*!$ident@$host"

  • irc.network.channel_encode

    • descrizione: decode/encode channel name inside messages using charset options; it is recommended to keep that off if you use only UTF-8 in channel names; you can enable this option if you are using an exotic charset like ISO in channel names

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.network.colors_receive

    • descrizione: se disabilitato, i codici colori vengono ignorati nei messaggi in entrata

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.network.colors_send

    • descrizione: allow user to send colors with special codes (ctrl-c + a code and optional color: b=bold, cxx=color, cxx,yy=color+background, i=italic, o=disable color/attributes, r=reverse, u=underline)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.network.lag_check

    • descrizione: intervallo tra due controlli per il ritardo (in secondi, 0 = nessun controllo)

    • tipo: intero

    • valori: 0 .. 604800

    • valore predefinito: 60

  • irc.network.lag_max

    • descrizione: maximum lag (in seconds): if this lag is reached, WeeChat will consider that the answer from server (pong) will never be received and will give up counting the lag (0 = never give up)

    • tipo: intero

    • valori: 0 .. 604800

    • valore predefinito: 1800

  • irc.network.lag_min_show

    • descrizione: ritardo minimo da visualizzare (in millisecondi)

    • tipo: intero

    • valori: 0 .. 86400000

    • valore predefinito: 500

  • irc.network.lag_reconnect

    • descrizione: reconnect to server if lag is greater than or equal to this value (in seconds, 0 = never reconnect); this value must be less than or equal to irc.network.lag_max

    • tipo: intero

    • valori: 0 .. 604800

    • valore predefinito: 300

  • irc.network.lag_refresh_interval

    • descrizione: intervallo tra due aggiornamenti per l'elemento ritardo, quando è in aumento (in secondi)

    • tipo: intero

    • valori: 1 .. 3600

    • valore predefinito: 1

  • irc.network.notify_check_ison

    • descrizione: intervallo tra due verifiche per la notifica con il comando IRC "ison" (in minuti)

    • tipo: intero

    • valori: 1 .. 10080

    • valore predefinito: 1

  • irc.network.notify_check_whois

    • descrizione: intervallo tra due verifiche per la notifica con il comando IRC "whois" (in minuti)

    • tipo: intero

    • valori: 1 .. 10080

    • valore predefinito: 5

  • irc.network.sasl_fail_unavailable

    • descrizione: cause SASL authentication failure when SASL is requested but unavailable on the server; when this option is enabled, it has effect only if option "sasl_fail" is set to "reconnect" or "disconnect" in the server

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.network.send_unknown_commands

    • descrizione: invia comandi sconosciuti al server

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.network.whois_double_nick

    • descrizione: double the nick in /whois command (if only one nick is given), to get idle time in answer; for example: "/whois nick" will send "whois nick nick"

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.server_default.addresses

    • descrizione: list of hostname/port or IP/port for server (separated by comma) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.anti_flood_prio_high

    • descrizione: anti-flood per coda ad alta priorità: numero di secondi tra due messaggi utente o comandi inviati al server IRC (0 = nessun anti-flood)

    • tipo: intero

    • valori: 0 .. 60

    • valore predefinito: 2

  • irc.server_default.anti_flood_prio_low

    • descrizione: anti-flood per coda a bassa priorità: numero di secondi tra due messaggi inviati al server IRC (messaggi come risposte CTCP automatiche) (0 = nessun anti-flood)

    • tipo: intero

    • valori: 0 .. 60

    • valore predefinito: 2

  • irc.server_default.autoconnect

    • descrizione: connette automaticamente ai server all'avvio di WeeChat

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.server_default.autojoin

    • descrizione: comma separated list of channels to join after connection to server (and after executing command + delay if they are set); the channels that require a key must be at beginning of the list, and all the keys must be given after the channels (separated by a space) (example: "#channel1,#channel2,#channel3 key1,key2" where #channel1 and #channel2 are protected by key1 and key2) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.autoreconnect

    • descrizione: riconnette automaticamente al server alla disconnessione

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.server_default.autoreconnect_delay

    • descrizione: ritardo (in secondi) prima di riprovare a riconnettersi al server

    • tipo: intero

    • valori: 1 .. 65535

    • valore predefinito: 10

  • irc.server_default.autorejoin

    • descrizione: automatically rejoin channels after kick; you can define a buffer local variable on a channel to override this value (name of variable: "autorejoin", value: "on" or "off")

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.server_default.autorejoin_delay

    • descrizione: ritardo (in secondi) prima di rientrare automaticamente (dopo il kick)

    • tipo: intero

    • valori: 0 .. 86400

    • valore predefinito: 30

  • irc.server_default.away_check

    • descrizione: intervallo tra le due verifiche per l'assenza (in minuti, 0 = nessun check)

    • tipo: intero

    • valori: 0 .. 10080

    • valore predefinito: 0

  • irc.server_default.away_check_max_nicks

    • descrizione: non verificare l'assenza su canali con un elevato numero di nick (0 = illimitato)

    • tipo: intero

    • valori: 0 .. 1000000

    • valore predefinito: 25

  • irc.server_default.capabilities

    • descrizione: comma-separated list of client capabilities to enable for server if they are available (see /help cap for a list of capabilities supported by WeeChat) (example: "away-notify,multi-prefix")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.command

    • descrizione: command(s) to run after connection to server and before auto-join of channels (many commands can be separated by ";", use "\;" for a semicolon, special variables $nick, $channel and $server are replaced by their value) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.command_delay

    • descrizione: delay (in seconds) after execution of command and before auto-join of channels (example: give some time for authentication before joining channels)

    • tipo: intero

    • valori: 0 .. 3600

    • valore predefinito: 0

  • irc.server_default.connection_timeout

    • descrizione: timeout (in secondi) tra la connessione TCP al server ed il messaggio 001 ricevuto, se questo timeout viene raggiunto prima della ricezione del messaggio 001, WeeChat effettuerà la disconnessione

    • tipo: intero

    • valori: 1 .. 3600

    • valore predefinito: 60

  • irc.server_default.ipv6

    • descrizione: usa il protocollo IPv6 per le comunicazioni con il server (prova con IPv6, se non disponibile usa IPv4); se disabilitato, viene usato solo IPv4

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.server_default.local_hostname

    • descrizione: nome host/IP locale definito per il server (opzionale, se vuoto viene usato il nome host locale)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.msg_kick

    • descrizione: default kick message used by commands "/kick" and "/kickban" (note: content is evaluated, see /help eval; special variables ${nick}, ${channel} and ${server} are replaced by their value)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.msg_part

    • descrizione: default part message (leaving channel) (note: content is evaluated, see /help eval; special variables ${nick}, ${channel} and ${server} are replaced by their value; "%v" is replaced by WeeChat version if there is no ${...} in string)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "WeeChat ${info:version}"

  • irc.server_default.msg_quit

    • descrizione: default quit message (disconnecting from server) (note: content is evaluated, see /help eval; special variables ${nick}, ${channel} and ${server} are replaced by their value; "%v" is replaced by WeeChat version if there is no ${...} in string)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "WeeChat ${info:version}"

  • irc.server_default.nicks

    • descrizione: nicknames to use on server (separated by comma) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.nicks_alternate

    • descrizione: get an alternate nick when all the declared nicks are already used on server: add some "_" until the nick has a length of 9, and then replace last char (or the two last chars) by a number from 1 to 99, until we find a nick not used on server

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.server_default.notify

    • descrizione: elenco notifiche per il server (si consiglia di non cambiare questa opzione ma di usare il comando /notify)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.password

    • descrizione: password per il server (nota: il contenuto viene valutato, consultare /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.proxy

    • descrizione: nome del proxy usato per questo server (opzionale, il proxy deve essere definito con il comando /proxy)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.realname

    • descrizione: real name to use on server (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.sasl_fail

    • descrizione: action to perform if SASL authentication fails: "continue" to ignore the authentication problem, "reconnect" to schedule a reconnection to the server, "disconnect" to disconnect from server (see also option irc.network.sasl_fail_unavailable)

    • tipo: intero

    • valori: continue, reconnect, disconnect

    • valore predefinito: continue

  • irc.server_default.sasl_key

    • descrizione: file with ECC private key for mechanism "ecdsa-nist256p-challenge" ("%h" will be replaced by WeeChat home, "~/.weechat" by default)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.sasl_mechanism

    • descrizione: mechanism for SASL authentication: "plain" for plain text password, "ecdsa-nist256p-challenge" for key-based challenge authentication, "external" for authentication using client side SSL cert, "dh-blowfish" for blowfish crypted password (insecure, not recommended), "dh-aes" for AES crypted password (insecure, not recommended)

    • tipo: intero

    • valori: plain, ecdsa-nist256p-challenge, external, dh-blowfish, dh-aes

    • valore predefinito: plain

  • irc.server_default.sasl_password

    • descrizione: password for SASL authentication; this option is not used for mechanisms "ecdsa-nist256p-challenge" and "external" (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.sasl_timeout

    • descrizione: timeout (in secondi) prima di annullare l'autenticazione SASL

    • tipo: intero

    • valori: 1 .. 3600

    • valore predefinito: 15

  • irc.server_default.sasl_username

    • descrizione: username for SASL authentication; this option is not used for mechanism "external" (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.ssl

    • descrizione: usa SSL per le comunicazioni col server

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • irc.server_default.ssl_cert

    • descrizione: file del certificato SSL usato per identificare automaticamente il proprio nick ("%h" sarà sostituito dalla home di WeeChat, "~/.weechat come predefinita)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.ssl_dhkey_size

    • descrizione: dimensione della chiave usata durante lo Scambio Chiavi Diffie-Hellman

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 2048

  • irc.server_default.ssl_fingerprint

    • descrizione: fingerprint of certificate which is trusted and accepted for the server; only hexadecimal digits are allowed (0-9, a-f): 64 chars for SHA-512, 32 chars for SHA-256, 20 chars for SHA-1 (insecure, not recommended); many fingerprints can be separated by commas; if this option is set, the other checks on certificates are NOT performed (option "ssl_verify") (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.ssl_priorities

    • descrizione: stringa con le priorità per gnutls (per la sintassi, consultare la documentazione per la funzione gnutls_priority_init nel manuale di gnutls, stringhe comuni sono: "PERFORMANCE", "NORMAL", "SECURE128", "SECURE256", "EXPORT", "NONE")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "NORMAL:-VERS-SSL3.0"

  • irc.server_default.ssl_verify

    • descrizione: verifica che la connessione SSL sia totalmente fidata

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • irc.server_default.usermode

    • descrizione: user mode(s) to set after connection to server and before executing command and the auto-join of channels; examples: "+R" (to set mode "R"), "+R-i" (to set mode "R" and remove "i"); see /help mode for the complete mode syntax (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • irc.server_default.username

    • descrizione: user name to use on server (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

4.6.3. Comandi

  • admin: trova informazioni sull’amministratore del server

/admin  [<destinazione>]

destinazione: nome server
  • allchan: esegue un comando su tutti i canali di tutti i server connessi

/allchan  [-current] [-exclude=<canale>[,<canale>...]] <comando> [<argomenti>]

 -current: execute command for channels of current server only
 -exclude: exclude some channels (wildcard "*" is allowed)
  command: command to execute
arguments: arguments for command (special variables $nick, $channel and $server are replaced by their value)

Examples:
  execute '/me is testing' on all channels:
    /allchan me is testing
  say 'hello' everywhere but not on #weechat:
    /allchan -exclude=#weechat msg * hello
  say 'hello' everywhere but not on #weechat and channels beginning with #linux:
    /allchan -exclude=#weechat,#linux* msg * hello
  • allpv: execute a command on all private buffers of all connected servers

/allpv  [-current] [-exclude=<nick>[,<nick>...]] <command> [<arguments>]

 -current: execute command for private buffers of current server only
 -exclude: exclude some nicks (wildcard "*" is allowed)
  command: command to execute
arguments: arguments for command (special variables $nick, $channel and $server are replaced by their value)

Examples:
  execute '/me is testing' on all private buffers:
    /allpv me is testing
  say 'hello' everywhere but not for nick foo:
    /allpv -exclude=foo msg * hello
  say 'hello' everywhere but not for nick foo and nicks beginning with bar:
    /allpv -exclude=foo,bar* msg * hello
  close all private buffers:
    /allpv close
  • allserv: esegue un comando su tutti i server connessi

/allserv  [-exclude=<server>[,<server>...]] <comando> [<argomenti>]

 -exclude: exclude some servers (wildcard "*" is allowed)
  command: command to execute
arguments: arguments for command (special variables $nick, $channel and $server are replaced by their value)

Examples:
  change nick on all servers:
    /allserv nick newnick
  set away on all servers:
    /allserv away I'm away
  do a whois on my nick on all servers:
    /allserv whois $nick
  • ban: banna nick oppure host

/ban  [<canale>] [<nick> [<nick>...]]

channel: channel name
   nick: nick or host

Without argument, this command displays the ban list for current channel.
  • cap: client capability negotiation

/cap  ls
      list
      req|ack [<capability> [<capability>...]]
      end

   ls: list the capabilities supported by the server
 list: list the capabilities currently enabled
  req: request a capability
  ack: acknowledge capabilities which require client-side acknowledgement
  end: end the capability negotiation

Without argument, "ls" and "list" are sent.

Capabilities supported by WeeChat are: account-notify, away-notify, cap-notify, extended-join, multi-prefix, server-time, userhost-in-names.

The capabilities to automatically enable on servers can be set in option irc.server_default.capabilities (or by server in option irc.server.xxx.capabilities).

Examples:
   /cap
   /cap req multi-prefix away-notify
  • connect: connette ad uno o più server IRC

/connect  <server> [<server>...] [-<opzione>[=<valore>]] [-no<option>] [-nojoin] [-switch]
          -all|-auto|-open [-nojoin] [-switch]

    server: server name, which can be:
            - internal server name (added by /server add, recommended usage)
            - hostname/port or IP/port, port is 6667 by default
            - URL with format: irc[6][s]://[nickname[:password]@]irc.example.org[:port][/#channel1][,#channel2[...]]
            Note: for an address/IP/URL, a temporary server is added (NOT SAVED), see /help irc.look.temporary_servers
    option: set option for server (for boolean option, value can be omitted)
  nooption: set boolean option to 'off' (for example: -nossl)
      -all: connect to all servers defined in configuration
     -auto: connect to servers with autoconnect enabled
     -open: connect to all opened servers that are not currently connected
   -nojoin: do not join any channel (even if autojoin is enabled on server)
   -switch: switch to next server address

To disconnect from a server or stop any connection attempt, use command /disconnect.

Examples:
  /connect freenode
  /connect irc.oftc.net/6667
  /connect irc6.oftc.net/6667 -ipv6
  /connect irc6.oftc.net/6697 -ipv6 -ssl
  /connect my.server.org/6697 -ssl -password=test
  /connect irc://nick@irc.oftc.net/#channel
  /connect -switch
  • ctcp: invia un messaggio CTCP (Protocollo Client-A-Client)

/ctcp  [-server <server>] <target>[,<target>...] <type> [<arguments>]

   server: send to this server (internal name)
   target: nick or channel ('*' = current channel)
     type: CTCP type (examples: "version", "ping", ..)
arguments: arguments for CTCP

Examples:
  /ctcp toto time
  /ctcp toto version
  /ctcp * version
  • cycle: esce e rienta in un canale

/cycle  [<canale>[,<canale>...]] [<messaggio>]

channel: channel name
message: part message (displayed to other users)
  • dcc: avvia una DCC (trasferimento file o chat diretta)

/dcc  chat <nick>
      send <nick> <file>

nick: nick
file: filename (on local host)

Examples:
  chat with nick "toto":
    /dcc chat toto
  send file "/home/foo/bar.txt" to nick "toto":
    /dcc send toto /home/foo/bar.txt
  • dehalfop: revoca lo stato di half-op del canale da uno o più nick

/dehalfop  <nick> [<nick>...]

nick: nick or mask (wildcard "*" is allowed)
   *: remove channel half-operator status from everybody on channel except yourself
  • deop: revoca lo stato di operatore del canale da uno o più nick

/deop  <nick> [<nick>...]
       * -yes

nick: nick or mask (wildcard "*" is allowed)
   *: remove channel operator status from everybody on channel except yourself
  • devoice: revoca il voice da uno o più nick

/devoice  <nick> [<nick>...]
          * -yes

nick: nick or mask (wildcard "*" is allowed)
   *: remove voice from everybody on channel
  • die: arresta il server

/die  [<destinazione>]

destinazione: nome server
  • disconnect: disconnette da uno o tutti i server IRC

/disconnect  [<server>|-all|-pending [<motivo>]]

  server: internal server name
    -all: disconnect from all servers
-pending: cancel auto-reconnection on servers currently reconnecting
  reason: reason for the "quit"
  • halfop: concede lo stato di half-op del canale ad uno o più nick

/halfop  <nick> [<nick>...]
         * -yes

nick: nick or mask (wildcard "*" is allowed)
   *: give channel half-operator status to everybody on channel
  • ignore: ignora nick/host dai server o dai canali

/ignore  list
         add [re:]<nick> [<server> [<canale>]]
         del <numero>|-all

     list: list all ignores
      add: add an ignore
     nick: nick or hostname (can be a POSIX extended regular expression if "re:" is given or a mask using "*" to replace zero or more chars)
      del: delete an ignore
   number: number of ignore to delete (look at list to find it)
     -all: delete all ignores
   server: internal server name where ignore is working
  channel: channel name where ignore is working

Note: the regular expression can start with "(?-i)" to become case sensitive.

Examples:
  ignore nick "toto" everywhere:
    /ignore add toto
  ignore host "toto@domain.com" on freenode server:
    /ignore add toto@domain.com freenode
  ignore host "toto*@*.domain.com" on freenode/#weechat:
    /ignore add toto*@*.domain.com freenode #weechat
  • info: ottieni informazioni sul server

/info  [<destinazione>]

destinazione: nome server
  • invite: invita un nick su un canale

/invite  <nick> [<nick>...] [<canale>]

  nick: nick
canale: nome del canale
  • ison: verifica se un nick è collegato IRC

/ison  <nick> [<nick>...]

nick: nick
  • join: entra in un canale

/join  [-noswitch] [-server <server>] [<canale1>[,<canale2>...]] [<chiave1>[,<chiave2>...]]

-noswitch: non passare al nuovo buffer
   server: invia a questo server (nome interno)
   canale: nome del canale in cui entrare
   chiave: chiave per entrare nel canale (i canali con una chiave devono essere primi nella lista)

Esempi:
  /join #weechat
  /join #canaleprotetto,#weechat chiave
  /join -server freenode #weechat
  /join -noswitch #weechat
  • kick: kick a user out of a channel

/kick  [<canale>] <nick> [<motivo>]

channel: channel name
   nick: nick
 reason: reason (special variables $nick, $channel and $server are replaced by their value)
  • kickban: kick a user out of a channel and ban the host

/kickban  [<canale>] <nick> [<motivo>]

channel: channel name
   nick: nick
 reason: reason (special variables $nick, $channel and $server are replaced by their value)

It is possible to kick/ban with a mask, nick will be extracted from mask and replaced by "*".

Example:
  ban "*!*@host.com" and then kick "toto":
    /kickban toto!*@host.com
  • kill: chiude connessione client-server

/kill  <nick> [<reason>]

  nick: nick
motivo: motivo
/links  [[<server>] <mask_server>]

     server: questo server dovrebbe rispondere alla richiesta
mask_server: elenco dei server che devono corrispondere a questa mask
  • list: elenca i canali ed i loro argomenti

/list  [<canale>[,<canale>...]] [<server>] [-re <regexp>]

channel: channel to list
 server: server name
  regex: POSIX extended regular expression used to filter results (case insensitive, can start by "(?-i)" to become case sensitive)

Examples:
  list all channels on server (can be very slow on large networks):
    /list
  list channel #weechat:
    /list #weechat
  list all channels beginning with "#weechat" (can be very slow on large networks):
    /list -re #weechat.*
  • lusers: ottiene statistiche sulla dimensione del network IRC

/lusers  [<mask> [<destinazione>]]

        mask: server corrispondenti alla mask
destinazione: server per redirigere la richiesta
  • map: mostra una mappa grafica della rete IRC


  • me: invia un’azione CTCP al canale corrente

/me  <messaggio>

messaggio: messaggio da inviare
  • mode: cambia modalità canale o utente

/mode  [<canale>] [+|-]o|p|s|i|t|n|m|l|b|e|v|k [<arguments>]
       <nick> [+|-]i|s|w|o

modalità canale:
  canale: nome canale da modificare (quello attivo è il predefinito)
  o: concede/revoca i privilegi di operatore del canale
  p: flag: canale privato
  s: flag: canale segreto
  i: flag: canale a solo invito
  t: flag: argomento modificabile solo dall'operatore del canale
  n: nessun messaggio al canale da client esterni
  m: canale moderato
  l: imposta il limite massimo di utenti sul canale
  b: imposta un mask ban per tenere alla larga agli utenti
  e: imposta mask di eccezione
  v: concede/nega la possibilità di parlare su un canale moderato
  k: imposta una chiave per il canale (password)
modalità utente:
  nick: nick da modificare
  i: marca un utente come invisibile
  s: marca un utente per la ricezione dei messaggi dal server
  w: l'utente riceve wallops
  o: flag: operatore

L'elenco delle modalità non è completa, è necessario leggere la documentazione del server per tutte le modalità disponibili.

Esempi:
  protegge l'argomento sul canale #weechat:
    /mode #weechat +t
  diventa invisibile sul server:
    /mode nick +i
  • motd: riceve il "Messaggio Del Giorno"

/motd  [<destinazione>]

destinazione: nome server
  • msg: invia un messaggio ad un nick o a un canale

/msg  [-server <server>] <destinazione>[,<destinazione>...] <testo>

      server: invia a questo server (nome interno)
destinazione: nick o canale (può essere una mask, '*' = canale corrente)
       testo: testo da inviare
  • names: elenca i nick sul canale

/names  [<canale>[,<canale>...]]

canale: nome canale
  • nick: cambia il nick corrente

/nick  [-all] <nick>

-all: imposta nuovo nick per tutti i server connessi
nick: nuovo nick
  • notice: invia messaggio di notifica all’utente

/notice  [-server <server>] <destinazione> <testo>

server: send to this server (internal name)
target: nick or channel name
  text: text to send
  • notify: aggiunge una notifica per lo stato di presenza o assenza dei nick sui server

/notify  add <nick> [<server> [-away]]
         del <nick>|-all [<server>]

   add: aggiunge una notifica
  nick: nick
server: nome interno del server (server corrente è il predefinito)
 -away: notifica quando il messaggio di assenza viene cambiato (effettuando il whois sul nick)
   del: elimina una notifica
  -all: elimina tutte le notifiche

Senza argomenti, questo comando mostra le notifiche per il server corrente (oppure tutti i server se il comando viene digitato sul buffer core).

Esempi:
  notifica quando "tizio" entra/esce dal server corrente:
    /notify add tizio
  notifica quando "tizio" entra/esce dal server freenode:
    /notify add toto freenode
  notifica quando "tizio" è assente o presente sul server freenode:
    /notify add toto freenode -away
  • op: concede lo stato di operatore del canale ad uno o più nick

/op  <nick> [<nick>...]
     * -yes

nick: nick or mask (wildcard "*" is allowed)
   *: give channel operator status to everybody on channel
  • oper: ottiene i privilegi di operatore

/oper  <utente> <password>

    user: utente
password: password
  • part: esce da un canale

/part  [<canale>[,<canale>...]] [<messaggio>]

   canale: nome del canale da lasciare
messaggio: messaggio di uscita (mostrato agli altri utenti)
  • ping: invia un ping al server

/ping  <server1> [<server2>]

server1: server su cui effettuare il ping
server2: reindirizza il ping a questo server
  • pong: risponde ad un messaggio ping

/pong  <demone> [<demone2>]

 demone: demone che ha risposto al messaggio di Ping
demone2: reindirizza messaggio a questo demone
  • query: invia un messaggio privato ad un nick

/query  [-noswitch] [-server <server>] <nick>[,<nick>...] [<text>]

-noswitch: do not switch to new buffer
   server: send to this server (internal name)
     nick: nick
     text: text to send
  • quiet: fa tacere nick o host

/quiet  [<canale>] [<nick> [<nick>...]]

channel: channel name
   nick: nick or host

Without argument, this command displays the quiet list for current channel.
  • quote: invia dati grezzi al server senza analisi

/quote  [-server <server>] <dati>

server: invia a questo server (nome interno)
  dati: dati raw da inviare
  • reconnect: riconnette a uno o più server

/reconnect  <server> [<server>...] [-nojoin] [-switch]
            -all [-nojoin] [-switch]

 server: server to reconnect (internal name)
   -all: reconnect to all servers
-nojoin: do not join any channel (even if autojoin is enabled on server)
-switch: switch to next server address
  • rehash: chiede al server di ricaricare il proprio file di configurazione

/rehash  [<opzione>]

opzione: opzione extra, per alcuni server
  • remove: force a user to leave a channel

/remove  [<canale>] <nick> [<motivo>]

channel: channel name
   nick: nick
 reason: reason (special variables $nick, $channel and $server are replaced by their value)
  • restart: chiede al server di riavviarsi

/restart  [<destinazione>]

destinazione: nome server
  • sajoin: forza un utente ad entrare su uno o più canali

/sajoin  <nick> <canale>[,<canale>...]

  nick: nick
canale: nome del canale
  • samode: cambia modalità sul canale, senza avere lo status di operatore

/samode  [<channel>] <mode>

  canale: nome del canale
modalità: modalità per il canale
  • sanick: forza un utente ad usare un altro nick

/sanick  <nick> <nuovo_nick>

      nick: nick
nuovo_nick: nuovo nick
  • sapart: forza un utente a lasciare uno o più canali

/sapart  <nick> <canale>[,<canale>...]

  nick: nick
canale: nome del canale
  • saquit: forza un utente ad abbandonare il server con un motivo

/saquit  <nick> <motivo>

  nick: nick
motivo: motivo
  • server: elenca, aggiunge o rimuove server IRC

/server  list|listfull [<server>]
         add <server> <hostname>[/<port>] [-temp] [-<option>[=<value>]] [-no<option>]
         copy|rename <server> <new_name>
         reorder <server> [<server>...]
         del|keep <server>
         deloutq|jump|raw

    list: list servers (without argument, this list is displayed)
listfull: list servers with detailed info for each server
     add: add a new server
  server: server name, for internal and display use
hostname: name or IP address of server, with optional port (default: 6667), many addresses can be separated by a comma
   -temp: add a temporary server (not saved)
  option: set option for server (for boolean option, value can be omitted)
nooption: set boolean option to 'off' (for example: -nossl)
    copy: duplicate a server
  rename: rename a server
 reorder: reorder list of servers
    keep: keep server in config file (for temporary servers only)
     del: delete a server
 deloutq: delete messages out queue for all servers (all messages WeeChat is currently sending)
    jump: jump to server buffer
     raw: open buffer with raw IRC data

Examples:
  /server listfull
  /server add freenode chat.freenode.net
  /server add freenode chat.freenode.net/6697 -ssl -autoconnect
  /server add chatspike irc.chatspike.net/6667,irc.duckspike.net/6667
  /server copy freenode freenode-test
  /server rename freenode-test freenode2
  /server reorder freenode2 freenode
  /server del freenode
  /server deloutq
  • service: registra un nuovo servizio

/service  <nick> <riservato> <distribuzione> <tipo> <riservato> <info>

distrubuzione: visibilità del servizio
         tipo: riservato per un uso futuro
  • servlist: elenca servizi attualmente connessi al network

/servlist  [<mask> [<tipo>]]

mask: elenca solo i servizi che corrispondono a questa mask
tipo: elenca solo i servizi di questo tipo
  • squery: invia un messaggio ad un servizio

/squery  <servizio> <testo>

servizio: nome del servizio
   testo: testo da inviare
  • squit: disconnette collegamenti al server

/squit  <server> <commento>

 server: server name
comment: comment
  • stats: richiede statistiche sul server

/stats  [<query> [<server>]]

 query: c/h/i/k/l/m/o/y/u (per info RFC1459)
server: nome server
  • summon: invia agli utenti connessi ad un host con un server IRC in esecuzione un messaggio per invitarli ad entrare su IRC

/summon  <utente> [<destinazione> [<canale>]]

      utente: nome utente
destinazione: nome server
      canale: nome canale
  • time: richiede l’ora locale dal server

/time  [<destinazione>]

destinazione: richiede l'ora dal server specificato
  • topic: legge/modifica argomento del canale

/topic  <[canale>] [<argomento>|delete]

channel: channel name
  topic: new topic
-delete: delete channel topic
  • trace: trova il path del server specifico

/trace  [<destinazione>]

destinazione: nome server
  • unban: rimuove il ban da nick o host

/unban  [<canale>] <nick> [<nick>...]

channel: channel name
   nick: nick or host
  • unquiet: unquiet nicks or hosts

/unquiet  [<canale>] <nick> [<nick>...]

channel: channel name
   nick: nick or host
  • userhost: restituisce un elenco di informazioni sui nick

/userhost  <nick> [<nick>...]

nick: nick
  • users: lista di utenti autenticati sul server

/users  [<destinazione>]

destinazione: nome server
  • version: riceve informazioni di versione del nick o del server (corrente o specificato)

/version  [<server>|<nick>]

server: nome server
  nick: nick
  • voice: concede il voice ad uno o più utenti

/voice  <nick> [<nick>...]

nick: nick or mask (wildcard "*" is allowed)
   *: give voice to everybody on channel
  • wallchops: invia una notifica agli operatori del canale

/wallchops  [<canale>] <testo>

canale: nome del canale
 testo: testo da inviare
  • wallops: invia un messaggio a tutti gli utenti attualmente connessi che hanno impostato la modalità 'w'

/wallops  <testo>

testo: testo da inviare
  • who: genera una richiesta per ottenere una lista di informazioni

/who  [<mask> [o]]

mask: solo l'informazione corrispondente al mask
   o: vengono restituiti solo gli operatori in base alla mask fornita
  • whois: richiedi informazioni su uno o più utenti

/whois  [<server>] [<nick>[,<nick>...]]

server: server name
  nick: nick (may be a mask)

Without argument, this command will do a whois on:
- your own nick if buffer is a server/channel
- remote nick if buffer is a private.

If option irc.network.whois_double_nick is enabled, two nicks are sent (if only one nick is given), to get idle time in answer.
  • whowas: richiede informazioni su un nick non più esistente

/whowas  <nick>[,<nick>...] [<count> [<destinazione>]]

  nick: nick
 count: number of replies to return (full search if negative number)
target: reply should match this mask

4.6.4. Certificati SSL

Al momento della connessione al server IRC con SSL, WeeChat verifica in maniera predefinita che la connessione sia completamente fidata.

Esistono alcune opzioni per controllare la connessione SSL:

weechat.network.gnutls_ca_file

path del file con il certificato delle autorità (predefinito: "%h/ssl/CAs.pem")

irc.server.xxx.ssl_cert

file del certificato SSL usato per identificare automaticamente il proprio nick ad esempio CertFP su oftc (a seguire)

irc.server.xxx.ssl_dhkey_size

dimensione della chiave usata durante lo Scambio Chiavi Diffie-Hellman (predefinita; 2048)

irc.server.xxx.ssl_verify

verifica che la connessione SSL sia totalmente fidata (opzione attivata in maniera predefinita)

L’opzione "ssl_verify" è attivata per default, in questo modo la verifica è rigorosa e potrebbe fallire, anche se funziona senza problemi con versioni precedenti la 0.3.1.
Primo esempio: connessione a otfc e verifica del certificato
  • Importare certificati nella shell:

$ mkdir -p ~/.weechat/ssl
$ wget -O ~/.weechat/ssl/CAs.pem http://www.spi-inc.org/ca/spi-cacert.crt
E possibile concatenare più certificati nel file CAs.pem.
  • In WeeChat, with "oftc" server already added:

/connect oftc
Secondo esempio: connessione a otfc con CertFP
  • Creare un certificato nella shell:

$ mkdir -p ~/.weechat/ssl
$ cd ~/.weechat/ssl
$ openssl req -nodes -newkey rsa:2048 -keyout nick.pem -x509 -days 365 -out nick.pem
  • In WeeChat, with "oftc" server already added:

/set irc.server.oftc.ssl_cert "%h/ssl/nick.pem"
/connect oftc
/msg nickserv cert add

Per maggiori informazioni consultare http://www.oftc.net/oftc/NickServ/CertFP

4.6.5. Autenticazione SASL

WeeChat supports SASL authentication, using different mechanisms:

  • plain: password in chiaro (default)

  • ecdsa-nist256p-challenge: challenge with public/private key

  • external: certificato SSL da lato client

  • dh-blowfish: blowfish encrypted password (insecure, not recommended)

  • dh-aes: AES encrypted password (insecure, not recommended)

La libreria "gcrypt" è richiesta per compilare WeeChat al fine di usare il meccanismo "dh-blowfish" (consultare dipendenze).

Le opzioni nel server sono:

  • sasl_mechanism: meccanismo da usare (see above)

  • sasl_timeout: timeout (in secondi) per l’autenticazione

  • sasl_fail: action to perform if authentication fails

  • sasl_username: nome utente (nick)

  • sasl_password: password

  • sasl_key: file with ECc private key (for mechanism ecdsa-nist256p-challenge)

SASL ECDSA-NIST256P-CHALLENGE

You must generate a private key in order to authentify with the ECDSA-NIST256P-CHALLENGE mechanism (no password is required on connection).

You can generate the key with this command:

$ openssl ecparam -genkey -name prime256v1 >~/.weechat/ecdsa.pem

Get the public key (encoded as base64) with this command:

$ openssl ec -noout -text -conv_form compressed -in ~/.weechat/ecdsa.pem | grep '^pub:' -A 3 | tail -n 3 | tr -d ' \n:' | xxd -r -p | base64

Connect to the server, identify (for example with "nickserv identify") and set your public key in your account, using nickserv (replace the base64 value with your public key):

/connect freenode
/msg nickserv identify your_password
/msg nickserv set pubkey Av8k1FOGetUDq7sPMBfufSIZ5c2I/QYWgiwHtNXkVe/q

Configure the SASL options in the server:

/set irc.server.freenode.sasl_mechanism ecdsa-nist256p-challenge
/set irc.server.freenode.sasl_username "your_nickname"
/set irc.server.freenode.sasl_key "%h/ecdsa.pem"

Reconnect to the server:

/reconnect freenode

4.6.6. Connessione a Freenode con TOR/SASL

Oltre ad SSL, i server Freenode supportano connessioni con TOR (https://www.torproject.org), una rete di tunnel virtuali che consente ad utenti e gruppi di migliorare la propria privacy e la sicurezza su Internet.

Il primo passo consiste nell’installare TOR. Per Debian (e derivate):

$ sudo apt-get install tor

In WeeChat è necessario creare un proxy socks5 per il servizio TOR (nome host/IP e porta dipendono dalla propria configurazione di TOR):

/proxy add tor socks5 127.0.0.1 9050

Now, add a new server, for example:

/server add freenode-tor p4fsi4ockecnea7l.onion

Impostare il proxy per TOR:

/set irc.server.freenode-tor.proxy "tor"

Impostare l’autenticazione SASL:

/set irc.server.freenode-tor.sasl_username "your_nickname"
/set irc.server.freenode-tor.sasl_password "your_password"

E alla fine, connettersi al server:

/connect freenode-tor

Per maggiori informazioni su Freenode e TOR: http://freenode.net/irc_servers.shtml#tor

4.6.7. Filtro smart per i messaggi di entrata/uscita/disconnessione

Un filtro smart è disponibile per filtrare i messaggi di entrata/uscita/disconnessione quando il nick non ha detto nulla durante gli ultimi X minuti sul canale

Il filtro smart è abilitato per default, ma è necessario aggiungere un filtro per nascondere le righe sul buffer, per esempio:

/filter add irc_smart * irc_smart_filter *

È possibile creare il filtro solo per un canale o per i canali che iniziano con lo stesso nome (consultare /help filter):

/filter add irc_smart_weechat irc.freenode.#weechat irc_smart_filter *
/filter add irc_smart_weechats irc.freenode.#weechat* irc_smart_filter *

È possibile nascondere solo i messaggi di entrata o di uscita/disconnessione con le seguenti opzioni:

/set irc.look.smart_filter_join on
/set irc.look.smart_filter_quit on

È possibile impostare un ritardo (in minuti):

/set irc.look.smart_filter_delay 5

Se un nick non ha parlato durante gli ultimi 5 minuti, i suoi ingressi e/o uscite/disconnessioni verranno nascosti sul canale.

4.6.8. Risposte CTCP

È possibile personalizzare le risposte CTCP, o bloccare alcune richieste CTCP (non rispondere).

Ad esempio, per personalizzare la richiesta CTCP "VERSIONE", utilizzare il seguente comando:

/set irc.ctcp.version "Uso WeeChat $version, fico!"

Se si desidera bloccare CTCP "VERSIONE" (non rispondere ad una query), allora basta impostare una stringa vuota:

/set irc.ctcp.version ""

Anche un CTCP sconosciuto può essere personalizzato, per esempio si può rispondere "BLABLA":

/set irc.ctcp.blabla "Questa è la mia risposta a CTCP BLABLA"

È possibile personalizzare CTCP per un solo server, utilizzando il suo nome interno prima del nome CTCP:

/set irc.ctcp.freenode.version "WeeChat $version (per freenode)"

Se si desidera ripristinare la risposta CTCP standard, allora disabilitare l’opzione:

/unset irc.ctcp.version

I codici seguenti possono essere utilizzati nelle stringhe e vengono estese automaticamente da WeeChat quando si risponde alle CTCP

Codice Descrizione Valore/esempio
$clientinfo

Elenco di CTCP supportate

ACTION DCC CLIENTINFO FINGER PING SOURCE TIME USERINFO VERSION

$version

Versione di WeeChat

0.4.0-dev

$versiongit

Versione di WeeChat + git version (1)

0.4.0-dev (git: v0.3.9-104-g7eb5cc4)

$git

Git version (1)

v0.3.9-104-g7eb5cc4

$compilation

Data di compilazione di WeeChat

Dec 16 2012

$osinfo

Informazioni sull’OS

Linux 2.6.32-5-amd64 / x86_64

$site

Sito di WeeChat

https://weechat.org/

$download

Sito di WeeChat, pagina di download

https://weechat.org/download

$time

Data/ora correnti

Sun, 16 Dec 2012 10:40:48 +0100

$username

Nome utente sul server IRC

name

$realname

Nome reale sul server IRC

John Doe

(1) The git version is the output of command git describe. It is known only if WeeChat has been compiled inside the git repository and if git was installed.

Se le opzioni CTCP non sono definite (comportamento predefinito), le risposte CTCP sono:

CTCP Formato risposta Esempio

CLIENTINFO

$clientinfo

ACTION DCC CLIENTINFO FINGER PING SOURCE TIME USERINFO VERSION

FINGER

WeeChat $versiongit

WeeChat 0.4.0-dev (git: v0.3.9-104-g7eb5cc4)

SOURCE

$download

https://weechat.org/download

TIME

$time

Sun, 16 Dec 2012 10:40:48 +0100

USERINFO

$username ($realname)

name (John Doe)

VERSION

WeeChat $versiongit ($compilation)

WeeChat 0.4.0-dev (git: v0.3.9-104-g7eb5cc4) (Dec 16 2012)

4.6.9. Buffer di destinazione per i messaggi IRC

È possibile personalizzare il buffer di destinazione per i messaggi IRC (buffer usato per visualizzare messaggi) con l’opzione irc.msgbuffer.*.

Per alcuni messaggi IRC (elenco in basso), si possono usare i seguenti valori:

current

buffer attivo (se è il buffer IRC, oppure sul buffer del server, come predefinito)

private

buffer privato per il nick, o il buffer corrente se non trovato (in base all’opzione irc.look.msgbuffer_fallback)

server

buffer del server

weechat

Il buffer "core" di WeeChat

Quando l’opzione non è impostata (default), WeeChat sceglie il buffer appropriato, di solito quello del server o del canale.

Ecco una lista incompleta dei messaggi IRC o degli alias che è possibile personalizzare:

messaggio alias descrizione

error

errore

invite

invitato su un canale

join

ingresso nel canale

kick

kick

kill

kill

mode

mode

notice

notifica

part

part

quit

quit

topic

topic

wallops

wallops

ctcp

ctcp (inviato o ricevuto, in un messaggio privato o di notifica)

221

stringa modalità utente

275

whois

whois (connessione sicura)

301

whois

whois (assente)

303

ison

305

unaway

presente

306

away

assente

307

whois

whois (nick registrato)

310

whois

whois (modalità aiuto)

311

whois

whois (utente)

312

whois

whois (server)

313

whois

whois (operatore)

314

whowas

whowas

315

who

who (fine)

317

whois

whois (inattività)

318

whois

whois (fine)

319

whois

whois (canali)

320

whois

whois (utente identificato)

321

list

list (inizio)

322

list

list (canale)

323

list

list (fine)

326

whois

whois (con privilegi di operatore)

327

whois

whois (host)

328

URL del canale

329

data di creazione del canale

330

whois

whois (loggato come)

331

nessun argomento per il canale

332

argomento del canale

333

informazioni sull’argomento

335

whois

whois (è un bot su)

338

whois

whois (host)

341

invito

343

whois

whois (è opered come)

344

reop

reop sul canale

345

reop

reop sul canale (fine)

346

invitelist

lista di inviti

347

invitelist

lista di inviti (fine)

348

exceptionlist

lista di eccezioni

349

exceptionlist

lista di eccezioni (fine)

351

versione del server

352

who

who

353

names

elenco di utenti su un canale

366

names

fine dell’elenco /names

367

banlist

elenco dei ban

368

banlist

fine della lista dei ban

369

whowas

whowas (fine)

378

whois

whois (connesso da)

379

whois

whois (usa le modalità)

401

whois

no such nick/channel

402

whois

no such server

432

nick errato

433

nick già utilizzato

438

non autorizzato a cambiare nick

671

whois

whois (connessione sicura)

728

quietlist

quiet list

729

quietlist

end of quiet list

732

monitor

list of monitored nicks

733

monitor

list of monitored nicks (end)

901

ora si è loggati

Anche altri comandi numerici possono essere personalizzati.

Il messaggio può essere preceduto dal nome del server per essere più precisi (ad esempio: freenode.whois).

Alcuni esempi:

  • visualizza il risultato di /whois su un buffer privato:

/set irc.msgbuffer.whois private
  • ripristina il buffer predefinito per il whois (buffer del server):

/unset irc.msgbuffer.whois
  • visualizza inviti sul buffer corrente, solo per il server "freenode":

/set irc.msgbuffer.freenode.invite current
  • visualizza messaggio "303" (ison) sul buffer "core" di WeeChat:

/set irc.msgbuffer.303 weechat

4.7. Plugin Logger

Il plugin Logger consente di salvare il contenuto dei buffer su file, con opzioni a proposito su cosa e come viene salvato.

4.7.1. Opzioni (logger.conf)

Sections:

Section Control command Description

look

/set logger.look.*

Look and feel.

color

/set logger.color.*

Colors.

file

/set logger.file.*

Options for log files.

level

/set logger.level.*

Log level by buffer (options can be added/removed in section).

mask

/set logger.mask.*

Filename mask by buffer (options can be added/removed in section).

Options:

  • logger.color.backlog_end

    • descrizione: colore per la riga finale nella cronologia

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • logger.color.backlog_line

    • descrizione: colore per la cronologia

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • logger.file.auto_log

    • descrizione: salva automaticamente il contenuto dei buffer su file (a meno che un buffer disabiliti il log)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • logger.file.flush_delay

    • descrizione: numero di secondi tra il flush (scrittura) dei file di log (0 = scrive sui file di log immediatamente per ogni riga stampata)

    • tipo: intero

    • valori: 0 .. 3600

    • valore predefinito: 120

  • logger.file.info_lines

    • descrizione: scrive una riga informativa nel file di log quando il log inizia o termina per un buffer

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • logger.file.mask

    • descrizione: default file name mask for log files (format is "directory/to/file" or "file", without first "/" because "path" option is used to build complete path to file); local buffer variables are permitted (you should use only variables that are defined on all buffers, so for example you should NOT use $server nor $channel); date specifiers are permitted (see man strftime)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "$plugin.$name.weechatlog"

  • logger.file.name_lower_case

    • descrizione: usare solo lettere minuscole per i nomi dei file di log

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • logger.file.nick_prefix

    • descrizione: testo da scrivere prima del nick nel prefisso del messaggo, esempio: "<"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • logger.file.nick_suffix

    • descrizione: testo da scrivere dopo il nick nel prefisso del messaggo, esempio: "<"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • logger.file.path

    • descrizione: path for WeeChat log files; "%h" at beginning of string is replaced by WeeChat home ("~/.weechat" by default); date specifiers are permitted (see man strftime) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%h/logs/"

  • logger.file.replacement_char

    • descrizione: carattere di sostituzione per i caratteri speciali nei nomi dei file salvati con la mask (come il delimitatore di directory)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "_"

  • logger.file.time_format

    • descrizione: data e ora usati nei file di log (consultare man strftime per gli specificatori di data/ora)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%Y-%m-%d %H:%M:%S"

  • logger.look.backlog

    • descrizione: numero massimo di righe da visualizzare dal file di log alla creazione di un nuovo buffer (0 = nessuna cronologia)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 20

4.7.2. Comandi

  • logger: configurazione del plugin logger

/logger  list
         set <livello>
         flush
         disable

   list: mostra lo stato del logging per i buffer aperti
    set: imposta il livello di logging per il buffer corrente
livello: livello per i messaggi da loggare (0 = disabilitato, 1 = alcuni messaggi (più importanti) .. 9 = tutti i messaggi)
  flush: scrive immediatamente tutti i file di log
disable: disabilita il logging sul buffer corrente (imposta livello a 0)

Le opzioni "logger.level.*" e "logger.mask.*" possono essere usate per impostare un livello o una mask per un buffer, o per i buffer che cominciano per nome.

Livelli di log usati dal plugin IRC:
  1: messaggio utente, notifica, privato
  2: cambio di nick
  3: messaggio del server
  4: entrata/uscita/abbandono
  9: tutti gli altri messaggi

Esempi:
  imposta il livello 5 per buffer corrente:
    /logger set 5
  disabilita logging per il buffer corrente:
    /logger disable
  imposta il livello 3 per tutti i buffer IRC:
    /set logger.level.irc 3
  disabilita logging per il buffer principale di WeeChat:
    /set logger.level.core.weechat 0
  usa una directory per il server IRC e un file per ogni canale al suo interno:
    /set logger.mask.irc "$server/$channel.weechatlog"

4.7.3. Livelli di log

Il logging viene effettuato con un livello per ogni buffer. Il livello predefinito è il 9 (registra tutti i messaggi visualizzati sul buffer). È possibile cambiare il livello per un buffer, oppure per un gruppo di buffer.

I livelli possibili sono da 0 a 9. Zero vuol dire "non registrare nulla" mentre 9 "registra tutto".

I plugin utilizzano livelli diversi per i messaggi visualizzati. Il plugin IRC usa i seguenti livelli:

  • livello 1: messaggio da un utente (su canale o privato)

  • livello 2: cambio nick (proprio o di qualcun altro)

  • livello 3: ogni messaggio del server (esclui entrata/uscita/disconnessione)

  • livello 4: messaggio del server entrata/uscita/disconnessione

Se viene impostato il livello 3 per un canale IRC, WeeChat registrerà tutti i messaggi, ma non quelli di entrata/uscita/disconnessione.

Alcuni esempi:

  • imposta il livello 3 per il canale IRC #weechat:

/set logger.level.irc.freenode.#weechat 3
  • set level 3 for freenode server buffer:

/set logger.level.irc.server.freenode 3
  • imposta il livello 3 per tutti i canali sul server freenode:

/set logger.level.irc.freenode 3
  • imposta il livello 2 per tutti i buffer IRC:

/set logger.level.irc 2

4.7.4. Mask per il nome file

È possibile definire un mask per il nome del file di ogni buffer, ed utilizzare le variabili buffer locali per costruire il nome del file. Per visualizzare le variabili locali per il buffer corrente:

/buffer localvar

Ad esempio, sul buffer "irc.freenode.#weechat", WeeChat cercherà un mask con il nome dell’opzione, in quest’ordine:

logger.mask.irc.freenode.#weechat
logger.mask.irc.freenode
logger.mask.irc
logger.file.mask

Ciò vuol dire che si hanno dei mask specifici per alcuni server IRC ("logger.mask.irc.freenode") o per un plugin ("logger.mask.irc").

File di log per data

Per avere file di log per data, è possibile usare specificatori data/ora nei mask (consultare man stfrtime per i formati), ad esempio:

/set logger.file.mask "%Y/%m/$plugin.$name.weechatlog"

Si avranno i seguenti file:

~/.weechat/
    |--- logs/
        |--- 2010/
            |--- 11/
            |       irc.server.freenode.weechatlog
            |       irc.freenode.#weechat.weechatlog
        |--- 2010/
            |--- 12/
            |       irc.server.freenode.weechatlog
            |       irc.freenode.#weechat.weechatlog
File di log IRC per server e canale

Se si desidera avere una directory per il server IRC ed una per il canale al suo interno:

/set logger.mask.irc "irc/$server/$channel.weechatlog"

Si avranno i seguenti file:

~/.weechat/
    |--- logs/
        |--- irc/
            |--- freenode/
            |       freenode.weechatlog
            |       #weechat.weechatlog
            |       #mychan.weechatlog
            |--- oftc/
            |       oftc.weechatlog
            |       #chan1.weechatlog
            |       #chan2.weechatlog

4.8. Plugin Relay

Il plugin Relay viene utilizzato per inoltrare i dati via rete, facendo uso di protocolli differenti:

  • irc: proxy IRC: usato per condividere le connessioni ai server IRC con uno o più client IRC

  • weechat: protocollo usato dalle interfacce remote per mostrare ed interagire con WeeChat (ad esempio QWeeChat)

4.8.1. Opzioni (relay.conf)

Sections:

Section Control command Description

look

/set relay.look.*

Look and feel.

color

/set relay.color.*

Colors.

network

/set relay.network.*

Network options.

irc

/set relay.irc.*

Options specific to irc protocol (irc proxy).

port

/relay add
/set relay.port.*

Ports used for relay (irc and weechat protocols) (options can be added/removed in section).

Options:

  • relay.color.client

    • descrizione: colore del testo per la descrizione del client

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • relay.color.status_active

    • descrizione: colore del testo per lo status "connesso"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightblue

  • relay.color.status_auth_failed

    • descrizione: colore del testo per lo status "autenticazione fallita"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • relay.color.status_connecting

    • descrizione: colore del testo per lo status "connessione in corso"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • relay.color.status_disconnected

    • descrizione: colore del testo per lo status "disconnesso"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • relay.color.status_waiting_auth

    • descrizione: colore del testo per lo status "in attesa dell'autenticazione"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: brown

  • relay.color.text

    • descrizione: colore del testo nei buffer relay

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • relay.color.text_bg

    • descrizione: colore di sfondo nel buffer relay

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • relay.color.text_selected

    • descrizione: colore del testo della riga selezionata nel buffer relay

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • relay.irc.backlog_max_minutes

    • descrizione: numero massimo di minuti nella cronologia per canale IRC (0 = nessun limite, esempi: 1440 = un giorno, 10000 = una settimana; 43200 = un mese, 525600 = un anno)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 1440

  • relay.irc.backlog_max_number

    • descrizione: numero massimo di righe nella cronologia per canale IRC (0 = nessun limite)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 256

  • relay.irc.backlog_since_last_disconnect

    • descrizione: mostra la cronologia a partire dall'ultima disconnessione del client

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • relay.irc.backlog_since_last_message

    • descrizione: display backlog starting from your last message

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • relay.irc.backlog_tags

    • descrizione: comma-separated list of messages tags which are displayed in backlog per IRC channel (supported tags: "irc_join", "irc_part", "irc_quit", "irc_nick", "irc_privmsg"), "*" = all supported tags

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "irc_privmsg"

  • relay.irc.backlog_time_format

    • descrizione: format for time in backlog messages (see man strftime for format) (not used if server capability "server-time" was enabled by client, because time is sent as irc tag); empty string = disable time in backlog messages

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "[%H:%M] "

  • relay.look.auto_open_buffer

    • descrizione: apre automaticamente il buffer relay alla connessione di un nuovo client

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • relay.look.raw_messages

    • descrizione: numero di messaggi raw da salvare in memoria quando il buffer dei dati raw viene chiuso (i messaggi verranno visualizzati all'apertura del buffer dei dati raw)

    • tipo: intero

    • valori: 0 .. 65535

    • valore predefinito: 256

  • relay.network.allow_empty_password

    • descrizione: allow empty password in relay (it should be enabled only for tests or local network)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • relay.network.allowed_ips

    • descrizione: POSIX extended regular expression with IPs allowed to use relay (case insensitive, use "(?-i)" at beginning to make it case sensitive), example: "^(123.45.67.89|192.160.*)$"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • relay.network.bind_address

    • descrizione: indirizzo per l'associazione (se vuoto, la connessione è possibile su tutte le interfacce, usare "127.0.0.1" per consentire le connessioni solo dalla macchina locale)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • relay.network.clients_purge_delay

    • descrizione: delay for purging disconnected clients (in minutes, 0 = purge clients immediately, -1 = never purge)

    • tipo: intero

    • valori: -1 .. 43200

    • valore predefinito: 0

  • relay.network.compression_level

    • descrizione: livello di compressione per i pacchetti inviati al client con il protocollo WeeChat (0 = disabilita compressione, 1 = compressione bassa ... 9 = compressione migliore)

    • tipo: intero

    • valori: 0 .. 9

    • valore predefinito: 6

  • relay.network.ipv6

    • descrizione: listen on IPv6 socket by default (in addition to IPv4 which is default); protocols IPv4 and IPv6 can be forced (individually or together) in the protocol name (see /help relay)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • relay.network.max_clients

    • descrizione: maximum number of clients connecting to a port (0 = no limit)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 5

  • relay.network.password

    • descrizione: password required by clients to access this relay (empty value means no password required, see option relay.network.allow_empty_password) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • relay.network.ssl_cert_key

    • descrizione: file con il certificato SSL e la chiave privata (per servire i client con SSL)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%h/ssl/relay.pem"

  • relay.network.ssl_priorities

    • descrizione: stringa con le priorità per gnutls (per la sintassi, consultare la documentazione per la funzione gnutls_priority_init nel manuale di gnutls, stringhe comuni sono: "PERFORMANCE", "NORMAL", "SECURE128", "SECURE256", "EXPORT", "NONE")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "NORMAL:-VERS-SSL3.0"

  • relay.network.websocket_allowed_origins

    • descrizione: POSIX extended regular expression with origins allowed in websockets (case insensitive, use "(?-i)" at beginning to make it case sensitive), example: "^http://(www\.)?example\.(com|org)"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

4.8.2. Comandi

  • relay: controllo relay

/relay  list|listfull|listrelay
        add <name> <port>
        del|stop|restart <name>
        raw
        sslcertkey

         list: list relay clients (only active relays)
     listfull: list relay clients (verbose, all relays)
    listrelay: list relays (name and port)
          add: add a relay (listen on a port)
          del: remove a relay (clients remain connected)
         stop: close the server socket (clients remain connected)
      restart: close the server socket and listen again on port (clients remain connected)
         name: relay name (see format below)
         port: port used for relay
          raw: open buffer with raw Relay data
   sslcertkey: set SSL certificate/key using path in option relay.network.ssl_cert_key

Relay name is: [ipv4.][ipv6.][ssl.]<protocol.name>
         ipv4: force use of IPv4
         ipv6: force use of IPv6
          ssl: enable SSL
protocol.name: protocol and name to relay:
                 - protocol "irc": name is the server to share (optional, if not given, the server name must be sent by client in command "PASS", with format: "PASS server:password")
                 - protocol "weechat" (name is not used)

The "irc" protocol allows any IRC client (including WeeChat itself) to connect on the port.
The "weechat" protocol allows a remote interface to connect on the port, see the list here: https://weechat.org/download/

Without argument, this command opens buffer with list of relay clients.

Examples:
  irc proxy, for server "freenode":
    /relay add irc.freenode 8000
  irc proxy, for server "freenode", with SSL:
    /relay add ssl.irc.freenode 8001
  irc proxy, for all servers (client will choose), with SSL:
    /relay add ssl.irc 8002
  weechat protocol:
    /relay add weechat 9000
  weechat protocol with SSL:
    /relay add ssl.weechat 9001
  weechat protocol with SSL, using only IPv4:
    /relay add ipv4.ssl.weechat 9001
  weechat protocol with SSL, using only IPv6:
    /relay add ipv6.ssl.weechat 9001
  weechat protocol with SSL, using IPv4 + IPv6:
    /relay add ipv4.ipv6.ssl.weechat 9001

4.8.3. Password

It is highly recommended to set a password for relay, with command:

/set relay.network.password "miapass"

This password is used for irc and weechat protocols.

4.8.4. SSL

È possibile usare SSL creando un certificato e una chiave privata, e usando il prefisso "ssl." nel nome del protocollo.

Il file predefinito per il certificato/chiave è ~/.weechat/ssl/relay.pem (opzione relay.network.ssl_cert_key).

È possibile creare un certificato e una chiave privata con i seguenti comandi:

$ mkdir -p ~/.weechat/ssl
$ cd ~/.weechat/ssl
$ openssl req -nodes -newkey rsa:2048 -keyout relay.pem -x509 -days 365 -out relay.pem

Se WeeChat è già in esecuzione, è possibile ricaricare il certificato e la chiave privata con il comando:

/relay sslcertkey

4.8.5. Proxy IRC

The Relay plugin can act as an IRC proxy: it will simulate an IRC server, and you can connect to WeeChat with any other IRC client (including WeeChat itself).

You can define one port by IRC server, or one generic port for all servers.

When using one port for all servers, the client must send the internal name of server in the IRC "PASS" command, with this format:

PASS server:miapass

Example: IRC proxy with SSL for any server (client will choose):

/relay add ssl.irc 8000

Example: IRC proxy without SSL only for server "freenode":

/relay add irc.freenode 8000

Now you can connect on port 8000 with any IRC client using server password "miapass" (or "freenode:miapass" if no server was specified in the relay).

4.8.6. Protocollo WeeChat

Il plugin Relay può inviare dati alle interfacce remote usando il protocollo WeeChat.

You can connect with a remote interface, see the list on download page: https://weechat.org/download

WeeChat itself can NOT connect to another WeeChat with this protocol.

Ad esempio:

/relay add weechat 9000

Ora è possibile connettersi sulla porta 9000 con un’interfaccia remota usando la password "miapass".

4.8.7. WebSocket

WebSocket protocol (RFC 6455) is supported in Relay plugin for all protocols.

The WebSocket handshake is automatically detected and socket becomes ready for WebSocket if required headers are found in handshake and if origin is allowed (see option relay.network.websocket_allowed_origins).

A WebSocket can be opened in a HTML5 with a single line of JavaScript:

websocket = new WebSocket("ws://server.com:9000/weechat");

The port (9000 in example) is the port defined in Relay plugin. The URI must always end with "/weechat" (for irc and weechat protocols).

4.9. Plugin per gli script

WeeChat fornisce 7 plugin per lo scripting: Python, Perl, Ruby, Lua, Tcl, Guile (scheme), Javascript. Questi plugin possono caricare, eseguire e scaricare gli script per questi linguaggi.

Another plugin called "script" is a scripts manager and is used to load/unload scripts of any language, and install/remove scripts of WeeChat scripts repository, which are visible at this URL: https://weechat.org/scripts

Per maggiori informazioni su come scrivere gli script, o le API WeeChat per gli script, consultare la Guida allo Scripting di WeeChat.

4.9.1. Script options (script.conf)

Sections:

Section Control command Description

look

/set script.look.*

Look and feel.

color

/set script.color.*

Colors.

scripts

/set script.scripts.*

Options for download of scripts.

Options:

  • script.color.status_autoloaded

    • descrizione: colore per lo status "caricato automaticamente" ("a")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • script.color.status_held

    • descrizione: colore per lo status "bloccato" ("H")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • script.color.status_installed

    • descrizione: colore per lo status "installato" ("i")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightcyan

  • script.color.status_obsolete

    • descrizione: colore per lo status "obsoleto" ("N")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • script.color.status_popular

    • descrizione: colore per lo status "popolare" ("*")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • script.color.status_running

    • descrizione: colore per lo status "in esecuzione" ("r")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • script.color.status_unknown

    • descrizione: colore per lo status "sconosciuto" ("?")

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • script.color.text

    • descrizione: colore del testo nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_bg

    • descrizione: colore di sfondo nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_bg_selected

    • descrizione: colore di sfondo per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: red

  • script.color.text_date

    • descrizione: colore del testo delle date nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_date_selected

    • descrizione: colore del testo delle date per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • script.color.text_delimiters

    • descrizione: colore del testo dei delimitatori nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_description

    • descrizione: colore del testo della descrizione nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_description_selected

    • descrizione: colore del testo della descrizione per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • script.color.text_extension

    • descrizione: colore del testo dell'estensione nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_extension_selected

    • descrizione: colore del testo dell'estensione per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • script.color.text_name

    • descrizione: colore del testo del nome dello script nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • script.color.text_name_selected

    • descrizione: colore del testo del nome dello script per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightcyan

  • script.color.text_selected

    • descrizione: colore del testo della riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • script.color.text_tags

    • descrizione: colore del testo dei tag nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: brown

  • script.color.text_tags_selected

    • descrizione: colore del testo dei tag per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • script.color.text_version

    • descrizione: colore del testo della versione nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: magenta

  • script.color.text_version_loaded

    • descrizione: colore del testo della versione caricata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • script.color.text_version_loaded_selected

    • descrizione: colore del testo della versione attiva per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • script.color.text_version_selected

    • descrizione: colore del testo della versione per la riga selezionata nel buffer degli script

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • script.look.columns

    • descrizione: format of columns displayed in script buffer: following column identifiers are replaced by their value: %a=author, %d=description, %D=date added, %e=extension, %l=language, %L=license, %n=name with extension, %N=name, %r=requirements, %s=status, %t=tags, %u=date updated, %v=version, %V=version loaded, %w=min_weechat, %W=max_weechat)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%s %n %V %v %u | %d | %t"

  • script.look.diff_color

    • descrizione: colora l'output di diff

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • script.look.diff_command

    • descrizione: comando usato per mostrare le differenze tra lo script installato e la nuova versione nel repository ("auto" = rileva automaticamente il comando diff (git o diff), valore vuoto = disabilita diff, altra stringa = nome del comando, ad esempio "diff")

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "auto"

  • script.look.display_source

    • descrizione: mostra il codice sorgente dello script sul buffer ed i relativi dettagli (lo script viene scaricato in un file temporaneo)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • script.look.quiet_actions

    • descrizione: quiet actions on script buffer: do not display messages on core buffer when scripts are installed/removed/loaded/unloaded (only errors are displayed)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • script.look.sort

    • descrizione: default sort keys for scripts: comma-separated list of identifiers: a=author, A=autoloaded, d=date added, e=extension, i=installed, l=language, n=name, o=obsolete, p=popularity, r=running, u=date updated; char "-" can be used before identifier to reverse order; example: "i,u": installed scripts first, sorted by update date

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "p,n"

  • script.look.translate_description

    • descrizione: translate description of scripts (if translation is available in your language, otherwise English version is used)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • script.look.use_keys

    • descrizione: use keys alt+X in script buffer to do actions on scripts (alt+i = install, alt+r = remove, ...); if disabled, only the input is allowed: i, r, ...

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • script.scripts.autoload

    • descrizione: autoload scripts installed (make a link in "autoload" directory to script in parent directory)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • script.scripts.cache_expire

    • descrizione: local cache expiration time, in minutes (-1 = never expires, 0 = always expire)

    • tipo: intero

    • valori: -1 .. 525600

    • valore predefinito: 1440

  • script.scripts.download_timeout

    • descrizione: timeout (in seconds) for download of scripts and list of scripts

    • tipo: intero

    • valori: 1 .. 3600

    • valore predefinito: 30

  • script.scripts.hold

    • descrizione: scripts to "hold": comma-separated list of scripts which will never been upgraded and can not be removed, for example: "buffers.pl,iset.pl"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • script.scripts.path

    • descrizione: local cache directory for scripts; "%h" at beginning of string is replaced by WeeChat home ("~/.weechat" by default) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%h/script"

  • script.scripts.url

    • descrizione: URL for file with list of scripts; by default HTTPS is forced, see option script.scripts.url_force_https

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "http://weechat.org/files/plugins.xml.gz"

  • script.scripts.url_force_https

    • descrizione: force use of HTTPS for downloads (index and scripts); you should disable this option only if you have problems with the downloads

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

4.9.2. Comandi Script

  • script: Gestore script di WeeChat

/script  list [-o|-i]
         search <text>
         show <script>
         load|unload|reload <script> [<script>...]
         autoload|noautoload|toggleautoload <script> [<script>...]
         install|remove|installremove|hold [-q] <script> [<script>...]
         upgrade
         update

          list: list loaded scripts (all languages)
            -o: send list of loaded scripts to buffer
            -i: copy list of loaded scripts in command line (for sending to buffer)
        search: search scripts by tags, language (python, perl, ...), filename extension (py, pl, ...) or text; result is displayed on scripts buffer
          show: show detailed info about a script
          load: load script(s)
        unload: unload script(s)
        reload: reload script(s)
      autoload: autoload the script
    noautoload: do not autoload the script
toggleautoload: toggle autoload
       install: install/upgrade script(s)
        remove: remove script(s)
 installremove: install or remove script(s), depending on current state
          hold: hold/unhold script(s) (a script held will not be upgraded any more and cannot be removed)
            -q: quiet mode: do not display messages
       upgrade: upgrade all installed scripts which are obsolete (new version available)
        update: update local scripts cache

Without argument, this command opens a buffer with list of scripts.

On script buffer, the possible status for each script are:
  * i a H r N
  | | | | | |
  | | | | | obsolete (new version available)
  | | | | running (loaded)
  | | | held
  | | autoloaded
  | installed
  popular script

Keys on script buffer:
  alt+i  install script
  alt+r  remove script
  alt+l  load script
  alt+L  reload script
  alt+u  unload script
  alt+A  autoload script
  alt+h  (un)hold script
  alt+v  view script

Input allowed on script buffer:
  i/r/l/L/u/h  action on script (same as keys above)
  q            close buffer
  $            refresh buffer
  s:x,y        sort buffer using keys x and y (see /help script.look.sort)
  s:           reset sort (use default sort)
  word(s)      filter scripts: search word(s) in scripts (description, tags, ...)
  *            remove filter

Mouse actions on script buffer:
  wheel         scroll list
  left button   select script
  right button  install/remove script

Examples:
  /script search url
  /script install iset.pl buffers.pl
  /script remove iset.pl
  /script hold urlserver.py
  /script reload urlserver
  /script upgrade

4.9.3. Comandi Python

  • python: elenca/carica/scarica script

/python  list|listfull [<nome>]
         load [-q] <nomefile>
         autoload
         reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.9.4. Comandi Perl

  • perl: elenca/carica/scarica script

/perl  list|listfull [<nome>]
       load [-q] <nomefile>
       autoload
       reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.9.5. Comandi Ruby

  • ruby: elenca/carica/scarica script

/ruby  list|listfull [<nome>]
       load [-q] <nomefile>
       autoload
       reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.9.6. Comandi Lua

  • lua: elenca/carica/scarica script

/lua  list|listfull [<nome>]
      load [-q] <nomefile>
      autoload
      reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.9.7. Comandi Tcl

  • tcl: elenca/carica/scarica script

/tcl  list|listfull [<nome>]
      load [-q] <nomefile>
      autoload
      reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.9.8. Comandi Guile

  • guile: elenca/carica/scarica script

/guile  list|listfull [<nome>]
        load [-q] <nomefile>
        autoload
        reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.9.9. Comandi Javascript

  • javascript: elenca/carica/scarica script

/javascript  list|listfull [<nome>]
             load [-q] <nomefile>
             autoload
             reload|unload [-q][<nome>]

     list: elenca i plugin caricati
 listfull: elenca i plugin caricati (dettagliato)
     load: carica un plugin
 autoload: carica automaticamente i plugin nella directory utente o di sistema
   reload: ricarica un plugin (se non specificato, scarica i plugin e li ricarica automaticamente)
   unload: scarica uno o tutti i plugin
nome_file: (file) script da caricare
     nome: il nome di uno script (usato nella chiamata alla funzione "register")
       -q: modalità silenziosa: non mostra messaggi

Senza argomento, questo comando elenca tutti i plugin caricati.

4.10. Trigger plugin

Trigger is the Swiss Army knife for WeeChat: it can hook many things (signal, modifier, print, …​), change the content of data, and execute one or more commands. A condition can be used to prevent the trigger to run in some circumstances.

Using triggers require you to know how the signals, modifiers, …​ are working. So you might consider reading the Hooks chapter in the WeeChat Plugin API Reference.

4.10.1. Options (trigger.conf)

Sections:

Section Control command Description

look

/set trigger.look.*

Look and feel.

color

/set trigger.color.*

Colors.

trigger

/trigger add
/trigger set
/set trigger.trigger.*

Trigger options.

Options:

  • trigger.color.flag_command

    • descrizione: text color for command flag (in /trigger list)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • trigger.color.flag_conditions

    • descrizione: text color for conditions flag (in /trigger list)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • trigger.color.flag_post_action

    • descrizione: text color for post action flag (in /trigger list)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightblue

  • trigger.color.flag_regex

    • descrizione: text color for regex flag (in /trigger list)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightcyan

  • trigger.color.flag_return_code

    • descrizione: text color for return code flag (in /trigger list)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightmagenta

  • trigger.color.regex

    • descrizione: text color for regular expressions

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • trigger.color.replace

    • descrizione: text color for replacement text (for regular expressions)

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: cyan

  • trigger.color.trigger

    • descrizione: text color for trigger name

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: green

  • trigger.color.trigger_disabled

    • descrizione: text color for disabled trigger name

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: red

  • trigger.look.enabled

    • descrizione: enable trigger support

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • trigger.look.monitor_strip_colors

    • descrizione: strip colors in hashtable values displayed on monitor buffer

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

4.10.2. Commands

  • trigger: manage triggers, the Swiss Army knife for WeeChat

/trigger  list|listfull|listdefault
          add|addoff|addreplace <name> <hook> ["<arguments>" ["<conditions>" ["<regex>" ["<command>" ["<return_code>" ["<post_action>"]]]]]]
          addinput [<hook>]
          input|output|recreate <name>
          set <name> <option> <value>
          rename|copy <name> <new_name>
          enable|disable|toggle [<name>|-all [<name>...]]
          restart <name>|-all [<name>...]
          show <name>
          del <name>|-all [<name>...]
          restore <name> [<name>...]
          default -yes
          monitor [<filter>]

       list: list triggers (without argument, this list is displayed)
   listfull: list triggers with detailed info for each trigger
listdefault: list default triggers
        add: add a trigger
     addoff: add a trigger (disabled)
 addreplace: add or replace an existing trigger
       name: name of trigger
       hook: signal, hsignal, modifier, print, command, command_run, timer, config, focus
  arguments: arguments for the hook, depending on hook (separated by semicolons):
             signal: name(s) of signal (required)
             hsignal: name(s) of hsignal (required)
             modifier: name(s) of modifier (required)
             print: buffer, tags, message, strip colors
             command: command (required), description, arguments, description of arguments, completion
             command_run: command(s) (required)
             timer: interval (required), align on second, max calls
             config: name(s) of option (required)
             focus: name(s) of area (required)
 conditions: evaluated conditions for the trigger
      regex: one or more regular expressions to replace strings in variables
    command: command to execute (many commands can be separated by ";"
return_code: return code in callback (ok (default), ok_eat, error)
post_action: action to take after execution (none (default), disable, delete)
   addinput: set input with default arguments to create a trigger
      input: set input with the command used to create the trigger
     output: send the command to create the trigger on the buffer
   recreate: same as "input", with option "addreplace" instead of "add"
        set: set an option in a trigger
     option: name of option: name, hook, arguments, conditions, regex, command, return_code
             (for help on option, you can type: /help trigger.trigger.<name>.<option>)
      value: new value for the option
     rename: rename a trigger
       copy: copy a trigger
     enable: enable trigger(s) (without arguments: enable triggers globally)
    disable: disable trigger(s) (without arguments: disable triggers globally)
     toggle: toggle trigger(s) (without arguments: toggle triggers globally)
    restart: restart trigger(s) (recreate the hooks)
       show: show detailed info on a trigger (with some stats)
        del: delete a trigger
       -all: do action on all triggers
    restore: restore trigger(s) with the default values (works only for default triggers)
    default: delete all triggers and restore default ones
    monitor: open the trigger monitor buffer, with optional filter:
     filter: filter hooks/triggers to display (a hook must start with "@", for example "@signal"), many filters can be separated by commas; wildcard "*" is allowed in each trigger name

When a trigger callback is called, following actions are performed, in this order:
  1. check conditions; if false, exit
  2. replace text using POSIX extended regular expression(s) (if defined in trigger)
  3. execute command(s) (if defined in trigger)
  4. exit with a return code (except for modifiers and focus)
  5. perform post action

Examples (you can also look at default triggers with /trigger listdefault):
  add text attributes *bold*, _underline_ and /italic/ (only in user messages):
    /trigger add effects modifier weechat_print "${tg_tag_nick}" "==\*(\S+)\*==*${color:bold}${re:1}${color:-bold}*== ==_(\S+)_==_${color:underline}${re:1}${color:-underline}_== ==/(\S+)/==/${color:italic}${re:1}${color:-italic}/"
  hide nicklist bar on small terminals:
    /trigger add resize_small signal signal_sigwinch "${info:term_width} < 100" "" "/bar hide nicklist"
    /trigger add resize_big signal signal_sigwinch "${info:term_width} >= 100" "" "/bar show nicklist"
  silently save config each hour:
    /trigger add cfgsave timer 3600000;0;0 "" "" "/mute /save"
  open trigger monitor and show only modifiers and triggers whose name starts with "resize":
    /trigger monitor @modifier,resize*

4.10.3. Anatomy of a trigger

A trigger has the following options (names are trigger.trigger.<name>.<option>):

Option Values Description

enabled

on, off

When option is off, the trigger is disabled and actions are not executed any more.

hook

signal, hsignal, modifier, print, command, command_run, timer, config, focus

The hook used in trigger. For more information, see WeeChat Plugin API Reference, chapter Hooks.

arguments

string

The arguments for the hook, it depends on the hook type used.

conditions

string

Conditions to execute the trigger; they are evaluated (see command /eval).

regex

string

One or more POSIX extended regular expressions, to change data received in the hook callback (and some stuff added by trigger plugin), see regular expression.

command

string

Command to execute (many commands can be separated by semicolons); it is evaluated (see command /eval).

return_code

ok, ok_eat, error

The return code of callback (default is ok, which should be used in almost all triggers, the other values are rarely used).

post_action

none, disable, delete

Action to take on the trigger after execution (default is none which should be used in almost all triggers, the other values are rarely used).

For example, the default beep trigger has following options:

trigger.trigger.beep.enabled = on
trigger.trigger.beep.hook = print
trigger.trigger.beep.arguments = ""
trigger.trigger.beep.conditions = "${tg_highlight} || ${tg_msg_pv}"
trigger.trigger.beep.regex = ""
trigger.trigger.beep.command = "/print -beep"
trigger.trigger.beep.return_code = ok
trigger.trigger.beep.post_action = none

4.10.4. Execution

When a trigger callback is called, following actions are executed, in this order, if triggers are globally enabled and if the trigger itself is enabled:

  1. check trigger conditions: if false, exit

  2. replace text in trigger using regular expression(s)

  3. execute command(s)

  4. exit with a return code (except for hooks modifier and focus)

  5. perform post action (if different from none).

4.10.5. Hook arguments

The arguments depend on the hook used. They are separated by semicolons.

Hook Arguments Examples

signal

1. signal name (priority allowed) (required)
2. signal name (priority allowed)
3. …​

*,irc_in_privmsg
*,irc_in_privmsg;*,irc_in_notice
signal_sigwinch

hsignal

1. signal name (priority allowed) (required)
2. signal name (priority allowed)
3. …​

nicklist_nick_added

modifier

1. modifier name (priority allowed) (required)
2. modifier name (priority allowed)
3. …​

weechat_print
5000|input_text_display;5000|history_add

print

1. buffer name
2. tags
3. message
4. strip colors (0/1)

irc.freenode.*
irc.freenode.#weechat
irc.freenode.#weechat;irc_notice
*;;;1

command

1. command name (priority allowed) (required)
2. description
3. arguments
4. description of arguments
5. completion

test
5000|test

command_run

1. command (priority allowed) (required)
2. command (priority allowed)
3. …​

/cmd arguments

timer

1. interval in milliseconds (required)
2. alignment on second (default: 0)
3. max number of calls (default: 0, which means "no end")

3600000
60000;0;5

config

1. option name (priority allowed) (required)
2. option name (priority allowed)
3. …​

weechat.look.*

focus

1. area name (priority allowed) (required)
2. area name (priority allowed)
3. …​

buffer_nicklist

4.10.6. Conditions

The conditions are used to continue processing in trigger, or stop everything.

They are evaluated, and data available in callback can be used (see data in callbacks and command /eval).

Example: the default beep trigger uses this condition to make a beep only on highlight or private message:

${tg_highlight} || ${tg_msg_pv}

4.10.7. Regular expression

The regular expression is used to change variables in callback hashtable.

The format is: "/regex/replace" or "/regex/replace/var" (where var is a variable of the hashtable).
If var is not specified, the default variable is used, it depends on hook type:

Hook Default variable

signal

tg_signal_data

hsignal

modifier

tg_string

print

tg_message

command

tg_argv_eol1

command_run

tg_command

timer

tg_remaining_calls

config

tg_value

focus

Many regular expressions can be separated by a space, for example: "/regex1/replace1/var1 /regex2/replace2/var2".

The char "/" can be replaced by any char (one or more identical chars).

Matching groups can be used in "replace":

  • ${re:0} to ${re:99}: ${re:0} is the whole match, ${re:1} to ${re:99} are groups captured

  • ${re:}+: the last match (with highest number)

  • ${hide:c,${re:N}}: match "N" with all chars replaced by "c" (example: ${hide:*,${re:2}} is the group #2 with all chars replaced by *).

Example: use bold for words between "*":

/\*(\S+)\*/*${color:bold}${re:1}${color:-bold}*/

Example: default trigger server_pass uses this regular expression to hide password in commands /server and /connect (chars in passwords are replaced by *):

==^(/(server|connect) .*-(sasl_)?password=)(\S+)(.*)==${re:1}${hide:*,${re:4}}${re:5}
In this example, the delimiter used is "==" because there is a "/" in the regular expression.

4.10.8. Command

The command is executed after replacement of text with the regular expression. Many commands can be separated by semicolons.

It is evaluated (see command /eval) and text replaced with a regular expression can be used in the command.

Example: default beep trigger uses this command to make a beep (BEL):

/print -beep

4.10.9. Data in callbacks

Data received in callbacks are stored in hashtables (pointers and strings) and can be used in following options:

  • conditions

  • regex

  • command

The content of hashtables depend on the hook type.

A convenient way to see data in a trigger is to open trigger monitor buffer, using the command:

/trigger monitor
Signal

The "signal" callback sets following variables in hashtable:

Variable Type Description

tg_signal

string

Name of signal.

tg_signal_data

string

Data sent with the signal.

If the signal contains an IRC message, the message is parsed and following data is added in hashtable:

Variable Type Description

server

string

Name of server (example: "freenode").

tags

string

Tags in message (rarely used).

message_without_tags

string

Message without tags.

nick

string

Nick.

host

string

Hostname.

command

string

IRC command (example: "PRIVMSG", "NOTICE", …​).

channel

string

IRC channel.

arguments

string

Arguments of command (includes value of channel).

text

string

Text (for example user message).

pos_command

string

The index of command in message ("-1" if command was not found).

pos_arguments

string

The index of arguments in message ("-1" if arguments was not found).

pos_channel

string

The index of channel in message ("-1" if channel was not found).

pos_text

string

The index of text in message ("-1" if text was not found).

When the data is a pointer, the variable tg_signal_data can be used like this to read a hdata property (in this example this is a pointer on a buffer):

${buffer[${tg_signal_data}].full_name}
Hsignal

The "hsignal" callback sets following variables in hashtable:

Variable Type Description

tg_signal

string

Name of signal.

The hashtable contains all keys/values from hashtable received (type: string/string).

Modifier

The "modifier" callback sets following variables in hashtable:

Variable Type Description

tg_modifier

string

Name of modifier.

tg_modifier_data

string

Data sent with modifier.

tg_string

string

The string that can be modified.

tg_string_nocolor

string

The string without color codes.

For the weechat_print modifier, variables using message tags are added (see hook print below), and following variables:

Variable Type Description

buffer

pointer

Buffer where message is printed.

tg_plugin

string

Plugin of buffer where message is printed.

tg_buffer

string

Full name of buffer where message is printed.

tg_prefix

string

Prefix of message printed.

tg_prefix_nocolor

string

Prefix without color codes.

tg_message

string

Message printed.

tg_message_nocolor

string

Message without color codes.

If the modifier contains an IRC message, the message is parsed and extra data is added in hashtable (see hook signal).

Print

The "print" callback sets following variables in hashtable:

Variable Type Description

buffer

pointer

Buffer.

tg_date

string

Message date/time (format: YYYY-MM-DD hh:mm:ss).

tg_displayed

string

"1" if displayed, "0" if line filtered.

tg_highlight

string

"1" if highlight, otherwise "0".

tg_prefix

string

Prefix.

tg_prefix_nocolor

string

Prefix without color codes.

tg_message

string

Message.

tg_message_nocolor

string

Message without color codes.

Variables set using tags in message (they are set in modifier weechat_print too):

Variable Type Description

tg_tags

string

Tags of message (with comma added at beginning/end of string).

tg_tags_count

string

Number of tags in message.

tg_tag_nick

string

Nick (from tag "nick_xxx").

tg_tag_prefix_nick

string

Color of nick in prefix (from tag "prefix_nick_ccc").

tg_tag_host

string

User name and host, format: username@host (from tag "host_xxx").

tg_tag_notify

string

Notify level (none, message, private, highlight).

tg_notify

string

Notify level, if different from none.

tg_msg_pv

string

"1" for a private message, otherwise "0".

Command

The "command" callback sets following variables in hashtable:

Variable Type Description

buffer

pointer

Buffer.

tg_argvN

string

Argument #N.

tg_argv_eolN

string

From argument #N until end of arguments.

Command_run

The "command_run" callback sets following variables in hashtable:

Variable Type Description

buffer

pointer

Buffer.

tg_command

string

Command executed.

Timer

The "timer" callback sets following variables in hashtable:

Variable Type Description

tg_remaining_calls

string

Number of remaining calls.

tg_date

string

Current date/time (format: YYYY-MM-DD hh:mm:ss).

Config

The "config" callback sets following variables in hashtable:

Variable Type Description

tg_option

string

Option.

tg_value

string

Value.

Focus

The "focus" callback sets following variables in hashtable:

Variable Type Description

window

pointer

Window.

buffer

pointer

Buffer.

The hashtable contains all keys/values from hashtable received (type: string/string).

4.10.10. Examples

Color for URLs

Display URLs in green:

/trigger add url_color modifier weechat_print "${tg_notify}" "==\S+://\S+==${color:green}${re:0}${color:reset}=="
The simple regex used to detect URL may not catch well all URLs, but it is faster than a complex regex.
Auto pong on ping queries

When someone sends a "ping" in a private buffer, this trigger will auto-reply with pong:

/trigger add pong print "" "${type} == private && ${tg_message} == ping" "" "pong"
Responsive layout

Following triggers can be used to customize things displayed when the size of terminal is changed:

/trigger add resize_small signal signal_sigwinch "${info:term_width} < 100" "" "/bar hide nicklist"
/trigger add resize_big signal signal_sigwinch "${info:term_width} >= 100" "" "/bar show nicklist"

The triggers catch the signal "signal_sigwinch", which is sent by WeeChat when signal SIGWINCH is received (when terminal size is changed).

The condition with ${info:term_width} checks the width of terminal (you can also use ${info:term_height} if needed).

In the example, when the terminal becomes small, the nicklist is hidden. And the bar is restored when the width is greater or equal to 100 chars.

Automatic save of configuration

You can automatically save configuration files (*.conf), for example each hour:

/trigger add cfgsave timer 3600000;0;0 "" "" "/mute /save"

Arguments for the timer hook are:

  • 3600000: 3600 * 1000 milliseconds, the callback is called each hour

  • 0: alignment on second (not aligned here)

  • 0: max number of calls (0 = no end for the timer)

The command /mute /save will silently save configuration files (nothing displayed on core buffer).

4.11. Plugin Xfer

Il plugin Xfer fornisce:

  • chat diretta (tra due host, senza server): per esempio "DCC Chat" tramite plugin IRC

  • trasferimento file, per esempio "DCC" tramite il plugin IRC

4.11.1. Opzioni (xfer.conf)

Sections:

Section Control command Description

look

/set xfer.look.*

Look and feel.

color

/set xfer.color.*

Colors.

network

/set xfer.network.*

Network options.

file

/set xfer.file.*

Options for files sent/received.

Options:

  • xfer.color.status_aborted

    • descrizione: colore del testo per lo status "annullato"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • xfer.color.status_active

    • descrizione: colore del testo per lo status "attivo"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightblue

  • xfer.color.status_connecting

    • descrizione: colore del testo per lo status "connessione in corso"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: yellow

  • xfer.color.status_done

    • descrizione: colore del testo per lo status "completato"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightgreen

  • xfer.color.status_failed

    • descrizione: colore del testo per lo status "fallito"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightred

  • xfer.color.status_waiting

    • descrizione: colore del testo per lo status "in attesa"

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: lightcyan

  • xfer.color.text

    • descrizione: colore del testo nel buffer xfer

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • xfer.color.text_bg

    • descrizione: colore di sfondo del buffer xfer

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: default

  • xfer.color.text_selected

    • descrizione: colore della riga selezionata nel buffer xfer

    • tipo: colore

    • valori: a WeeChat color name (default, black, (dark)gray, white, (light)red, (light)green, brown, yellow, (light)blue, (light)magenta, (light)cyan), a terminal color number or an alias; attributes are allowed before color (for text color only, not background): "*" for bold, "!" for reverse, "/" for italic, "_" for underline

    • valore predefinito: white

  • xfer.file.auto_accept_chats

    • descrizione: accetta automaticamente le richieste di chat (usare con cautela!)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • xfer.file.auto_accept_files

    • descrizione: accetta automaticamente i file in arrivo (usare con cautela!)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • xfer.file.auto_accept_nicks

    • descrizione: comma-separated list of nicks for which the incoming files and chats are automatically accepted; format is "server.nick" (for a specific server) or "nick" (for all servers); example: "freenode.FlashCode,andrew"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • xfer.file.auto_check_crc32

    • descrizione: automatically check CRC32 file checksum if it is found in the filename (8 hexadecimal chars)

    • tipo: bool

    • valori: on, off

    • valore predefinito: off

  • xfer.file.auto_rename

    • descrizione: rinomina i file in ingresso se esistenti (aggiunge ".1", ".2", ...)

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • xfer.file.auto_resume

    • descrizione: riprende automaticamente il trasferimento dei file se la connessione all'host viene perduta

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • xfer.file.convert_spaces

    • descrizione: convert spaces to underscores when sending and receiving files

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • xfer.file.download_path

    • descrizione: path for writing incoming files: "%h" at beginning of string is replaced by WeeChat home ("~/.weechat" by default) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "%h/xfer"

  • xfer.file.upload_path

    • descrizione: path for reading files when sending (when no path is specified by user): "%h" at beginning of string is replaced by WeeChat home ("~/.weechat" by default) (note: content is evaluated, see /help eval)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "~"

  • xfer.file.use_nick_in_filename

    • descrizione: usa il nick remoto come prefisso nel nome del file locale alla ricezione

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • xfer.look.auto_open_buffer

    • descrizione: apre automaticamente il buffer xfer quando un nuovo xfer viene aggiunto alla lista

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • xfer.look.progress_bar_size

    • descrizione: dimensione barra di avanzamento, in caratteri (se 0, è disabilitata)

    • tipo: intero

    • valori: 0 .. 256

    • valore predefinito: 20

  • xfer.look.pv_tags

    • descrizione: elenco separato da virgole di tag usati nei messaggi privati, ad esempio: "notify_message", "notify_private" o "notify_highlight"

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: "notify_private"

  • xfer.network.blocksize

    • descrizione: dimensione blocco per l'invio dei pacchetti, in byte

    • tipo: intero

    • valori: 1024 .. 102400

    • valore predefinito: 65536

  • xfer.network.fast_send

    • descrizione: non attendere ACK all'invio del file

    • tipo: bool

    • valori: on, off

    • valore predefinito: on

  • xfer.network.own_ip

    • descrizione: Indirizzo IP o DNS per l'invio di file/chat (se vuoto, verrà usata l'interfaccia IP locale)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • xfer.network.port_range

    • descrizione: forza i file in uscita/chat ad usare solo le porte in un dato intervallo (utile per il NAT) (sintassi: una singola porta, es. 5000 o un intervallo di porte, es. 5000-5015. Un valore nullo significa qualsiasi porta, consigliato usare porte maggiori di 1024, perché l'uso di porte inferiori è possibile solo per root)

    • tipo: stringa

    • valori: qualsiasi stringa

    • valore predefinito: ""

  • xfer.network.speed_limit

    • descrizione: limite di velocità per l'invio dei file, in kb per secondo (0 vuol dire senza limite)

    • tipo: intero

    • valori: 0 .. 2147483647

    • valore predefinito: 0

  • xfer.network.timeout

    • descrizione: timeout per la richiesta xfer (in secondi)

    • tipo: intero

    • valori: 5 .. 2147483647

    • valore predefinito: 300

4.11.2. Comandi

  • me: invia un’azione CTCP all’host remoto

/me  <messaggio>

messaggio: messaggio da inviare
  • xfer: controllo xfer

/xfer  [list|listfull]

    list: lista xfer
listfull: lista xfer (dettagliata)

Senza argomenti, il comando apre il buffer con la lista xfer.

5. Supporto

Before asking for support, be sure you’ve read documentation and FAQ provided with WeeChat.

For support with IRC, on server chat.freenode.net:

  • official channels (with developers):

    • #weechat (English)

    • #weechat-fr (French)

  • non-official channels:

    • #weechat-de (German)

For other ways of support, see: https://weechat.org/dev/support