mirror of
https://github.com/weechat/weechat.git
synced 2026-06-12 14:14:48 +02:00
core: change default key for bare display from alt-'!' to alt-'l'
This commit is contained in:
+1
-1
@@ -69,7 +69,7 @@ http://weechat.org/files/releasenotes/ReleaseNotes-devel.html[release notes]
|
||||
* core: add options "-beep" and "-current" in command /print
|
||||
* core: allow empty arguments for command /print
|
||||
* core: add bare display mode (for easy text selection and click on URLs), new
|
||||
key: key[alt-!], new option "bare" in command /window, new options:
|
||||
key: key[alt-l], new option "bare" in command /window, new options:
|
||||
weechat.look.bare_display_exit_on_input and
|
||||
weechat.look.bare_display_time_format
|
||||
* core: fix freeze/crash in gnutls (bug #41576)
|
||||
|
||||
@@ -87,7 +87,7 @@ obsolete plugins).
|
||||
=== Bare display
|
||||
|
||||
A bare display mode has been added (for easy text selection and click on URLs),
|
||||
the new default key is key[alt-!].
|
||||
the new default key is key[alt-l].
|
||||
|
||||
Use command `/key missing` to add the key or `/key listdiff` to see differences
|
||||
between your current keys and WeeChat default keys.
|
||||
|
||||
@@ -6,7 +6,6 @@ key\[([^,\]]+),([^\]]+)\]=key[\1], key[\2]
|
||||
key\[(ctrl|alt|shift)\]=<span class="key \1">\1</span>
|
||||
key\[(ctrl|alt|shift)-\]=<span class="key \1">\1</span><span class="keyplus">+</span>
|
||||
key\[(ctrl|alt|shift)-([^\]]+)\]=<span class="key \1">\1</span><span class="keyplus">+</span>key[\2]
|
||||
key\[l\]=<span class="key">l</span><span class="keyplus"> (L)</span>
|
||||
key\[([A-Za-z0-9/_&\=!-])\]=<span class="key">\1</span>
|
||||
key\[([a-z0-9/_&\=!-][^\]]*)\]=<span class="key">\1</span>
|
||||
key\[([^\]]+)\]=<span class="key other">\1</span>
|
||||
|
||||
@@ -227,7 +227,7 @@ werden sollte:
|
||||
[[terminal_copy_paste]]
|
||||
=== Wie kann ich einen Text kopieren und einfügen ohne das die Nickliste mit kopiert wird?
|
||||
|
||||
Ab WeeChat ≥ 1.0 kann ein einfacher Anzeigemodus genutzt werden (Standardtastenbelegung: key[alt-!]).
|
||||
Ab WeeChat ≥ 1.0 kann ein einfacher Anzeigemodus genutzt werden (Standardtastenbelegung: key[alt-l]).
|
||||
|
||||
Hierzu kannst Du ein Terminal nutzen welches Block-Auswahl erlaubt (wie z.B. rxvt-unicode,
|
||||
konsole, gnome-terminal, ...). Im Normalfall erfolgt die Markierung mittels der Tasten
|
||||
@@ -243,7 +243,7 @@ Bildschirm zu positionieren:
|
||||
[[urls]]
|
||||
=== Wie kann ich eine URL aufrufen die einen Zeilenumbruch besitzt?
|
||||
|
||||
Ab WeeChat ≥ 1.0 kann ein einfacher Anzeigemodus genutzt werden (Standardtastenbelegung: key[alt-!]).
|
||||
Ab WeeChat ≥ 1.0 kann ein einfacher Anzeigemodus genutzt werden (Standardtastenbelegung: key[alt-l]).
|
||||
|
||||
WeeChat stellt standardmäßig die Uhrzeit als auch einen Präfix in jeder
|
||||
Zeile dar. Optional können zusätzlich auch Bars im Chatfenster dargestellt
|
||||
|
||||
@@ -889,7 +889,7 @@ Der vereinfachte Anzeigemodus hat folgende Funktionen:
|
||||
wie in einem Terminal genutzt werden um URLs anzuklicken oder Text zu markieren
|
||||
* ncurses wird nicht genutzt, deshalb werden URLs nicht am Ende der Zeile angeschnitten.
|
||||
|
||||
Der Standardtastenbefehl um den vereinfachten Textmodus zu aktivieren ist key[alt-!],
|
||||
Der Standardtastenbefehl um den vereinfachten Textmodus zu aktivieren ist key[alt-l],
|
||||
mit dem selben Tastenbefehl wird dieser Modus wieder beendet (es kann auch mit jeder
|
||||
beliegen Tasteneingabe der Modus beendet werden, siehe Option
|
||||
<<option_weechat.look.bare_display_exit_on_input,weechat.look.bare_display_exit_on_input>>).
|
||||
@@ -1100,6 +1100,7 @@ Befehl festgelegt werden:
|
||||
| key[alt-j,alt-s] | wechselt zum IRC Server Buffer | `/server jump`
|
||||
| key[alt-0...9] | wechselt zum Buffer mit der Nummer (0 = 10) | `/buffer *N`
|
||||
| key[alt-j,01...99] | wechselt zum Buffer mit der angegeben Nummer | `/buffer NN`
|
||||
| key[alt-l] | schaltet einfachen Anzeigemodus an/aus | `/window bare`
|
||||
| key[alt-m] | schaltet Mausfunktion ein/aus | `/mouse toggle`
|
||||
| key[alt-n] | springt zur nächsten Highlight Nachricht | `/window scroll_next_highlight`
|
||||
| key[alt-p] | springt zur vorherigen Highlight Nachricht | `/window scroll_previous_highlight`
|
||||
@@ -1116,7 +1117,6 @@ Befehl festgelegt werden:
|
||||
| key[alt-/] | wechselt zum jeweils zuletzt angezeigten Buffern | `/input jump_last_buffer_displayed`
|
||||
| key[alt-=] | schaltet Filterfunktion an/aus | `/filter toggle`
|
||||
| key[alt--] | schaltet, für den aktuellen Buffer, Filterfunktion an/aus | `/filter toggle @`
|
||||
| key[alt-!] | schaltet einfachen Anzeigemodus an/aus | `/window bare`
|
||||
|===
|
||||
|
||||
[[key_bindings_search_context]]
|
||||
|
||||
@@ -216,7 +216,7 @@ any bar:
|
||||
[[terminal_copy_paste]]
|
||||
=== How can I copy/paste text without pasting nicklist?
|
||||
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-!]).
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-l]).
|
||||
|
||||
You can use a terminal with rectangular selection (like rxvt-unicode,
|
||||
konsole, gnome-terminal, ...). Key is usually key[ctrl-]key[alt-] mouse
|
||||
@@ -231,7 +231,7 @@ Another solution is to move nicklist to top or bottom, for example:
|
||||
[[urls]]
|
||||
=== How can I click on long URLs (more than one line)?
|
||||
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-!]).
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-l]).
|
||||
|
||||
By default, WeeChat displays time and prefix for each line and optional bars
|
||||
around chat area. To make easier URL click, you can move nicklist to top and
|
||||
|
||||
@@ -878,7 +878,7 @@ The bare display has following features:
|
||||
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 key[alt-!], and same key to exit (or
|
||||
The default key to enabled bare display is key[alt-l], and same key to exit (or
|
||||
by default anything changing the input will exit the bare display, see option
|
||||
<<option_weechat.look.bare_display_exit_on_input,weechat.look.bare_display_exit_on_input>>).
|
||||
|
||||
@@ -1084,6 +1084,7 @@ The notify level for a buffer can be set with command `/buffer`:
|
||||
| key[alt-j,alt-s] | Switch to IRC server buffer | `/server jump`
|
||||
| key[alt-0...9] | Switch to buffer by number (0 = 10) | `/buffer *N`
|
||||
| key[alt-j,01...99] | Switch to buffer by number | `/buffer NN`
|
||||
| key[alt-l] | Toggle bare display on/off | `/window bare`
|
||||
| key[alt-m] | Toggle mouse | `/mouse toggle`
|
||||
| key[alt-n] | Scroll to next highlight | `/window scroll_next_highlight`
|
||||
| key[alt-p] | Scroll to previous highlight | `/window scroll_previous_highlight`
|
||||
@@ -1100,7 +1101,6 @@ The notify level for a buffer can be set with command `/buffer`:
|
||||
| key[alt-/] | Switch to last buffer displayed (before last jump to a buffer) | `/input jump_last_buffer_displayed`
|
||||
| key[alt-=] | Toggle filters on/off | `/filter toggle`
|
||||
| key[alt--] | Toggle filters on/off in current buffer | `/filter toggle @`
|
||||
| key[alt-!] | Toggle bare display on/off | `/window bare`
|
||||
|===
|
||||
|
||||
[[key_bindings_search_context]]
|
||||
|
||||
@@ -223,7 +223,7 @@ barre, WeeChat recréera automatiquement la barre par défaut "input" si l'objet
|
||||
=== Comment puis-je copier/coller du texte sans coller la liste des pseudos ?
|
||||
|
||||
Avec WeeChat ≥ 1.0, vous pouvez utiliser l'affichage dépouillé (touche par
|
||||
défaut : key[alt-!]).
|
||||
défaut : key[alt-l]).
|
||||
|
||||
Vous pouvez utiliser un terminal qui propose la sélection rectangulaire (comme
|
||||
rxvt-unicode, konsole, gnome-terminal, etc...). La touche est habituellement
|
||||
@@ -240,7 +240,7 @@ exemple :
|
||||
=== Comment puis-je cliquer sur les longs URLs (plus d'une ligne) ?
|
||||
|
||||
Avec WeeChat ≥ 1.0, vous pouvez utiliser l'affichage dépouillé (touche par
|
||||
défaut : key[alt-!]).
|
||||
défaut : key[alt-l]).
|
||||
|
||||
Par défaut, WeeChat affiche l'heure et un préfixe pour chaque ligne avec des
|
||||
barres optionnelles autour de la zone de discussion. Pour rendre la le clic
|
||||
|
||||
@@ -904,7 +904,7 @@ L'affichage dépouillé a les caractéristiques suivantes :
|
||||
* ncurses n'est pas utilisé, par conséquent les URLs ne sont pas coupés en fin
|
||||
de ligne.
|
||||
|
||||
La touche par défaut pour activer l'affichage dépouillé est key[alt-!], et la
|
||||
La touche par défaut pour activer l'affichage dépouillé est key[alt-l], et la
|
||||
même touche pour en sortir (ou par défaut tout changement dans la ligne de
|
||||
commande sortira de l'affichage dépouillé, voir l'option
|
||||
<<option_weechat.look.bare_display_exit_on_input,weechat.look.bare_display_exit_on_input>>).
|
||||
@@ -1113,6 +1113,7 @@ commande `/buffer` :
|
||||
| key[alt-j,alt-s] | Sauter au tampon IRC du serveur | `/server jump`
|
||||
| key[alt-0...9] | Sauter au tampon qui porte ce numéro (0 = 10) | `/buffer *N`
|
||||
| key[alt-j,01...99] | Sauter au tampon qui porte ce numéro | `/buffer NN`
|
||||
| key[alt-l] | Activer/désactiver le mode d'affichage dépouillé | `/window bare`
|
||||
| key[alt-m] | Activer/désactiver la souris | `/mouse toggle`
|
||||
| key[alt-n] | Se positionner sur le highlight suivant | `/window scroll_next_highlight`
|
||||
| key[alt-p] | Se positionner sur le highlight précédent | `/window scroll_previous_highlight`
|
||||
@@ -1129,7 +1130,6 @@ commande `/buffer` :
|
||||
| key[alt-/] | Sauter au dernier tampon affiché (avant le dernier saut vers un tampon) | `/input jump_last_buffer_displayed`
|
||||
| key[alt-=] | Activer/désactiver les filtres | `/filter toggle`
|
||||
| key[alt--] | Activer/désactiver les filtres dans le tampon courant | `/filter toggle @`
|
||||
| key[alt-!] | Activer/désactiver le mode d'affichage dépouillé | `/window bare`
|
||||
|===
|
||||
|
||||
[[key_bindings_search_context]]
|
||||
|
||||
@@ -226,7 +226,7 @@ non viene usato da un'altra barra:
|
||||
=== Come posso copiare/incollare testo senza incollare la lista nick?
|
||||
|
||||
// TRANSLATION MISSING
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-!]).
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-l]).
|
||||
|
||||
È possibile usare un terminale con la selezione rettangolare (come
|
||||
rxvt-unicode, konsole, gnome-terminal, ...). La combinazione tasti in
|
||||
@@ -242,7 +242,7 @@ Un'altra soluzione è spostare la lista nick in alto o in basso, per esempio:
|
||||
=== Come posso cliccare su URL lunghi (più di una riga)?
|
||||
|
||||
// TRANSLATION MISSING
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-!]).
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-l]).
|
||||
|
||||
Con le impostazioni predefinite, WeeChat mostra l'ora ed il prefisso per ogni
|
||||
riga e le barre opzionali intorno all'area di chat. Per facilitare il clic
|
||||
|
||||
@@ -912,7 +912,7 @@ The bare display has following features:
|
||||
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 key[alt-!], and same key to exit (or
|
||||
The default key to enabled bare display is key[alt-l], and same key to exit (or
|
||||
by default anything changing the input will exit the bare display, see option
|
||||
<<option_weechat.look.bare_display_exit_on_input,weechat.look.bare_display_exit_on_input>>).
|
||||
|
||||
@@ -1122,6 +1122,8 @@ Il livello di notifica per un buffer può essere impostato con il comando `/buff
|
||||
| key[alt-j,alt-s] | Passa al buffer server IRC | `/server jump`
|
||||
| key[alt-0...9] | Passa al buffer numero (0 = 10) | `/buffer *N`
|
||||
| key[alt-j,01...99] | Passa al buffer numero | `/buffer NN`
|
||||
// TRANSLATION MISSING
|
||||
| key[alt-l] | Toggle bare display on/off | `/window bare`
|
||||
| key[alt-m] | Abilita/disabilita | `/mouse toggle`
|
||||
| key[alt-n] | Scorre fino alla notifica successiva | `/window scroll_next_highlight`
|
||||
| key[alt-p] | Scorre fino alla notifica precedente | `/window scroll_previous_highlight`
|
||||
@@ -1139,8 +1141,6 @@ Il livello di notifica per un buffer può essere impostato con il comando `/buff
|
||||
| key[alt-=] | Attiva/disattiva filtri | `/filter toggle`
|
||||
// TRANSLATION MISSING
|
||||
| key[alt--] | Toggle filters on/off in current buffer | `/filter toggle @`
|
||||
// TRANSLATION MISSING
|
||||
| key[alt-!] | Toggle bare display on/off | `/window bare`
|
||||
|===
|
||||
|
||||
[[key_bindings_search_context]]
|
||||
|
||||
@@ -216,7 +216,7 @@ WeeChat は自動的にデフォルトバー "input" を作成します:
|
||||
[[terminal_copy_paste]]
|
||||
=== どうすればニックネームリストを選択せずにテキストだけをコピー/ペーストできますか。
|
||||
|
||||
WeeChat ≥ 1.0 では、最小限表示を使うことができます (デフォルトキー: key[alt-!])。
|
||||
WeeChat ≥ 1.0 では、最小限表示を使うことができます (デフォルトキー: key[alt-l])。
|
||||
|
||||
矩形選択のできるターミナルを使ってください (rxvt-unicode、
|
||||
konsole、gnome-terminal、...)。通常、キーは key[ctrl-]key[alt-] マウス選択です。
|
||||
@@ -230,7 +230,7 @@ konsole、gnome-terminal、...)。通常、キーは key[ctrl-]key[alt-] マウ
|
||||
[[urls]]
|
||||
=== どうすれば長い (一行以上に渡る) URL をクリックできますか。
|
||||
|
||||
WeeChat ≥ 1.0 では、最小限表示を使うことができます (デフォルトキー: key[alt-!])。
|
||||
WeeChat ≥ 1.0 では、最小限表示を使うことができます (デフォルトキー: key[alt-l])。
|
||||
|
||||
デフォルトでは、WeeChat はそれぞれの行の最初に時間とプレフィックス、
|
||||
さらにチャットエリアを囲むようにオプションバーを表示します。url のクリックを簡単にするには、
|
||||
|
||||
@@ -877,7 +877,7 @@ URL を簡単にクリックしたり、テキストを簡単に選択できる
|
||||
ターミナルでやるのと同じように URL をクリックしたりテキストを選択できます
|
||||
* ncurses を使わない、このため URL を行の最後で分断されることがなくなります。
|
||||
|
||||
最小限表示を有効化するデフォルトキーは key[alt-!] で、終了するには同じキーを押してください
|
||||
最小限表示を有効化するデフォルトキーは key[alt-l] で、終了するには同じキーを押してください
|
||||
(また、デフォルトでは入力が変更された場合に最小限表示を終了します、<<option_weechat.look.bare_display_exit_on_input,weechat.look.bare_display_exit_on_input>>
|
||||
オプションを参照)。
|
||||
|
||||
@@ -1083,6 +1083,7 @@ irc サーバ "freenode" に含まれる全てのバッファに対して設定
|
||||
| key[alt-j,alt-s] | IRC サーババッファに移動 | `/server jump`
|
||||
| key[alt-0...9] | 番号のバッファに移動 (0 = 10) | `/buffer *N`
|
||||
| key[alt-j,01...99] | 番号のバッファに移動 | `/buffer NN`
|
||||
| key[alt-l] | 最小限表示の有効無効を切り替え | `/window bare`
|
||||
| key[alt-m] | マウスの有効無効を切り替え | `/mouse toggle`
|
||||
| key[alt-n] | 次のハイライトまでスクロール | `/window scroll_next_highlight`
|
||||
| key[alt-p] | 前のハイライトまでスクロール | `/window scroll_previous_highlight`
|
||||
@@ -1099,7 +1100,6 @@ irc サーバ "freenode" に含まれる全てのバッファに対して設定
|
||||
| key[alt-/] | 最後に表示したバッファに移動 (バッファ移動前に表示していたウィンドウ) | `/input jump_last_buffer_displayed`
|
||||
| key[alt-=] | フィルタの有効無効を切り替え | `/filter toggle`
|
||||
| key[alt--] | 現在のバッファのフィルタの有効無効を切り替え | `/filter toggle @`
|
||||
| key[alt-!] | 最小限表示の有効無効を切り替え | `/window bare`
|
||||
|===
|
||||
|
||||
[[key_bindings_search_context]]
|
||||
|
||||
@@ -219,7 +219,7 @@ użyty w żadnym z pasków:
|
||||
=== Jak mogę kopiować/wklejać tekst bez wklejania listy nicków?
|
||||
|
||||
// TRANSLATION MISSING
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-!]).
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-l]).
|
||||
|
||||
Możesz użyć terminala z prostokątnym zaznaczaniem (jak rxvt-unicode,
|
||||
konsole, gnome-terminal, ...). Klawisze to zazwyczaj key[ctrl-]key[alt-] zaznaczenie myszką.
|
||||
@@ -234,7 +234,7 @@ Innym rozwiązaniem jest przesunięcie listy nicków na górę lub dół, na prz
|
||||
=== Jak mogę kliknąć na długi URL (dłuższy niż linia)?
|
||||
|
||||
// TRANSLATION MISSING
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-!]).
|
||||
With WeeChat ≥ 1.0, you can use the bare display (default key: key[alt-l]).
|
||||
|
||||
Domyślnie WeeChat wyświetla czas i przedrostki dla każdej linii i opcjonalne paski
|
||||
dookoła obszaru rozmowy. Aby usprawnić klikanie w urle można przesunąć listę nicków
|
||||
|
||||
@@ -885,7 +885,7 @@ The bare display has following features:
|
||||
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 key[alt-!], and same key to exit (or
|
||||
The default key to enabled bare display is key[alt-l], and same key to exit (or
|
||||
by default anything changing the input will exit the bare display, see option
|
||||
<<option_weechat.look.bare_display_exit_on_input,weechat.look.bare_display_exit_on_input>>).
|
||||
|
||||
@@ -1093,6 +1093,8 @@ Poziom powiadomień dla bufora może zostać ustawiony za pomocą komendy `/buff
|
||||
| key[alt-j,alt-s] | Przełącz na bufor serwera IRC | `/server jump`
|
||||
| key[alt-0...9] | Przełącz na bufor za pomocą liczb (0 = 10) | `/buffer *N`
|
||||
| key[alt-j,01...99] | Przełącz na bufor za pomocą liczb | `/buffer NN`
|
||||
// TRANSLATION MISSING
|
||||
| key[alt-l] | Toggle bare display on/off | `/window bare`
|
||||
| key[alt-m] | Przełącz obsługę myszy | `/mouse toggle`
|
||||
| key[alt-n] | Przewiń do następnego powiadomienia | `/window scroll_next_highlight`
|
||||
| key[alt-p] | Przewiń do poprzedniego powiadomienia | `/window scroll_previous_highlight`
|
||||
@@ -1110,8 +1112,6 @@ Poziom powiadomień dla bufora może zostać ustawiony za pomocą komendy `/buff
|
||||
| key[alt-=] | Włącz/wyłącz filtry | `/filter toggle`
|
||||
// TRANSLATION MISSING
|
||||
| key[alt--] | Toggle filters on/off in current buffer | `/filter toggle @`
|
||||
// TRANSLATION MISSING
|
||||
| key[alt-!] | Toggle bare display on/off | `/window bare`
|
||||
|===
|
||||
|
||||
[[key_bindings_search_context]]
|
||||
|
||||
@@ -216,7 +216,7 @@ gui_key_default_bindings (int context)
|
||||
BIND(/* m-m */ "meta-m", "/mute mouse toggle");
|
||||
BIND(/* start paste */ "meta2-200~", "/input paste_start");
|
||||
BIND(/* end paste */ "meta2-201~", "/input paste_stop");
|
||||
BIND(/* bare display*/ "meta-!", "/window bare");
|
||||
BIND(/* bare display*/ "meta-l", "/window bare");
|
||||
|
||||
/* bind meta-j + {01..99} to switch to buffers # > 10 */
|
||||
for (i = 1; i < 100; i++)
|
||||
|
||||
+90
-81
@@ -19,38 +19,38 @@
|
||||
# along with WeeChat. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
|
||||
#
|
||||
# weercd - the WeeChat IRC testing server
|
||||
#
|
||||
# It can be used with any IRC client (not only WeeChat).
|
||||
#
|
||||
# In the "flood" mode, various IRC commands are sent in a short time (privmsg,
|
||||
# notice, join/quit, ..) to test client resistance and memory usage (to quickly
|
||||
# detect memory leaks, for example with client scripts).
|
||||
#
|
||||
# This script works with Python 2.x (>= 2.7) and 3.x.
|
||||
#
|
||||
# It is *STRONGLY RECOMMENDED* to connect this server with a client in a test
|
||||
# environment:
|
||||
# - for WeeChat, another home with: `weechat --dir /tmp/weechat`
|
||||
# - on a test machine, because CPU will be used a lot by client to display
|
||||
# messages from weercd
|
||||
# - if possible locally (ie server and client on same machine), to speed up
|
||||
# data exchange between server and client.
|
||||
#
|
||||
# Instructions to use this server with WeeChat:
|
||||
# 1. open a terminal and run server:
|
||||
# python weercd.py
|
||||
# 2. open another terminal and run WeeChat with home in /tmp:
|
||||
# weechat --dir /tmp/weechat
|
||||
# 3. optional: install script(s) (/script install ...)
|
||||
# 4. add server and connect to it:
|
||||
# /server add weercd 127.0.0.1/7777
|
||||
# /connect weercd
|
||||
# 5. wait some months.....
|
||||
# WeeChat still not crashed and does not use 200 TB of RAM ?
|
||||
# Yeah, it's stable \o/
|
||||
#
|
||||
"""
|
||||
weercd - the WeeChat IRC testing server
|
||||
|
||||
It can be used with any IRC client (not only WeeChat).
|
||||
|
||||
In the "flood" mode, various IRC commands are sent in a short time (privmsg,
|
||||
notice, join/quit, ..) to test client resistance and memory usage (to quickly
|
||||
detect memory leaks, for example with client scripts).
|
||||
|
||||
This script works with Python 2.x (>= 2.7) and 3.x.
|
||||
|
||||
It is *STRONGLY RECOMMENDED* to connect this server with a client in a test
|
||||
environment:
|
||||
- for WeeChat, another home with: `weechat --dir /tmp/weechat`
|
||||
- on a test machine, because CPU will be used a lot by client to display
|
||||
messages from weercd
|
||||
- if possible locally (ie server and client on same machine), to speed up
|
||||
data exchange between server and client.
|
||||
|
||||
Instructions to use this server with WeeChat:
|
||||
1. open a terminal and run server:
|
||||
python weercd.py
|
||||
2. open another terminal and run WeeChat with home in /tmp:
|
||||
weechat --dir /tmp/weechat
|
||||
3. optional: install script(s) (/script install ...)
|
||||
4. add server and connect to it:
|
||||
/server add weercd 127.0.0.1/7777
|
||||
/connect weercd
|
||||
5. wait some months.....
|
||||
WeeChat still not crashed and does not use 200 TB of RAM ?
|
||||
Yeah, it's stable!
|
||||
"""
|
||||
|
||||
from __future__ import division, print_function
|
||||
|
||||
@@ -70,9 +70,32 @@ NAME = 'weercd'
|
||||
VERSION = '0.8'
|
||||
|
||||
|
||||
class Client:
|
||||
def fuzzy_string(minlength=1, maxlength=50, spaces=False):
|
||||
"""Return a fuzzy string (random length and content)."""
|
||||
length = random.randint(minlength, maxlength)
|
||||
strspace = ''
|
||||
if spaces:
|
||||
strspace = ' '
|
||||
return ''.join(random.choice(string.ascii_uppercase +
|
||||
string.ascii_lowercase +
|
||||
string.digits + strspace)
|
||||
for x in range(length))
|
||||
|
||||
def __init__(self, sock, addr, args, **kwargs):
|
||||
|
||||
def fuzzy_host():
|
||||
"""Return a fuzzy host name."""
|
||||
return '{0}@{1}'.format(fuzzy_string(1, 10), fuzzy_string(1, 10))
|
||||
|
||||
|
||||
def fuzzy_channel():
|
||||
"""Return a fuzzy channel name."""
|
||||
return '#{0}'.format(fuzzy_string(1, 25))
|
||||
|
||||
|
||||
class Client(object):
|
||||
"""A client of weercd server."""
|
||||
|
||||
def __init__(self, sock, addr, args):
|
||||
self.sock, self.addr = sock, addr
|
||||
self.args = args
|
||||
self.name = NAME
|
||||
@@ -105,43 +128,24 @@ class Client:
|
||||
try:
|
||||
while not self.quit:
|
||||
self.flood()
|
||||
except Exception as e:
|
||||
except Exception as exc:
|
||||
if self.quit:
|
||||
self.endmsg = 'quit received'
|
||||
else:
|
||||
self.endmsg = 'connection lost'
|
||||
self.endexcept = e
|
||||
self.endexcept = exc
|
||||
except KeyboardInterrupt:
|
||||
self.endmsg = 'interrupted'
|
||||
else:
|
||||
self.endmsg = 'quit received'
|
||||
|
||||
def fuzzy_str(self, minlength=1, maxlength=50, spaces=False):
|
||||
"""Return a fuzzy string (random length and content)."""
|
||||
length = random.randint(minlength, maxlength)
|
||||
strspace = ''
|
||||
if spaces:
|
||||
strspace = ' '
|
||||
return ''.join(random.choice(string.ascii_uppercase +
|
||||
string.ascii_lowercase +
|
||||
string.digits + strspace)
|
||||
for x in range(length))
|
||||
|
||||
def fuzzy_host(self):
|
||||
"""Return a fuzzy host name."""
|
||||
return '{0}@{1}'.format(self.fuzzy_str(1, 10), self.fuzzy_str(1, 10))
|
||||
|
||||
def fuzzy_nick(self, with_number=False):
|
||||
"""Return a fuzzy nick name."""
|
||||
if with_number:
|
||||
self.nicknumber += 1
|
||||
return '{0}{1}'.format(self.fuzzy_str(1, 5), self.nicknumber)
|
||||
return '{0}{1}'.format(fuzzy_string(1, 5), self.nicknumber)
|
||||
else:
|
||||
return self.fuzzy_str(1, 10)
|
||||
|
||||
def fuzzy_chan(self):
|
||||
"""Return a fuzzy channel name."""
|
||||
return '#{0}'.format(self.fuzzy_str(1, 25))
|
||||
return fuzzy_string(1, 10)
|
||||
|
||||
def send(self, data):
|
||||
"""Send one message to client."""
|
||||
@@ -177,9 +181,9 @@ class Client:
|
||||
elif data.startswith('NICK '):
|
||||
self.nick = data[5:]
|
||||
elif data.startswith('PART '):
|
||||
m = re.search('^PART :?(#[^ ]+)', data)
|
||||
if m:
|
||||
channel = m.group(1)
|
||||
match = re.search('^PART :?(#[^ ]+)', data)
|
||||
if match:
|
||||
channel = match.group(1)
|
||||
if channel in self.channels:
|
||||
del self.channels[channel]
|
||||
elif data.startswith('QUIT '):
|
||||
@@ -188,7 +192,7 @@ class Client:
|
||||
|
||||
def read(self, timeout):
|
||||
"""Read raw data received from client."""
|
||||
inr, outr, exceptr = select.select([self.sock], [], [], timeout)
|
||||
inr = select.select([self.sock], [], [], timeout)[0]
|
||||
if inr:
|
||||
data = self.sock.recv(4096)
|
||||
if data:
|
||||
@@ -236,7 +240,7 @@ class Client:
|
||||
|
||||
def flood_self_join(self):
|
||||
"""Self join on a new channel."""
|
||||
channel = self.fuzzy_chan()
|
||||
channel = fuzzy_channel()
|
||||
if channel in self.channels:
|
||||
return
|
||||
self.send_cmd('JOIN', channel,
|
||||
@@ -249,8 +253,8 @@ class Client:
|
||||
|
||||
def flood_user_notice(self):
|
||||
"""Notice for the user."""
|
||||
self.send_cmd('NOTICE', self.fuzzy_str(1, 400, spaces=True),
|
||||
nick=self.fuzzy_nick(), host=self.fuzzy_host())
|
||||
self.send_cmd('NOTICE', fuzzy_string(1, 400, spaces=True),
|
||||
nick=self.fuzzy_nick(), host=fuzzy_host())
|
||||
|
||||
def flood_channel_join(self, channel):
|
||||
"""Join of a user in a channel."""
|
||||
@@ -258,7 +262,7 @@ class Client:
|
||||
return
|
||||
newnick = self.fuzzy_nick(with_number=True)
|
||||
self.send_cmd('JOIN', channel,
|
||||
nick=newnick, host=self.fuzzy_host(), target='')
|
||||
nick=newnick, host=fuzzy_host(), target='')
|
||||
self.channels[channel].append(newnick)
|
||||
|
||||
def flood_channel_part(self, channel):
|
||||
@@ -270,10 +274,10 @@ class Client:
|
||||
return
|
||||
if random.randint(1, 2) == 1:
|
||||
self.send_cmd('PART', channel,
|
||||
nick=rnick, host=self.fuzzy_host(), target='')
|
||||
nick=rnick, host=fuzzy_host(), target='')
|
||||
else:
|
||||
self.send_cmd('QUIT', self.fuzzy_str(1, 30),
|
||||
nick=rnick, host=self.fuzzy_host(), target='')
|
||||
self.send_cmd('QUIT', fuzzy_string(1, 30),
|
||||
nick=rnick, host=fuzzy_host(), target='')
|
||||
self.channels[channel].remove(rnick)
|
||||
|
||||
def flood_channel_kick(self, channel):
|
||||
@@ -283,8 +287,8 @@ class Client:
|
||||
rnick1 = self.channel_random_nick(channel)
|
||||
rnick2 = self.channel_random_nick(channel)
|
||||
if rnick1 and rnick2 and rnick1 != rnick2:
|
||||
self.send_cmd('KICK', self.fuzzy_str(1, 50),
|
||||
nick=rnick1, host=self.fuzzy_host(),
|
||||
self.send_cmd('KICK', fuzzy_string(1, 50),
|
||||
nick=rnick1, host=fuzzy_host(),
|
||||
target='{0} {1}'.format(channel, rnick2))
|
||||
self.channels[channel].remove(rnick2)
|
||||
|
||||
@@ -295,11 +299,11 @@ class Client:
|
||||
rnick = self.channel_random_nick(channel)
|
||||
if not rnick:
|
||||
return
|
||||
msg = self.fuzzy_str(1, 400, spaces=True)
|
||||
msg = fuzzy_string(1, 400, spaces=True)
|
||||
if 'channel' in self.args.notice and random.randint(1, 100) == 100:
|
||||
# notice for channel
|
||||
self.send_cmd('NOTICE', msg,
|
||||
nick=rnick, host=self.fuzzy_host(), target=channel)
|
||||
nick=rnick, host=fuzzy_host(), target=channel)
|
||||
else:
|
||||
# add random highlight
|
||||
if random.randint(1, 100) == 100:
|
||||
@@ -312,7 +316,7 @@ class Client:
|
||||
# CTCP version
|
||||
msg = '\x01VERSION\x01'
|
||||
self.send_cmd('PRIVMSG', msg,
|
||||
nick=rnick, host=self.fuzzy_host(), target=channel)
|
||||
nick=rnick, host=fuzzy_host(), target=channel)
|
||||
|
||||
def flood(self):
|
||||
"""Yay, funny stuff here! Flood the client!"""
|
||||
@@ -360,11 +364,11 @@ class Client:
|
||||
self.send(message.format(self=self))
|
||||
count += 1
|
||||
self.read(0.1 if stdin else self.args.sleep)
|
||||
except IOError as e:
|
||||
except IOError as exc:
|
||||
self.endmsg = 'unable to read file {0}'.format(self.args.file)
|
||||
self.endexcept = e
|
||||
self.endexcept = exc
|
||||
return
|
||||
except Exception as e:
|
||||
except Exception as exc:
|
||||
traceback.print_exc()
|
||||
self.endmsg = 'connection lost'
|
||||
return
|
||||
@@ -378,7 +382,7 @@ class Client:
|
||||
sys.stdout.flush()
|
||||
try:
|
||||
sys.stdin.readline()
|
||||
except:
|
||||
except Exception:
|
||||
pass
|
||||
|
||||
def stats(self):
|
||||
@@ -400,14 +404,16 @@ class Client:
|
||||
countrate=countrate,
|
||||
bytesrate=bytesrate))
|
||||
if self.endmsg == 'connection lost':
|
||||
print('Uh-oh! No quit received, client has crashed? Ahah \o/')
|
||||
print('Uh-oh! No quit received, client has crashed? Ahah \\o/')
|
||||
|
||||
def __del__(self):
|
||||
self.stats()
|
||||
print('Closing connection with', self.addr)
|
||||
self.sock.close()
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
||||
def main():
|
||||
"""Main function."""
|
||||
# parse command line arguments
|
||||
parser = argparse.ArgumentParser(
|
||||
formatter_class=argparse.ArgumentDefaultsHelpFormatter,
|
||||
@@ -457,8 +463,8 @@ if __name__ == "__main__":
|
||||
servsock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||
servsock.bind((args.host or '', args.port))
|
||||
servsock.listen(1)
|
||||
except Exception as e:
|
||||
print('Socket error: {0}'.format(e))
|
||||
except Exception as exc:
|
||||
print('Socket error: {0}'.format(exc))
|
||||
sys.exit(1)
|
||||
print('Listening on port', args.port, '(ctrl-C to exit)')
|
||||
clientsock = None
|
||||
@@ -475,3 +481,6 @@ if __name__ == "__main__":
|
||||
# no loop if message were sent from a file
|
||||
if args.file:
|
||||
break
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
||||
Reference in New Issue
Block a user