1
0
mirror of https://github.com/weechat/weechat.git synced 2026-07-03 16:23:14 +02:00

Add smart join/part/quit message filter in IRC plugin, add names for filters

This commit is contained in:
Sebastien Helleu
2008-10-25 19:13:43 +02:00
parent 707034442a
commit b712ed09d7
19 changed files with 992 additions and 379 deletions
+2 -1
View File
@@ -1,10 +1,11 @@
WeeChat - Wee Enhanced Environment for Chat
===========================================
ChangeLog - 2008-10-19
ChangeLog - 2008-10-25
Version 0.2.7 (under dev!):
* add smart join/part/quit filter in IRC plugin (task #8503)
* add color decoding in title for IRC channels (task #6030)
* fix lock with SSL servers when connection fails, and when disconnecting
during connection problem (bug #17584)
+57 -22
View File
@@ -6,7 +6,7 @@ msgid ""
msgstr ""
"Project-Id-Version: WeeChat 0.2.7-dev\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: 2008-09-17 16:19+0200\n"
"Last-Translator: Jiri Golembiovsky <golemj@gmail.com>\n"
"Language-Team: weechat-dev <weechat-dev@nongnu.org>\n"
@@ -238,7 +238,7 @@ msgid "Message filters:"
msgstr "Filtry zpráv:"
#, fuzzy, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " (není obsluhovač zprávy)\n"
#, fuzzy
@@ -250,19 +250,15 @@ msgid "No message filter defined"
msgstr "Žádné aliasy nejsou definovány.\n"
#, fuzzy, c-format
msgid "Filter %d enabled"
msgid "Filter \"%s\" enabled"
msgstr "Filtry povoleny"
#, fuzzy, c-format
msgid "%sError: filter not found"
msgid "%sError: filter \"%s\" not found"
msgstr "%s plugin \"%s\" nenalezen\n"
#, fuzzy, c-format
msgid "%sError: wrong filter number"
msgstr "%s nekorektní číslo bufferu\n"
#, fuzzy, c-format
msgid "Filter %d disabled"
msgid "Filter \"%s\" disabled"
msgstr "uživatel byl zablokován"
#, fuzzy, c-format
@@ -273,20 +269,28 @@ msgstr "%s ignorování již existuje\n"
msgid "%sError: you must specify at least tag(s) or regex for filter"
msgstr "%sChyba: musíte specifikovat buď tag(y) nebo regulární výrazpro filter"
#, fuzzy
msgid "Filter added"
msgstr "uživatel byl zablokován"
#, fuzzy, c-format
msgid "Filter \"%s\" added"
msgstr "Filtry povoleny"
#, fuzzy, c-format
msgid "%sError adding filter"
msgstr "%s nekorektní číslo bufferu\n"
#, fuzzy, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr "Filtry povoleny"
#, fuzzy, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr "%s neznámá volba pro příkaz \"%s\"\n"
#, fuzzy
msgid "All filters have been deleted"
msgstr "uživatel byl zablokován"
#, fuzzy
msgid "Filter deleted"
#, fuzzy, c-format
msgid "Filter \"%s\" deleted"
msgstr "uživatel byl zablokován"
#. TRANSLATORS: %s is "weechat"
@@ -812,8 +816,8 @@ msgstr ""
#, fuzzy
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
"[list] | [enable|disable|toggle] | [add buffer tagy regex] | [del číslo]"
@@ -823,9 +827,9 @@ msgid ""
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -835,14 +839,16 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
" list: seznam všech filtrů\n"
" enable: povolit filtry (filtry jsou defaultně povoleny)\n"
@@ -3359,6 +3365,11 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr "%s špatné parametry pro příkaz \"%s\"\n"
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
#, fuzzy, c-format
msgid "%s%s: error creating server \"%s\""
msgstr "%s nedostatek paměti pro infobar zprávu\n"
@@ -3476,6 +3487,14 @@ msgstr ""
msgid "show remote away message only once in private"
msgstr "zobrazit vzdálený zprávu o nepřítomnosti pouze jednou v soukromém okně"
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr ""
msgid "display notices as private messages"
msgstr "zobrazit upozornění jako soukromé zprávy"
@@ -4896,6 +4915,22 @@ msgstr "%s DCC: nemohu nastavit 'neblokovaci' volbu na soket\n"
msgid "%s%s: timeout for \"%s\" with %s"
msgstr "%s chybí argument pro volbu \"%s\"\n"
#, fuzzy
#~ msgid "%sError: filter not \"%s\" found"
#~ msgstr "%s plugin \"%s\" nenalezen\n"
#, fuzzy
#~ msgid "%sError: filter not found"
#~ msgstr "%s plugin \"%s\" nenalezen\n"
#, fuzzy
#~ msgid "Filter added"
#~ msgstr "uživatel byl zablokován"
#, fuzzy
#~ msgid "%sError: wrong filter number"
#~ msgstr "%s nekorektní číslo bufferu\n"
#, fuzzy
#~ msgid "Message filtering is enabled"
#~ msgstr "Filtry zpráv:"
+56 -21
View File
@@ -9,7 +9,7 @@ msgid ""
msgstr ""
"Project-Id-Version: WeeChat 0.2.7-dev\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: 2007-09-06 12:44+0200\n"
"Last-Translator: Thomas Schuetz <i18n@internet-villa.de>\n"
"Language-Team: weechat-dev <weechat-dev@nongnu.org>\n"
@@ -243,7 +243,7 @@ msgid "Message filters:"
msgstr ""
#, fuzzy, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " (kein Message-Handler)\n"
#, fuzzy
@@ -255,19 +255,15 @@ msgid "No message filter defined"
msgstr "Keine Aliases definiert.\n"
#, fuzzy, c-format
msgid "Filter %d enabled"
msgid "Filter \"%s\" enabled"
msgstr "/users wurde deaktiviert"
#, fuzzy, c-format
msgid "%sError: filter not found"
msgid "%sError: filter \"%s\" not found"
msgstr "%s Plugin \"%s\" nicht gefunden\n"
#, fuzzy, c-format
msgid "%sError: wrong filter number"
msgstr "%s falsche Puffernummer\n"
#, fuzzy, c-format
msgid "Filter %d disabled"
msgid "Filter \"%s\" disabled"
msgstr "/users wurde deaktiviert"
#, fuzzy, c-format
@@ -278,20 +274,28 @@ msgstr "%s diese /ignore-Regel existiert bereits\n"
msgid "%sError: you must specify at least tag(s) or regex for filter"
msgstr ""
#, fuzzy
msgid "Filter added"
#, fuzzy, c-format
msgid "Filter \"%s\" added"
msgstr "/users wurde deaktiviert"
#, fuzzy, c-format
msgid "%sError adding filter"
msgstr "%s falsche Puffernummer\n"
#, fuzzy, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr "/users wurde deaktiviert"
#, fuzzy, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr "%s unbekannte Option für den \"%s\"-Befehl\n"
#, fuzzy
msgid "All filters have been deleted"
msgstr "/users wurde deaktiviert"
#, fuzzy
msgid "Filter deleted"
#, fuzzy, c-format
msgid "Filter \"%s\" deleted"
msgstr "/users wurde deaktiviert"
#. TRANSLATORS: %s is "weechat"
@@ -800,8 +804,8 @@ msgid ""
msgstr ""
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
msgid ""
@@ -809,9 +813,9 @@ msgid ""
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -821,14 +825,16 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
#, fuzzy
@@ -3273,6 +3279,11 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr "%s fehlerhafte Argumente für der \"%s\"-Befehl\n"
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
#, fuzzy, c-format
msgid "%s%s: error creating server \"%s\""
msgstr "%s nicht genügend Speicher für Infobar-Nachricht\n"
@@ -3392,6 +3403,14 @@ msgid "show remote away message only once in private"
msgstr ""
"in privaten Unterhaltungen nur einmalig eine Abwesenheitsnachricht anzeigen"
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr ""
msgid "display notices as private messages"
msgstr "NOTICEs als Queries anzeigen"
@@ -4796,6 +4815,22 @@ msgstr "%s DCC: kann die 'nonblock'-Option für den Socket nicht festlegen\n"
msgid "%s%s: timeout for \"%s\" with %s"
msgstr "%s fehlende Argumente für die \"--dir\"-Option\n"
#, fuzzy
#~ msgid "%sError: filter not \"%s\" found"
#~ msgstr "%s Plugin \"%s\" nicht gefunden\n"
#, fuzzy
#~ msgid "%sError: filter not found"
#~ msgstr "%s Plugin \"%s\" nicht gefunden\n"
#, fuzzy
#~ msgid "Filter added"
#~ msgstr "/users wurde deaktiviert"
#, fuzzy
#~ msgid "%sError: wrong filter number"
#~ msgstr "%s falsche Puffernummer\n"
#, fuzzy
#~ msgid "Message filtering is enabled"
#~ msgstr "Keine Aliases definiert.\n"
+56 -21
View File
@@ -6,7 +6,7 @@ msgid ""
msgstr ""
"Project-Id-Version: WeeChat 0.2.7-dev\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: 2007-09-19 12:09+0200\n"
"Last-Translator: Roberto González Cardenete <robert.glez@gmail.com>\n"
"Language-Team: weechat-dev <weechat-dev@nongnu.org>\n"
@@ -239,7 +239,7 @@ msgid "Message filters:"
msgstr ""
#, fuzzy, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " (sin manejador de mensaje)\n"
#, fuzzy
@@ -251,19 +251,15 @@ msgid "No message filter defined"
msgstr "Ningún alias definido.\n"
#, fuzzy, c-format
msgid "Filter %d enabled"
msgid "Filter \"%s\" enabled"
msgstr "los usuarios han sido desactivados"
#, fuzzy, c-format
msgid "%sError: filter not found"
msgid "%sError: filter \"%s\" not found"
msgstr "%s plugin \"%s\" no encontrado\n"
#, fuzzy, c-format
msgid "%sError: wrong filter number"
msgstr "%s número de búfer incorrecto\n"
#, fuzzy, c-format
msgid "Filter %d disabled"
msgid "Filter \"%s\" disabled"
msgstr "los usuarios han sido desactivados"
#, fuzzy, c-format
@@ -274,20 +270,28 @@ msgstr "el ignore %s ya existe\n"
msgid "%sError: you must specify at least tag(s) or regex for filter"
msgstr ""
#, fuzzy
msgid "Filter added"
#, fuzzy, c-format
msgid "Filter \"%s\" added"
msgstr "los usuarios han sido desactivados"
#, fuzzy, c-format
msgid "%sError adding filter"
msgstr "%s número de búfer incorrecto\n"
#, fuzzy, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr "los usuarios han sido desactivados"
#, fuzzy, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr "%s opción desconocida para el comando \"%s\"\n"
#, fuzzy
msgid "All filters have been deleted"
msgstr "los usuarios han sido desactivados"
#, fuzzy
msgid "Filter deleted"
#, fuzzy, c-format
msgid "Filter \"%s\" deleted"
msgstr "los usuarios han sido desactivados"
#. TRANSLATORS: %s is "weechat"
@@ -796,8 +800,8 @@ msgid ""
msgstr ""
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
msgid ""
@@ -805,9 +809,9 @@ msgid ""
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -817,14 +821,16 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
#, fuzzy
@@ -3266,6 +3272,11 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr "%s argumentos incorrectos para el comando \"%s\"\n"
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
#, fuzzy, c-format
msgid "%s%s: error creating server \"%s\""
msgstr ""
@@ -3383,6 +3394,14 @@ msgid "show remote away message only once in private"
msgstr ""
"mostrar mensaje de ausencia remota únicamente una vez se está en privado"
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr ""
msgid "display notices as private messages"
msgstr "mostrar noticias como mensajes privados"
@@ -4801,6 +4820,22 @@ msgstr "%s no es posible crear el servidor\n"
msgid "%s%s: timeout for \"%s\" with %s"
msgstr "%s falta un argumento para la opción --dir\n"
#, fuzzy
#~ msgid "%sError: filter not \"%s\" found"
#~ msgstr "%s plugin \"%s\" no encontrado\n"
#, fuzzy
#~ msgid "%sError: filter not found"
#~ msgstr "%s plugin \"%s\" no encontrado\n"
#, fuzzy
#~ msgid "Filter added"
#~ msgstr "los usuarios han sido desactivados"
#, fuzzy
#~ msgid "%sError: wrong filter number"
#~ msgstr "%s número de búfer incorrecto\n"
#, fuzzy
#~ msgid "Message filtering is enabled"
#~ msgstr "Ningún alias definido.\n"
+61 -35
View File
@@ -6,8 +6,8 @@ msgid ""
msgstr ""
"Project-Id-Version: WeeChat 0.2.7-dev\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"PO-Revision-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: 2008-10-25 17:52+0200\n"
"Last-Translator: FlashCode <flashcode@flashtux.org>\n"
"Language-Team: weechat-dev <weechat-dev@nongnu.org>\n"
"MIME-Version: 1.0\n"
@@ -231,8 +231,8 @@ msgid "Message filters:"
msgstr "Filtres de messages:"
#, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " %s[%s%d%s]%s tampon: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " %s[%s%s%s]%s tampon: %s%s%s / tags: %s / regex: %s %s"
msgid "(disabled)"
msgstr "(désactivé)"
@@ -241,20 +241,16 @@ msgid "No message filter defined"
msgstr "Pas de filtre de message défini"
#, c-format
msgid "Filter %d enabled"
msgstr "Filtre %d activé"
msgid "Filter \"%s\" enabled"
msgstr "Filtre \"%s\" activé"
#, c-format
msgid "%sError: filter not found"
msgstr "%sErreur: filtre non trouvé"
msgid "%sError: filter \"%s\" not found"
msgstr "%sErreur: filtre \"%s\" non trouvé"
#, c-format
msgid "%sError: wrong filter number"
msgstr "%sErreur: numéro de filtre incorrect"
#, c-format
msgid "Filter %d disabled"
msgstr "Filtre %d désactivé"
msgid "Filter \"%s\" disabled"
msgstr "Filtre \"%s\" désactivé"
#, c-format
msgid "%sError: filter already exists"
@@ -266,18 +262,28 @@ msgstr ""
"%sErreur: vous devez spécifier au moins un/plusieurs tags(s) ou une "
"expression régulière pour filtrer"
msgid "Filter added"
msgstr "Filtre ajouté"
#, c-format
msgid "Filter \"%s\" added"
msgstr "Filtre \"%s\" ajouté"
#, c-format
msgid "%sError adding filter"
msgstr "%sErreur d'ajout du filtre"
#, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr "Filtre \"%s\" renommé en \"%s\""
#, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr "%sErreur: impossible de renommer le filtre \"%s\" en \"%s\""
msgid "All filters have been deleted"
msgstr "Tous les filtres ont été supprimés"
msgid "Filter deleted"
msgstr "Filtre supprimé"
#, c-format
msgid "Filter \"%s\" deleted"
msgstr "Filtre \"%s\" supprimé"
#. TRANSLATORS: %s is "weechat"
#, c-format
@@ -810,20 +816,20 @@ msgstr ""
"tags ou expressions régulières"
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del numéro|-"
"all]"
"[list] | [enable|disable|toggle [nom]] | [add nom buffer tags regex] | [del "
"nom|-all]"
msgid ""
" list: list all filters\n"
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -833,23 +839,24 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
" list: liste tous les filtres\n"
" enable: active les filtres (par défaut les filtres sont activés)\n"
"disable: désactive les filtres\n"
" toggle: active/désactive les filtres\n"
" nom: nom de filtre\n"
" add: ajoute un filtre\n"
" del: supprime un filtre\n"
" numéro: numéro du filtre à supprimer (voir la liste des filtres pour le "
"trouver)\n"
" -all: supprime tous les filtres\n"
" buffer: tampon où le filtre est actif: cela peut être un nom ou \"*\" pour "
"tous les tampons\n"
@@ -859,14 +866,16 @@ msgstr ""
"séparer le préfixe du message)\n"
"\n"
"Exemples:\n"
" filtrer les messages IRC join/part/quit:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" utiliser le filtre intelligent IRC pour les messages join/part/quit:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filtrer tous les messages IRC join/part/quit:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filtrer le pseudo \"toto\" sur le canal #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filtrer les lignes contenant le mot \"spam\":\n"
" /filter add * * spam\n"
" /filter add filtrespam * * spam\n"
" filtrer les lignes contenant \"weechat sucks\" sur le canal #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgid "display help about commands and options"
msgstr "afficher l'aide sur les commandes et les options"
@@ -3328,6 +3337,13 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr "%sirc: pas assez de paramètres pour la commande \"%s\""
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
"Vous devriez maintenant créer un filtre sur le tag \"irc_smart_filter\" avec "
"la commande /filter."
#, c-format
msgid "%s%s: error creating server \"%s\""
msgstr "%s%s: erreur de création du serveur \"%s\""
@@ -3448,6 +3464,16 @@ msgstr ""
msgid "show remote away message only once in private"
msgstr "voir le message d'absence distant une seule fois en privé"
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
"filtrer les messages join/part/quit pour un pseudo s'il n'a pas parlé "
"pendant quelques minutes sur le canal"
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr "délai pour filtrer les messages join/part/quit (en minutes)"
msgid "display notices as private messages"
msgstr "afficher les notices comme des messages privés"
+56 -21
View File
@@ -12,7 +12,7 @@ msgid ""
msgstr ""
"Project-Id-Version: WeeChat 0.2.7-dev\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: 2007-10-10 18:07+0200\n"
"Last-Translator: Andras Voroskoi <voroskoi@frugalware.org>\n"
"Language-Team: weechat-dev <weechat-dev@nongnu.org>\n"
@@ -244,7 +244,7 @@ msgid "Message filters:"
msgstr ""
#, fuzzy, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " (nincs üzenetkezelő)\n"
#, fuzzy
@@ -256,19 +256,15 @@ msgid "No message filter defined"
msgstr "Nincs aliasz definiálva.\n"
#, fuzzy, c-format
msgid "Filter %d enabled"
msgid "Filter \"%s\" enabled"
msgstr "a felhasználók le lettek tiltva"
#, fuzzy, c-format
msgid "%sError: filter not found"
msgid "%sError: filter \"%s\" not found"
msgstr "%s a \"%s\" modul nem található\n"
#, fuzzy, c-format
msgid "%sError: wrong filter number"
msgstr "%s helytelen pufferszám\n"
#, fuzzy, c-format
msgid "Filter %d disabled"
msgid "Filter \"%s\" disabled"
msgstr "a felhasználók le lettek tiltva"
#, fuzzy, c-format
@@ -279,20 +275,28 @@ msgstr "%s az ignore már létezik\n"
msgid "%sError: you must specify at least tag(s) or regex for filter"
msgstr ""
#, fuzzy
msgid "Filter added"
#, fuzzy, c-format
msgid "Filter \"%s\" added"
msgstr "a felhasználók le lettek tiltva"
#, fuzzy, c-format
msgid "%sError adding filter"
msgstr "%s helytelen pufferszám\n"
#, fuzzy, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr "a felhasználók le lettek tiltva"
#, fuzzy, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr "%s ismeretlen opció a \"%s\" parancsnak\n"
#, fuzzy
msgid "All filters have been deleted"
msgstr "a felhasználók le lettek tiltva"
#, fuzzy
msgid "Filter deleted"
#, fuzzy, c-format
msgid "Filter \"%s\" deleted"
msgstr "a felhasználók le lettek tiltva"
#. TRANSLATORS: %s is "weechat"
@@ -815,8 +819,8 @@ msgid ""
msgstr ""
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
msgid ""
@@ -824,9 +828,9 @@ msgid ""
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -836,14 +840,16 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
#, fuzzy
@@ -3310,6 +3316,11 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr "%s rossz argumentum a \"%s\" parancsnak\n"
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
#, fuzzy, c-format
msgid "%s%s: error creating server \"%s\""
msgstr "%s nincs elég memória az információs pult üzenethez\n"
@@ -3424,6 +3435,14 @@ msgstr ""
msgid "show remote away message only once in private"
msgstr "privát beszélgetésben a másik fél távollétét csak egyszer jelezze"
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr ""
msgid "display notices as private messages"
msgstr "figyelmeztetések privát üzenetként való mutatása"
@@ -4819,6 +4838,22 @@ msgstr "%s DCC: nem sikerült 'nonblock' opciót beállítani a csatornán\n"
msgid "%s%s: timeout for \"%s\" with %s"
msgstr "%s hiányzó argumentum a(z) \"%s\" opciónak\n"
#, fuzzy
#~ msgid "%sError: filter not \"%s\" found"
#~ msgstr "%s a \"%s\" modul nem található\n"
#, fuzzy
#~ msgid "%sError: filter not found"
#~ msgstr "%s a \"%s\" modul nem található\n"
#, fuzzy
#~ msgid "Filter added"
#~ msgstr "a felhasználók le lettek tiltva"
#, fuzzy
#~ msgid "%sError: wrong filter number"
#~ msgstr "%s helytelen pufferszám\n"
#, fuzzy
#~ msgid "Message filtering is enabled"
#~ msgstr "Nincs aliasz definiálva.\n"
+56 -21
View File
@@ -6,7 +6,7 @@ msgid ""
msgstr ""
"Project-Id-Version: WeeChat 0.2.7-dev\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: 2007-09-06 12:44+0200\n"
"Last-Translator: Pavel Shevchuk <stlwrt@gmail.com>\n"
"Language-Team: weechat-dev <weechat-dev@nongnu.org>\n"
@@ -240,7 +240,7 @@ msgid "Message filters:"
msgstr ""
#, fuzzy, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr " (нет обработчика сообщений)\n"
#, fuzzy
@@ -252,19 +252,15 @@ msgid "No message filter defined"
msgstr "Сокращения не заданы.\n"
#, fuzzy, c-format
msgid "Filter %d enabled"
msgid "Filter \"%s\" enabled"
msgstr "команда users отключена"
#, fuzzy, c-format
msgid "%sError: filter not found"
msgid "%sError: filter \"%s\" not found"
msgstr "%s plugin \"%s\" не найден\n"
#, fuzzy, c-format
msgid "%sError: wrong filter number"
msgstr "%s неправильный номер буфера\n"
#, fuzzy, c-format
msgid "Filter %d disabled"
msgid "Filter \"%s\" disabled"
msgstr "команда users отключена"
#, fuzzy, c-format
@@ -275,20 +271,28 @@ msgstr "%s игнорирование уже существует\n"
msgid "%sError: you must specify at least tag(s) or regex for filter"
msgstr ""
#, fuzzy
msgid "Filter added"
#, fuzzy, c-format
msgid "Filter \"%s\" added"
msgstr "команда users отключена"
#, fuzzy, c-format
msgid "%sError adding filter"
msgstr "%s неправильный номер буфера\n"
#, fuzzy, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr "команда users отключена"
#, fuzzy, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr "%s неизвестный параметр для команды \"%s\"\n"
#, fuzzy
msgid "All filters have been deleted"
msgstr "команда users отключена"
#, fuzzy
msgid "Filter deleted"
#, fuzzy, c-format
msgid "Filter \"%s\" deleted"
msgstr "команда users отключена"
#. TRANSLATORS: %s is "weechat"
@@ -809,8 +813,8 @@ msgid ""
msgstr ""
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
msgid ""
@@ -818,9 +822,9 @@ msgid ""
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -830,14 +834,16 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
#, fuzzy
@@ -3304,6 +3310,11 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr "%s некорректные аргументы команды \"%s\"\n"
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
#, fuzzy, c-format
msgid "%s%s: error creating server \"%s\""
msgstr "%s недостаточно памяти для сообщения в строке информации\n"
@@ -3418,6 +3429,14 @@ msgstr ""
msgid "show remote away message only once in private"
msgstr "отображать уведомление об отсутствии единожды в привате"
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr ""
msgid "display notices as private messages"
msgstr "отображать notice'ы в виде личных сообщений"
@@ -4801,6 +4820,22 @@ msgstr "%s DCC: не могу установить неблокирующий р
msgid "%s%s: timeout for \"%s\" with %s"
msgstr "%s нет аргумента для параметра \"%s\"\n"
#, fuzzy
#~ msgid "%sError: filter not \"%s\" found"
#~ msgstr "%s plugin \"%s\" не найден\n"
#, fuzzy
#~ msgid "%sError: filter not found"
#~ msgstr "%s plugin \"%s\" не найден\n"
#, fuzzy
#~ msgid "Filter added"
#~ msgstr "команда users отключена"
#, fuzzy
#~ msgid "%sError: wrong filter number"
#~ msgstr "%s неправильный номер буфера\n"
#, fuzzy
#~ msgid "Message filtering is enabled"
#~ msgstr "Сокращения не заданы.\n"
+40 -19
View File
@@ -7,7 +7,7 @@ msgid ""
msgstr ""
"Project-Id-Version: PACKAGE VERSION\n"
"Report-Msgid-Bugs-To: flashcode@flashtux.org\n"
"POT-Creation-Date: 2008-10-24 18:03+0200\n"
"POT-Creation-Date: 2008-10-25 17:52+0200\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
@@ -212,7 +212,7 @@ msgid "Message filters:"
msgstr ""
#, c-format
msgid " %s[%s%d%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgid " %s[%s%s%s]%s buffer: %s%s%s / tags: %s / regex: %s %s"
msgstr ""
msgid "(disabled)"
@@ -222,19 +222,15 @@ msgid "No message filter defined"
msgstr ""
#, c-format
msgid "Filter %d enabled"
msgid "Filter \"%s\" enabled"
msgstr ""
#, c-format
msgid "%sError: filter not found"
msgid "%sError: filter \"%s\" not found"
msgstr ""
#, c-format
msgid "%sError: wrong filter number"
msgstr ""
#, c-format
msgid "Filter %d disabled"
msgid "Filter \"%s\" disabled"
msgstr ""
#, c-format
@@ -245,17 +241,27 @@ msgstr ""
msgid "%sError: you must specify at least tag(s) or regex for filter"
msgstr ""
msgid "Filter added"
#, c-format
msgid "Filter \"%s\" added"
msgstr ""
#, c-format
msgid "%sError adding filter"
msgstr ""
#, c-format
msgid "Filter \"%s\" renamed to \"%s\""
msgstr ""
#, c-format
msgid "%sError: unable to rename filter \"%s\" to \"%s\""
msgstr ""
msgid "All filters have been deleted"
msgstr ""
msgid "Filter deleted"
#, c-format
msgid "Filter \"%s\" deleted"
msgstr ""
#. TRANSLATORS: %s is "weechat"
@@ -696,8 +702,8 @@ msgid ""
msgstr ""
msgid ""
"[list] | [enable|disable|toggle] | [add buffer tags regex] | [del number|-"
"all]"
"[list] | [enable|disable|toggle [name]] | [add name buffer tags regex] | "
"[del name|-all]"
msgstr ""
msgid ""
@@ -705,9 +711,9 @@ msgid ""
" enable: enable filters (filters are enabled by default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be a name or \"*\" for all "
"buffers\n"
@@ -717,14 +723,16 @@ msgid ""
"from message)\n"
"\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel #weechat:\n"
" /filter add freenode.#weechat * weechat sucks"
" /filter add sucks freenode.#weechat * weechat sucks"
msgstr ""
msgid "display help about commands and options"
@@ -2789,6 +2797,11 @@ msgstr ""
msgid "%sirc: too few arguments for \"%s\" command"
msgstr ""
msgid ""
"You should now create filter on tag \"irc_smart_filter\" with command /"
"filter."
msgstr ""
#, c-format
msgid "%s%s: error creating server \"%s\""
msgstr ""
@@ -2890,6 +2903,14 @@ msgstr ""
msgid "show remote away message only once in private"
msgstr ""
msgid ""
"filter join/part/quit messages for a nick if not speaking for some minutes "
"on channel"
msgstr ""
msgid "delay for filtering join/part/quit messages (in minutes)"
msgstr ""
msgid "display notices as private messages"
msgstr ""
+104 -105
View File
@@ -774,9 +774,6 @@ command_filter (void *data, struct t_gui_buffer *buffer,
int argc, char **argv, char **argv_eol)
{
struct t_gui_filter *ptr_filter;
int i;
long number;
char *error;
/* make C compiler happy */
(void) data;
@@ -797,17 +794,15 @@ command_filter (void *data, struct t_gui_buffer *buffer,
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Message filters:"));
i = 0;
for (ptr_filter = gui_filters; ptr_filter;
ptr_filter = ptr_filter->next_filter)
{
i++;
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_(" %s[%s%d%s]%s buffer: %s%s%s "
_(" %s[%s%s%s]%s buffer: %s%s%s "
"/ tags: %s / regex: %s %s"),
GUI_COLOR(GUI_COLOR_CHAT_DELIMITERS),
GUI_COLOR(GUI_COLOR_CHAT),
i,
ptr_filter->name,
GUI_COLOR(GUI_COLOR_CHAT_DELIMITERS),
GUI_COLOR(GUI_COLOR_CHAT),
GUI_COLOR(GUI_COLOR_CHAT_BUFFER),
@@ -834,34 +829,23 @@ command_filter (void *data, struct t_gui_buffer *buffer,
if (argc > 2)
{
/* enable a filter */
error = NULL;
number = strtol (argv[2], &error, 10);
if (error && !error[0])
ptr_filter = gui_filter_search_by_name (argv[2]);
if (ptr_filter)
{
ptr_filter = gui_filter_search_by_number (number);
if (ptr_filter)
{
if (!ptr_filter->enabled)
{
gui_filter_enable (ptr_filter);
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Filter %d enabled"),
number);
}
}
else
if (!ptr_filter->enabled)
{
gui_filter_enable (ptr_filter);
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: filter not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
_("Filter \"%s\" enabled"),
ptr_filter->name);
}
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: wrong filter number"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
_("%sError: filter \"%s\" not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
argv[2]);
return WEECHAT_RC_ERROR;
}
}
@@ -884,34 +868,23 @@ command_filter (void *data, struct t_gui_buffer *buffer,
if (argc > 2)
{
/* enable a filter */
error = NULL;
number = strtol (argv[2], &error, 10);
if (error && !error[0])
ptr_filter = gui_filter_search_by_name (argv[2]);
if (ptr_filter)
{
ptr_filter = gui_filter_search_by_number (number);
if (ptr_filter)
{
if (ptr_filter->enabled)
{
gui_filter_disable (ptr_filter);
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Filter %d disabled"),
number);
}
}
else
if (ptr_filter->enabled)
{
gui_filter_disable (ptr_filter);
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: filter not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
_("Filter \"%s\" disabled"),
ptr_filter->name);
}
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: wrong filter number"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
_("%sError: filter \"%s\" not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
argv[2]);
return WEECHAT_RC_ERROR;
}
}
@@ -927,38 +900,27 @@ command_filter (void *data, struct t_gui_buffer *buffer,
}
return WEECHAT_RC_OK;
}
/* toggle global filtering or a filter on/off */
if (string_strcasecmp (argv[1], "toggle") == 0)
{
if (argc > 2)
{
/* toggle a filter */
error = NULL;
number = strtol (argv[2], &error, 10);
if (error && !error[0])
ptr_filter = gui_filter_search_by_name (argv[2]);
if (ptr_filter)
{
ptr_filter = gui_filter_search_by_number (number);
if (ptr_filter)
{
if (ptr_filter->enabled)
gui_filter_disable (ptr_filter);
else
gui_filter_enable (ptr_filter);
}
if (ptr_filter->enabled)
gui_filter_disable (ptr_filter);
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: filter not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
}
gui_filter_enable (ptr_filter);
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: wrong filter number"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
_("%sError: filter \"%s\" not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
argv[2]);
return WEECHAT_RC_ERROR;
}
}
@@ -975,7 +937,7 @@ command_filter (void *data, struct t_gui_buffer *buffer,
/* add filter */
if (string_strcasecmp (argv[1], "add") == 0)
{
if (argc < 5)
if (argc < 6)
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: missing arguments for \"%s\" "
@@ -984,26 +946,27 @@ command_filter (void *data, struct t_gui_buffer *buffer,
"filter add");
return WEECHAT_RC_ERROR;
}
if (gui_filter_search (argv[2], argv[3], argv_eol[4]))
if (gui_filter_search (argv[3], argv[4], argv_eol[5]))
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: filter already exists"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
}
if ((strcmp (argv[3], "*") == 0) && (strcmp (argv_eol[4], "*") == 0))
if ((strcmp (argv[4], "*") == 0) && (strcmp (argv_eol[5], "*") == 0))
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: you must specify at least tag(s) or "
"regex for filter"),
_("%sError: you must specify at least "
"tag(s) or regex for filter"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
}
if (gui_filter_new (1, argv[2], argv[3], argv_eol[4]))
if (gui_filter_new (1, argv[2], argv[3], argv[4], argv_eol[5]))
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Filter added"));
_("Filter \"%s\" added"),
argv[2]);
}
else
{
@@ -1014,6 +977,51 @@ command_filter (void *data, struct t_gui_buffer *buffer,
return WEECHAT_RC_OK;
}
/* rename a filter */
if (string_strcasecmp (argv[1], "rename") == 0)
{
if (argc < 4)
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: missing arguments for \"%s\" "
"command"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
"filter rename");
return WEECHAT_RC_ERROR;
}
/* rename filter */
ptr_filter = gui_filter_search_by_name (argv[2]);
if (ptr_filter)
{
if (gui_filter_rename (ptr_filter, argv[3]))
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Filter \"%s\" renamed to \"%s\""),
argv[2], argv[3]);
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: unable to rename filter "
"\"%s\" to \"%s\""),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
argv[2], argv[3]);
return WEECHAT_RC_ERROR;
}
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: filter \"%s\" not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
argv[2]);
return WEECHAT_RC_ERROR;
}
return WEECHAT_RC_OK;
}
/* delete filter */
if (string_strcasecmp (argv[1], "del") == 0)
@@ -1043,31 +1051,21 @@ command_filter (void *data, struct t_gui_buffer *buffer,
}
else
{
error = NULL;
number = strtol (argv[2], &error, 10);
if (error && !error[0])
ptr_filter = gui_filter_search_by_name (argv[2]);
if (ptr_filter)
{
ptr_filter = gui_filter_search_by_number (number);
if (ptr_filter)
{
gui_filter_free (ptr_filter);
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Filter deleted"));
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: filter not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
}
gui_filter_free (ptr_filter);
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("Filter \"%s\" deleted"),
argv[2]);
}
else
{
gui_chat_printf_date_tags (NULL, 0, GUI_FILTER_TAG_NO_FILTER,
_("%sError: wrong filter number"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR]);
return WEECHAT_RC_ERROR;
_("%sError: filter \"%s\" not found"),
gui_chat_prefix[GUI_CHAT_PREFIX_ERROR],
argv[2]);
return WEECHAT_RC_ERROR;
}
}
return WEECHAT_RC_OK;
@@ -3112,18 +3110,17 @@ command_init ()
hook_command (NULL, "filter",
N_("filter messages in buffers, to hide/show them according "
"to tags or regex"),
N_("[list] | [enable|disable|toggle] | "
"[add buffer tags regex] | "
"[del number|-all]"),
N_("[list] | [enable|disable|toggle [name]] | "
"[add name buffer tags regex] | "
"[del name|-all]"),
N_(" list: list all filters\n"
" enable: enable filters (filters are enabled by "
"default)\n"
"disable: disable filters\n"
" toggle: toggle filters\n"
" name: filter name\n"
" add: add a filter\n"
" del: delete a filter\n"
" number: number of filter to delete (look at list to "
"find it)\n"
" -all: delete all filters\n"
" buffer: buffer where filter is active: it may be "
"a name or \"*\" for all buffers\n"
@@ -3132,16 +3129,18 @@ command_init ()
" regex: regular expression to search in "
"line (use \\t to separate prefix from message)\n\n"
"Examples:\n"
" filter IRC join/part/quit messages:\n"
" /filter add * irc_join,irc_part,irc_quit *\n"
" use IRC smart filter for join/part/quit messages:\n"
" /filter add irc_smart * irc_smart_filter *\n"
" filter all IRC join/part/quit messages:\n"
" /filter add joinquit * irc_join,irc_part,irc_quit *\n"
" filter nick \"toto\" on channel #weechat:\n"
" /filter add freenode.#weechat * toto\\t\n"
" /filter add toto freenode.#weechat * toto\\t\n"
" filter lines containing word \"spam\":\n"
" /filter add * * spam\n"
" /filter add filterspam * * spam\n"
" filter lines containing \"weechat sucks\" on channel "
"#weechat:\n"
" /filter add freenode.#weechat * weechat sucks"),
"list|enable|disable|toggle|add|del",
" /filter add sucks freenode.#weechat * weechat sucks"),
"list|enable|disable|toggle|add|rename|del %F",
&command_filter, NULL);
hook_command (NULL, "help",
N_("display help about commands and options"),
+4 -7
View File
@@ -704,13 +704,10 @@ config_weechat_filter_read (void *data,
{
argv = string_explode (value, ";", 0, 0, &argc);
argv_eol = string_explode (value, ";", 1, 0, NULL);
if (argv && argv_eol && (argc >= 3))
if (argv && argv_eol && (argc >= 4))
{
if (argc == 3)
gui_filter_new (1, argv[0], argv[1], argv_eol[2]);
else
gui_filter_new ((string_strcasecmp (argv[0], "on") == 0) ? 1 : 0,
argv[1], argv[2], argv_eol[3]);
gui_filter_new ((string_strcasecmp (argv[0], "on") == 0) ? 1 : 0,
option_name, argv[1], argv[2], argv_eol[3]);
}
if (argv)
string_free_exploded (argv);
@@ -740,7 +737,7 @@ config_weechat_filter_write (void *data, struct t_config_file *config_file,
ptr_filter = ptr_filter->next_filter)
{
config_file_write_line (config_file,
"filter",
ptr_filter->name,
"%s;%s;%s;%s",
(ptr_filter->enabled) ? "on" : "off",
ptr_filter->buffer,
+21
View File
@@ -43,6 +43,7 @@
#include "gui-bar.h"
#include "gui-buffer.h"
#include "gui-color.h"
#include "gui-filter.h"
#include "gui-keyboard.h"
#include "gui-nicklist.h"
@@ -463,6 +464,23 @@ gui_completion_list_add_filename (struct t_gui_completion *completion)
free (buffer);
}
/*
* gui_completion_list_add_filters: add filters to completion list
*/
void
gui_completion_list_add_filters (struct t_gui_completion *completion)
{
struct t_gui_filter *ptr_filter;
for (ptr_filter = gui_filters; ptr_filter;
ptr_filter = ptr_filter->next_filter)
{
gui_completion_list_add (completion, ptr_filter->name,
0, WEECHAT_LIST_POS_SORT);
}
}
/*
* gui_completion_list_add_command_hooks: add command hooks to completion list
*/
@@ -931,6 +949,9 @@ gui_completion_build_list_template (struct t_gui_completion *completion,
case 'f': /* filename */
gui_completion_list_add_filename (completion);
break;
case 'F': /* filters */
gui_completion_list_add_filters (completion);
break;
case 'h': /* command hooks */
gui_completion_list_add_command_hooks (completion);
break;
+33 -10
View File
@@ -253,22 +253,19 @@ gui_filter_search (const char *buffer, const char *tags, const char *regex)
}
/*
* gui_filter_search_by_number: search a filter by number (first is #1)
* gui_filter_search_by_name: search a filter by name
*/
struct t_gui_filter *
gui_filter_search_by_number (int number)
gui_filter_search_by_name (const char *name)
{
struct t_gui_filter *ptr_filter;
int i;
i = 1;
for (ptr_filter = gui_filters; ptr_filter;
ptr_filter = ptr_filter->next_filter)
{
if (i == number)
if (strcmp (ptr_filter->name, name) == 0)
return ptr_filter;
i++;
}
/* filter not found */
@@ -280,15 +277,18 @@ gui_filter_search_by_number (int number)
*/
struct t_gui_filter *
gui_filter_new (int enabled, const char *buffer, const char *tags,
const char *regex)
gui_filter_new (int enabled, const char *name, const char *buffer,
const char *tags, const char *regex)
{
struct t_gui_filter *new_filter;
regex_t *regex1, *regex2;
char *pos_tab, *regex_prefix;
const char *pos_regex_message;
if (!buffer || !tags || !regex)
if (!name || !buffer || !tags || !regex)
return NULL;
if (gui_filter_search_by_name (name))
return NULL;
regex1 = NULL;
@@ -347,6 +347,7 @@ gui_filter_new (int enabled, const char *buffer, const char *tags,
{
/* init filter */
new_filter->enabled = enabled;
new_filter->name = strdup (name);
new_filter->buffer = (buffer) ? strdup (buffer) : strdup ("*");
if (tags)
{
@@ -382,6 +383,25 @@ gui_filter_new (int enabled, const char *buffer, const char *tags,
return new_filter;
}
/*
* gui_filter_rename: rename a filter
*/
int
gui_filter_rename (struct t_gui_filter *filter, const char *new_name)
{
if (!filter || !new_name)
return 0;
if (gui_filter_search_by_name (new_name))
return 0;
free (filter->name);
filter->name = strdup (new_name);
return 1;
}
/*
* gui_filter_free: remove a filter
*/
@@ -393,6 +413,8 @@ gui_filter_free (struct t_gui_filter *filter)
WEECHAT_HOOK_SIGNAL_POINTER, filter);
/* free data */
if (filter->name)
free (filter->name);
if (filter->buffer)
free (filter->buffer);
if (filter->tags)
@@ -501,6 +523,7 @@ gui_filter_print_log ()
log_printf ("");
log_printf ("[filter (addr:0x%x)]", ptr_filter);
log_printf (" enabled. . . . . . . . : %d", ptr_filter->enabled);
log_printf (" name . . . . . . . . . : '%s'", ptr_filter->name);
log_printf (" buffer . . . . . . . . : '%s'", ptr_filter->buffer);
log_printf (" tags . . . . . . . . . : '%s'", ptr_filter->tags);
log_printf (" regex. . . . . . . . . : '%s'", ptr_filter->regex);
+5 -1
View File
@@ -31,6 +31,7 @@ struct t_gui_line;
struct t_gui_filter
{
int enabled; /* 1 if filter enabled, otherwise 0 */
char *name;
char *buffer; /* name of buffer */
char *tags; /* tags */
int tags_count; /* number of tags */
@@ -59,11 +60,14 @@ extern void gui_filter_disable (struct t_gui_filter *filter);
extern struct t_gui_filter *gui_filter_search (const char *buffer,
const char *tags,
const char *regex);
extern struct t_gui_filter *gui_filter_search_by_number (int number);
extern struct t_gui_filter *gui_filter_search_by_name (const char *name);
extern struct t_gui_filter *gui_filter_new (int enabled,
const char *name,
const char *buffer,
const char *tags,
const char *regex);
extern int gui_filter_rename (struct t_gui_filter *filter,
const char *new_name);
extern void gui_filter_free (struct t_gui_filter *filter);
extern void gui_filter_free_all ();
extern int gui_filter_add_to_infolist (struct t_infolist *infolist,
+299 -77
View File
@@ -21,6 +21,7 @@
#include <stdlib.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include "../weechat-plugin.h"
@@ -148,6 +149,8 @@ irc_channel_new (struct t_irc_server *server, int channel_type,
new_channel->last_nick = NULL;
new_channel->buffer = new_buffer;
new_channel->nicks_speaking = NULL;
new_channel->nicks_speaking_time = NULL;
new_channel->last_nick_speaking_time = NULL;
new_channel->buffer_as_string = NULL;
/* add new channel to channels list */
@@ -180,66 +183,6 @@ irc_channel_set_topic (struct t_irc_channel *channel, char *topic)
weechat_buffer_set (channel->buffer, "title", channel->topic);
}
/*
* irc_channel_free: free a channel and remove it from channels list
*/
void
irc_channel_free (struct t_irc_server *server, struct t_irc_channel *channel)
{
struct t_irc_channel *new_channels;
if (!server || !channel)
return;
/* remove channel from channels list */
if (server->last_channel == channel)
server->last_channel = channel->prev_channel;
if (channel->prev_channel)
{
(channel->prev_channel)->next_channel = channel->next_channel;
new_channels = server->channels;
}
else
new_channels = channel->next_channel;
if (channel->next_channel)
(channel->next_channel)->prev_channel = channel->prev_channel;
/* free data */
if (channel->name)
free (channel->name);
if (channel->topic)
free (channel->topic);
if (channel->modes)
free (channel->modes);
if (channel->key)
free (channel->key);
irc_nick_free_all (channel);
if (channel->away_message)
free (channel->away_message);
if (channel->nicks_speaking)
weechat_list_free (channel->nicks_speaking);
if (channel->buffer_as_string)
free (channel->buffer_as_string);
free (channel);
server->channels = new_channels;
}
/*
* irc_channel_free_all: free all allocated channels
*/
void
irc_channel_free_all (struct t_irc_server *server)
{
/* remove all channels for the server */
while (server->channels)
irc_channel_free (server, server->channels);
}
/*
* irc_channel_search: returns pointer on a channel with name
*/
@@ -386,11 +329,11 @@ irc_channel_set_away (struct t_irc_channel *channel, const char *nick, int is_aw
}
/*
* irc_channel_add_nick_speaking: add a nick speaking on a channel
* irc_channel_nick_speaking_add: add a nick speaking on a channel
*/
void
irc_channel_add_nick_speaking (struct t_irc_channel *channel, const char *nick)
irc_channel_nick_speaking_add (struct t_irc_channel *channel, const char *nick)
{
int size, to_remove, i;
@@ -411,6 +354,233 @@ irc_channel_add_nick_speaking (struct t_irc_channel *channel, const char *nick)
}
}
/*
* irc_channel_nick_speaking_rename: rename a nick speaking on a channel
*/
void
irc_channel_nick_speaking_rename (struct t_irc_channel *channel,
const char *old_nick,
const char *new_nick)
{
struct t_weelist_item *ptr_item;
if (channel->nicks_speaking)
{
ptr_item = weechat_list_search (channel->nicks_speaking, old_nick);
if (ptr_item)
weechat_list_set (ptr_item, new_nick);
}
}
/*
* irc_channel_nick_speaking_time_search: search a nick speaking time on a
* channel
*/
struct t_irc_channel_speaking *
irc_channel_nick_speaking_time_search (struct t_irc_channel *channel,
const char *nick,
int check_time)
{
struct t_irc_channel_speaking *ptr_nick;
time_t time_limit;
time_limit = time (NULL) -
(weechat_config_integer (irc_config_look_smart_filter_delay) * 60);
for (ptr_nick = channel->nicks_speaking_time; ptr_nick;
ptr_nick = ptr_nick->next_nick)
{
if (strcmp (ptr_nick->nick, nick) == 0)
{
if (check_time && (ptr_nick->time_last_message < time_limit))
return NULL;
return ptr_nick;
}
}
/* nick speaking time not found */
return NULL;
}
/*
* irc_channel_nick_speaking_time_free: free a nick speaking on a channel
*/
void
irc_channel_nick_speaking_time_free (struct t_irc_channel *channel,
struct t_irc_channel_speaking *nick)
{
/* free data */
if (nick->nick)
free (nick->nick);
/* remove nick from list */
if (nick->prev_nick)
(nick->prev_nick)->next_nick = nick->next_nick;
if (nick->next_nick)
(nick->next_nick)->prev_nick = nick->prev_nick;
if (channel->nicks_speaking_time == nick)
channel->nicks_speaking_time = nick->next_nick;
if (channel->last_nick_speaking_time == nick)
channel->last_nick_speaking_time = nick->prev_nick;
free (nick);
}
/*
* irc_channel_nick_speaking_time_free_all: free all nick speaking on a channel
*/
void
irc_channel_nick_speaking_time_free_all (struct t_irc_channel *channel)
{
while (channel->nicks_speaking_time)
{
irc_channel_nick_speaking_time_free (channel,
channel->nicks_speaking_time);
}
}
/*
* irc_channel_nick_speaking_time_remove_old: remove old nicks speaking
*/
void
irc_channel_nick_speaking_time_remove_old (struct t_irc_channel *channel)
{
time_t time_limit;
time_limit = time (NULL) -
(weechat_config_integer (irc_config_look_smart_filter_delay) * 60);
while (channel->last_nick_speaking_time)
{
if (channel->last_nick_speaking_time->time_last_message >= time_limit)
break;
irc_channel_nick_speaking_time_free (channel,
channel->last_nick_speaking_time);
}
}
/*
* irc_channel_nick_speaking_time_add: add a nick speaking time on a channel
*/
void
irc_channel_nick_speaking_time_add (struct t_irc_channel *channel,
const char *nick,
time_t time_last_message)
{
struct t_irc_channel_speaking *ptr_nick, *new_nick;
ptr_nick = irc_channel_nick_speaking_time_search (channel, nick, 0);
if (ptr_nick)
irc_channel_nick_speaking_time_free (channel, ptr_nick);
new_nick = malloc (sizeof (*new_nick));
if (new_nick)
{
new_nick->nick = strdup (nick);
new_nick->time_last_message = time_last_message;
/* insert nick at beginning of list */
new_nick->prev_nick = NULL;
new_nick->next_nick = channel->nicks_speaking_time;
if (channel->nicks_speaking_time)
channel->nicks_speaking_time->prev_nick = new_nick;
else
channel->last_nick_speaking_time = new_nick;
channel->nicks_speaking_time = new_nick;
}
}
/*
* irc_channel_nick_speaking_time_rename: rename a nick speaking time on a
* channel
*/
void
irc_channel_nick_speaking_time_rename (struct t_irc_channel *channel,
const char *old_nick,
const char *new_nick)
{
struct t_irc_channel_speaking *ptr_nick;
if (channel->nicks_speaking_time)
{
ptr_nick = irc_channel_nick_speaking_time_search (channel, old_nick, 0);
if (ptr_nick)
{
free (ptr_nick->nick);
ptr_nick->nick = strdup (new_nick);
}
}
}
/*
* irc_channel_free: free a channel and remove it from channels list
*/
void
irc_channel_free (struct t_irc_server *server, struct t_irc_channel *channel)
{
struct t_irc_channel *new_channels;
if (!server || !channel)
return;
/* remove channel from channels list */
if (server->last_channel == channel)
server->last_channel = channel->prev_channel;
if (channel->prev_channel)
{
(channel->prev_channel)->next_channel = channel->next_channel;
new_channels = server->channels;
}
else
new_channels = channel->next_channel;
if (channel->next_channel)
(channel->next_channel)->prev_channel = channel->prev_channel;
/* free data */
if (channel->name)
free (channel->name);
if (channel->topic)
free (channel->topic);
if (channel->modes)
free (channel->modes);
if (channel->key)
free (channel->key);
irc_nick_free_all (channel);
if (channel->away_message)
free (channel->away_message);
if (channel->nicks_speaking)
weechat_list_free (channel->nicks_speaking);
irc_channel_nick_speaking_time_free_all (channel);
if (channel->buffer_as_string)
free (channel->buffer_as_string);
free (channel);
server->channels = new_channels;
}
/*
* irc_channel_free_all: free all allocated channels
*/
void
irc_channel_free_all (struct t_irc_server *server)
{
/* remove all channels for the server */
while (server->channels)
irc_channel_free (server, server->channels);
}
/*
* irc_channel_add_to_infolist: add a channel in an infolist
* return 1 if ok, 0 if error
@@ -421,6 +591,10 @@ irc_channel_add_to_infolist (struct t_infolist *infolist,
struct t_irc_channel *channel)
{
struct t_infolist_item *ptr_item;
struct t_weelist_item *ptr_list_item;
struct t_irc_channel_speaking *ptr_nick;
char option_name[64];
int i;
if (!infolist || !channel)
return 0;
@@ -463,6 +637,39 @@ irc_channel_add_to_infolist (struct t_infolist *infolist,
return 0;
if (!weechat_infolist_new_var_integer (ptr_item, "nick_completion_reset", channel->nick_completion_reset))
return 0;
if (channel->nicks_speaking)
{
i = 0;
for (ptr_list_item = weechat_list_get (channel->nicks_speaking, 0);
ptr_list_item;
ptr_list_item = weechat_list_next (ptr_list_item))
{
snprintf (option_name, sizeof (option_name), "nick_speaking_%05d", i);
if (!weechat_infolist_new_var_string (ptr_item, option_name,
weechat_list_string (ptr_list_item)))
return 0;
i++;
}
}
if (channel->nicks_speaking_time)
{
i = 0;
for (ptr_nick = channel->last_nick_speaking_time; ptr_nick;
ptr_nick = ptr_nick->prev_nick)
{
snprintf (option_name, sizeof (option_name),
"nick_speaking_time_nick_%05d", i);
if (!weechat_infolist_new_var_string (ptr_item, option_name,
ptr_nick->nick))
return 0;
snprintf (option_name, sizeof (option_name),
"nick_speaking_time_time_%05d", i);
if (!weechat_infolist_new_var_time (ptr_item, option_name,
ptr_nick->time_last_message))
return 0;
i++;
}
}
return 1;
}
@@ -475,26 +682,29 @@ void
irc_channel_print_log (struct t_irc_channel *channel)
{
struct t_weelist_item *ptr_item;
struct t_irc_channel_speaking *ptr_nick_speaking;
int i;
struct t_irc_nick *ptr_nick;
weechat_log_printf ("");
weechat_log_printf (" => channel %s (addr:0x%x)]", channel->name, channel);
weechat_log_printf (" type . . . . . . . . : %d", channel->type);
weechat_log_printf (" topic. . . . . . . . : '%s'", channel->topic);
weechat_log_printf (" modes. . . . . . . . : '%s'", channel->modes);
weechat_log_printf (" limit. . . . . . . . : %d", channel->limit);
weechat_log_printf (" key. . . . . . . . . : '%s'", channel->key);
weechat_log_printf (" checking_away. . . . : %d", channel->checking_away);
weechat_log_printf (" away_message . . . . : '%s'", channel->away_message);
weechat_log_printf (" cycle. . . . . . . . : %d", channel->cycle);
weechat_log_printf (" display_creation_date: %d", channel->display_creation_date);
weechat_log_printf (" nicks. . . . . . . . : 0x%x", channel->nicks);
weechat_log_printf (" last_nick. . . . . . : 0x%x", channel->last_nick);
weechat_log_printf (" buffer . . . . . . . : 0x%x", channel->buffer);
weechat_log_printf (" nicks_speaking . . . : 0x%x", channel->nicks_speaking);
weechat_log_printf (" prev_channel . . . . : 0x%x", channel->prev_channel);
weechat_log_printf (" next_channel . . . . : 0x%x", channel->next_channel);
weechat_log_printf (" type . . . . . . . . . . : %d", channel->type);
weechat_log_printf (" topic. . . . . . . . . . : '%s'", channel->topic);
weechat_log_printf (" modes. . . . . . . . . . : '%s'", channel->modes);
weechat_log_printf (" limit. . . . . . . . . . : %d", channel->limit);
weechat_log_printf (" key. . . . . . . . . . . : '%s'", channel->key);
weechat_log_printf (" checking_away. . . . . . : %d", channel->checking_away);
weechat_log_printf (" away_message . . . . . . : '%s'", channel->away_message);
weechat_log_printf (" cycle. . . . . . . . . . : %d", channel->cycle);
weechat_log_printf (" display_creation_date. . : %d", channel->display_creation_date);
weechat_log_printf (" nicks. . . . . . . . . . : 0x%x", channel->nicks);
weechat_log_printf (" last_nick. . . . . . . . : 0x%x", channel->last_nick);
weechat_log_printf (" buffer . . . . . . . . . : 0x%x", channel->buffer);
weechat_log_printf (" nicks_speaking . . . . . : 0x%x", channel->nicks_speaking);
weechat_log_printf (" nicks_speaking_time. . . : 0x%x", channel->nicks_speaking_time);
weechat_log_printf (" last_nick_speaking_time. : 0x%x", channel->last_nick_speaking_time);
weechat_log_printf (" prev_channel . . . . . . : 0x%x", channel->prev_channel);
weechat_log_printf (" next_channel . . . . . . : 0x%x", channel->next_channel);
if (channel->nicks_speaking)
{
weechat_log_printf ("");
@@ -507,6 +717,18 @@ irc_channel_print_log (struct t_irc_channel *channel)
i++;
}
}
if (channel->nicks_speaking_time)
{
weechat_log_printf ("");
for (ptr_nick_speaking = channel->nicks_speaking_time;
ptr_nick_speaking;
ptr_nick_speaking = ptr_nick_speaking->next_nick)
{
weechat_log_printf (" nick speaking time: '%s', time: %ld",
ptr_nick_speaking->nick,
ptr_nick_speaking->time_last_message);
}
}
for (ptr_nick = channel->nicks; ptr_nick; ptr_nick = ptr_nick->next_nick)
{
irc_nick_print_log (ptr_nick);
+25 -1
View File
@@ -31,6 +31,14 @@
struct t_irc_server;
struct t_irc_channel_speaking
{
char *nick; /* nick speaking */
time_t time_last_message; /* time */
struct t_irc_channel_speaking *prev_nick; /* pointer to previous nick */
struct t_irc_channel_speaking *next_nick; /* pointer to next nick */
};
struct t_irc_channel
{
int type; /* channel type */
@@ -49,6 +57,9 @@ struct t_irc_channel
struct t_irc_nick *nicks; /* nicks on the channel */
struct t_irc_nick *last_nick; /* last nick on the channel */
struct t_weelist *nicks_speaking; /* for smart completion */
struct t_irc_channel_speaking *nicks_speaking_time; /* for smart filter */
/* of join/part/quit messages */
struct t_irc_channel_speaking *last_nick_speaking_time;
struct t_gui_buffer *buffer; /* buffer allocated for channel */
char *buffer_as_string; /* used to return buffer info */
struct t_irc_channel *prev_channel; /* link to previous channel */
@@ -77,8 +88,21 @@ extern void irc_channel_check_away (struct t_irc_server *server,
struct t_irc_channel *channel, int force);
extern void irc_channel_set_away (struct t_irc_channel *channel, const char *nick,
int is_away);
extern void irc_channel_add_nick_speaking (struct t_irc_channel *channel,
extern void irc_channel_nick_speaking_add (struct t_irc_channel *channel,
const char *nick);
extern void irc_channel_nick_speaking_rename (struct t_irc_channel *channel,
const char *old_nick,
const char *new_nick);
extern struct t_irc_channel_speaking *irc_channel_nick_speaking_time_search (struct t_irc_channel *channel,
const char *nick,
int check_time);
extern void irc_channel_nick_speaking_time_remove_old (struct t_irc_channel *channel);
extern void irc_channel_nick_speaking_time_add (struct t_irc_channel *channel,
const char *nick,
time_t time_last_message);
extern void irc_channel_nick_speaking_time_rename (struct t_irc_channel *channel,
const char *old_nick,
const char *new_nick);
extern int irc_channel_add_to_infolist (struct t_infolist *infolist,
struct t_irc_channel *channel);
extern void irc_channel_print_log (struct t_irc_channel *channel);
+31 -2
View File
@@ -59,6 +59,8 @@ struct t_config_option *irc_config_look_display_away;
struct t_config_option *irc_config_look_display_channel_modes;
struct t_config_option *irc_config_look_highlight_tags;
struct t_config_option *irc_config_look_show_away_once;
struct t_config_option *irc_config_look_smart_filter;
struct t_config_option *irc_config_look_smart_filter_delay;
struct t_config_option *irc_config_look_notice_as_pv;
/* IRC config, network section */
@@ -140,7 +142,7 @@ irc_config_get_server_from_option_name (const char *name)
/*
* irc_config_change_one_server_buffer: called when the "one server buffer"
* setting is changed
* option is changed
*/
void
@@ -154,7 +156,7 @@ irc_config_change_one_server_buffer ()
/*
* irc_config_change_display_channel_modes: called when the "display channel modes"
* setting is changed
* option is changed
*/
void
@@ -163,6 +165,22 @@ irc_config_change_display_channel_modes ()
weechat_bar_item_update ("buffer_name");
}
/*
* irc_config_change_smart_filter: called when the "smart_filter" option is
* changed
*/
void
irc_config_change_smart_filter ()
{
if (weechat_config_boolean (irc_config_look_smart_filter))
{
weechat_printf (NULL,
_("You should now create filter on tag "
"\"irc_smart_filter\" with command /filter."));
}
}
/*
* irc_config_change_away_check: called when away check is changed
*/
@@ -1023,6 +1041,17 @@ irc_config_init ()
"show_away_once", "boolean",
N_("show remote away message only once in private"),
NULL, 0, 0, "on", NULL, NULL, NULL, NULL, NULL, NULL, NULL);
irc_config_look_smart_filter = weechat_config_new_option (
irc_config_file, ptr_section,
"smart_filter", "boolean",
N_("filter join/part/quit messages for a nick if not speaking for "
"some minutes on channel"),
NULL, 0, 0, "off", NULL, NULL, NULL, &irc_config_change_smart_filter, NULL, NULL, NULL);
irc_config_look_smart_filter_delay = weechat_config_new_option (
irc_config_file, ptr_section,
"smart_filter_delay", "integer",
N_("delay for filtering join/part/quit messages (in minutes)"),
NULL, 1, 60*24*7, "5", NULL, NULL, NULL, NULL, NULL, NULL, NULL);
irc_config_look_notice_as_pv = weechat_config_new_option (
irc_config_file, ptr_section,
"notice_as_pv", "boolean",
+2
View File
@@ -71,6 +71,8 @@ extern struct t_config_option *irc_config_look_display_away;
extern struct t_config_option *irc_config_look_display_channel_modes;
extern struct t_config_option *irc_config_look_highlight_tags;
extern struct t_config_option *irc_config_look_show_away_once;
extern struct t_config_option *irc_config_look_smart_filter;
extern struct t_config_option *irc_config_look_smart_filter_delay;
extern struct t_config_option *irc_config_look_notice_as_pv;
extern struct t_config_option *irc_config_network_default_msg_part;
+53 -13
View File
@@ -267,7 +267,9 @@ irc_protocol_cmd_join (struct t_irc_server *server, const char *command,
{
struct t_irc_channel *ptr_channel;
struct t_irc_nick *ptr_nick;
struct t_irc_channel_speaking *ptr_nick_speaking;
char *pos_channel;
int local_join;
/* JOIN message looks like:
:nick!user@host JOIN :#channel
@@ -299,8 +301,14 @@ irc_protocol_cmd_join (struct t_irc_server *server, const char *command,
if (!irc_ignore_check (server, ptr_channel, nick, host))
{
local_join = (strcmp (nick, server->nick) == 0);
ptr_nick_speaking = (weechat_config_boolean (irc_config_look_smart_filter)) ?
irc_channel_nick_speaking_time_search (ptr_channel, nick, 1) : NULL;
weechat_printf_tags (ptr_channel->buffer,
"irc_join",
(local_join
|| !weechat_config_boolean (irc_config_look_smart_filter)
|| ptr_nick_speaking) ?
"irc_join" : "irc_join,irc_smart_filter",
_("%s%s%s %s(%s%s%s)%s has joined %s%s"),
weechat_prefix ("join"),
IRC_COLOR_CHAT_NICK,
@@ -575,7 +583,7 @@ irc_protocol_cmd_nick (struct t_irc_server *server, const char *command,
struct t_irc_channel *ptr_channel;
struct t_irc_nick *ptr_nick;
char *new_nick;
int nick_is_me;
int local_nick;
/* NICK message looks like:
:oldnick!user@host NICK :newnick
@@ -590,7 +598,7 @@ irc_protocol_cmd_nick (struct t_irc_server *server, const char *command,
new_nick = (argv[2][0] == ':') ? argv[2] + 1 : argv[2];
nick_is_me = (strcmp (nick, server->nick) == 0) ? 1 : 0;
local_nick = (strcmp (nick, server->nick) == 0) ? 1 : 0;
for (ptr_channel = server->channels; ptr_channel;
ptr_channel = ptr_channel->next_channel)
@@ -616,7 +624,7 @@ irc_protocol_cmd_nick (struct t_irc_server *server, const char *command,
/* change nick and display message on all channels */
irc_nick_change (server, ptr_channel, ptr_nick, new_nick);
if (nick_is_me)
if (local_nick)
{
weechat_printf_tags (ptr_channel->buffer,
"irc_nick",
@@ -641,6 +649,10 @@ irc_protocol_cmd_nick (struct t_irc_server *server, const char *command,
IRC_COLOR_CHAT_NICK,
new_nick);
}
irc_channel_nick_speaking_rename (ptr_channel,
nick, new_nick);
irc_channel_nick_speaking_time_rename (ptr_channel,
nick, new_nick);
}
/* enable hotlist */
@@ -650,7 +662,7 @@ irc_protocol_cmd_nick (struct t_irc_server *server, const char *command,
}
}
if (nick_is_me)
if (local_nick)
irc_server_set_nick (server, new_nick);
return WEECHAT_RC_OK;
@@ -879,9 +891,10 @@ irc_protocol_cmd_part (struct t_irc_server *server, const char *command,
int argc, char **argv, char **argv_eol)
{
char *pos_comment, *join_string;
int join_length;
int join_length, local_part;
struct t_irc_channel *ptr_channel;
struct t_irc_nick *ptr_nick;
struct t_irc_channel_speaking *ptr_nick_speaking;
/* PART message looks like:
:nick!user@host PART #channel :part message
@@ -900,13 +913,20 @@ irc_protocol_cmd_part (struct t_irc_server *server, const char *command,
ptr_nick = irc_nick_search (ptr_channel, nick);
if (ptr_nick)
{
local_part = (strcmp (nick, server->nick) == 0);
/* display part message */
if (!irc_ignore_check (server, ptr_channel, nick, host))
{
ptr_nick_speaking = (weechat_config_boolean (irc_config_look_smart_filter)) ?
irc_channel_nick_speaking_time_search (ptr_channel, nick, 1) : NULL;
if (pos_comment)
{
weechat_printf_tags (ptr_channel->buffer,
"irc_part",
(local_part
|| !weechat_config_boolean (irc_config_look_smart_filter)
|| ptr_nick_speaking) ?
"irc_part" : "irc_part,irc_smart_filter",
_("%s%s%s %s(%s%s%s)%s has left %s%s "
"%s(%s%s%s)"),
weechat_prefix ("quit"),
@@ -927,7 +947,10 @@ irc_protocol_cmd_part (struct t_irc_server *server, const char *command,
else
{
weechat_printf_tags (ptr_channel->buffer,
"irc_part",
(local_part
|| !weechat_config_boolean (irc_config_look_smart_filter)
|| ptr_nick_speaking) ?
"irc_part" : "irc_part,irc_smart_filter",
_("%s%s%s %s(%s%s%s)%s has left "
"%s%s"),
weechat_prefix ("quit"),
@@ -944,7 +967,7 @@ irc_protocol_cmd_part (struct t_irc_server *server, const char *command,
}
/* part request was issued by local client ? */
if (strcmp (ptr_nick->name, server->nick) == 0)
if (local_part)
{
irc_nick_free_all (ptr_channel);
@@ -1158,7 +1181,10 @@ irc_protocol_cmd_privmsg (struct t_irc_server *server, const char *command,
IRC_COLOR_CHAT,
pos_args);
irc_channel_add_nick_speaking (ptr_channel, nick);
irc_channel_nick_speaking_add (ptr_channel, nick);
irc_channel_nick_speaking_time_remove_old (ptr_channel);
irc_channel_nick_speaking_time_add (ptr_channel, nick,
time (NULL));
if (pos_end_01)
pos_end_01[0] = '\01';
@@ -1315,7 +1341,10 @@ irc_protocol_cmd_privmsg (struct t_irc_server *server, const char *command,
NULL),
pos_args);
irc_channel_add_nick_speaking (ptr_channel, nick);
irc_channel_nick_speaking_add (ptr_channel, nick);
irc_channel_nick_speaking_time_remove_old (ptr_channel);
irc_channel_nick_speaking_time_add (ptr_channel, nick,
time (NULL));
}
}
else
@@ -2011,6 +2040,8 @@ irc_protocol_cmd_quit (struct t_irc_server *server, const char *command,
char *pos_comment;
struct t_irc_channel *ptr_channel;
struct t_irc_nick *ptr_nick;
struct t_irc_channel_speaking *ptr_nick_speaking;
int local_quit;
/* QUIT message looks like:
:nick!user@host QUIT :quit message
@@ -2039,10 +2070,16 @@ irc_protocol_cmd_quit (struct t_irc_server *server, const char *command,
/* display quit message */
if (!irc_ignore_check (server, ptr_channel, nick, host))
{
local_quit = (strcmp (nick, server->nick) == 0);
ptr_nick_speaking = (weechat_config_boolean (irc_config_look_smart_filter)) ?
irc_channel_nick_speaking_time_search (ptr_channel, nick, 1) : NULL;
if (pos_comment && pos_comment[0])
{
weechat_printf_tags (ptr_channel->buffer,
"irc_quit",
(local_quit
|| !weechat_config_boolean (irc_config_look_smart_filter)
|| ptr_nick_speaking) ?
"irc_quit" : "irc_quit,irc_smart_filter",
_("%s%s%s %s(%s%s%s)%s has quit "
"%s(%s%s%s)"),
weechat_prefix ("quit"),
@@ -2061,7 +2098,10 @@ irc_protocol_cmd_quit (struct t_irc_server *server, const char *command,
else
{
weechat_printf_tags (ptr_channel->buffer,
"irc_quit",
(local_quit
|| !weechat_config_boolean (irc_config_look_smart_filter)
|| ptr_nick_speaking) ?
"irc_quit" : "irc_quit,irc_smart_filter",
_("%s%s%s %s(%s%s%s)%s has quit"),
weechat_prefix ("quit"),
IRC_COLOR_CHAT_NICK,
+31 -2
View File
@@ -19,6 +19,7 @@
/* irc-upgrade.c: save/restore IRC plugin data */
#include <stdio.h>
#include <string.h>
#include "../weechat-plugin.h"
@@ -168,8 +169,8 @@ int
irc_upgrade_read_cb (int object_id,
struct t_infolist *infolist)
{
int flags, sock, size;
char *str, *buf, *buffer_name;
int flags, sock, size, index;
char *str, *buf, *buffer_name, option_name[64], *nick;
struct t_irc_nick *ptr_nick;
struct t_gui_buffer *ptr_buffer;
@@ -269,6 +270,34 @@ irc_upgrade_read_cb (int object_id,
irc_upgrade_current_channel->cycle = weechat_infolist_integer (infolist, "cycle");
irc_upgrade_current_channel->display_creation_date = weechat_infolist_integer (infolist, "display_creation_date");
irc_upgrade_current_channel->nick_completion_reset = weechat_infolist_integer (infolist, "nick_completion_reset");
index = 0;
while (1)
{
snprintf (option_name, sizeof (option_name),
"nick_speaking_%05d", index);
nick = weechat_infolist_string (infolist, option_name);
if (!nick)
break;
irc_channel_nick_speaking_add (irc_upgrade_current_channel,
nick);
index++;
}
index = 0;
while (1)
{
snprintf (option_name, sizeof (option_name),
"nick_speaking_time_nick_%05d", index);
nick = weechat_infolist_string (infolist, option_name);
if (!nick)
break;
snprintf (option_name, sizeof (option_name),
"nick_speaking_time_time_%05d", index);
irc_channel_nick_speaking_time_add (irc_upgrade_current_channel,
nick,
weechat_infolist_time (infolist,
option_name));
index++;
}
}
}
break;