diff options
57 files changed, 0 insertions, 9209 deletions
diff --git a/.cache/mailx/empty b/.cache/mailx/empty deleted file mode 100644 index e69de29..0000000 --- a/.cache/mailx/empty +++ /dev/null diff --git a/.calendar/calendar b/.calendar/calendar deleted file mode 100644 index a3eb397..0000000 --- a/.calendar/calendar +++ /dev/null @@ -1,36 +0,0 @@ -#include <calendar.usholiday> - -#ifndef _calendar_canada_ -#define _calendar_canada_ - -01/01 New Year's Day (Statutory holiday) -02/02 Groundhog Day -02/14 St. Valentine's Day -02/15 Flag day -03/17 Saint Patrick's Day -03/20* Vernal Equinox -03/SunSecond Daylight Saving Time begins; clocks move forward (2nd Sunday of March) -04/01 April Fool's Day -Easter-2 Good Friday (Statutory holiday) -Easter+1 Easter Monday -05/SunSecond Mother's Day (2nd Sunday of May) -/* Holds until 2016 */ -05/MonThird* Victoria Day (Monday on or immediately before May 24) -06/SunThird Father's Day (3rd Sunday of June) -06/21* Summer Solstice -06/24 St-Jean Baptiste -07/01 Canada Day (Statutory holiday) -08/MonFirst August Civic Holiday -09/MonFirst Labour Day (Statutory holiday) -09/22* Autumnal Equinox -10/MonSecond Thanksgiving -10/31 All Hallows Eve (Halloween) -11/SunFirst Daylight Saving Time ends; clocks move back (1st Sunday in November) -11/11 Remembrance Day -12/21* Winter Solstice -12/24 Christmas Eve -12/25 Christmas Day (Statutory holiday) -12/26 Boxing Day -12/31 New Year's Eve - -#endif /* !_calendar_canada_ */ diff --git a/.cmus/rc b/.cmus/rc deleted file mode 100644 index 7bce8fe..0000000 --- a/.cmus/rc +++ /dev/null @@ -1,4 +0,0 @@ -fset pibroch=genre="Piobaireachd" -bind -f common = vol +1% -bind -f common * vol -1% -factivate @@ -1,16 +0,0 @@ -[extensions] -color = -convert = -hgk = -mq = -pager = -rebase = -record = -shelve = ~/.hgext/hgshelve.py -histedit = - -[ui] -username = Ryan Kavanagh <rak@debian.org> - -[pager] -pager = less -FRXQ diff --git a/.irssi/config b/.irssi/config deleted file mode 100644 index 6667bf6..0000000 --- a/.irssi/config +++ /dev/null @@ -1,750 +0,0 @@ -servers = ( - { - address = "chat.freenode.net"; - chatnet = "Freenode"; - port = "6697"; - use_tls = "yes"; - tls_cert = "~/.irssi/certs/freenode.pem"; - tls_verify = "no"; - autoconnect = "yes"; - }, - { - address = "irc.undernet.org"; - chatnet = "Undernet"; - port = "6667"; - }, - { - address = "irc.oftc.net"; - chatnet = "OFTC"; - port = "6697"; - use_tls = "yes"; - tls_cert = "~/.irssi/certs/oftc.pem"; - tls_verify = "yes"; - autoconnect = "yes"; - }, - { - address = "irc.schmorp.de"; - chatnet = "schmorp"; - port = "6667"; - use_tls = "no"; - tls_verify = "no"; - }, - { - address = "irc.snoonet.org"; - chatnet = "snoonet"; - port = "6697"; - use_tls = "yes"; - tls_cert = "~/.irssi/certs/snoonet.pem"; - tls_verify = "no"; - autoconnect = "yes"; - }, - { - address = "irc.choopa.net"; - chatnet = "EFNet"; - port = "6667"; - use_tls = "no"; - tls_verify = "no"; - autoconnect = "yes"; - }, - { - address = "irc.tilde.chat"; - chatnet = "tilde"; - port = "6697"; - use_tls = "yes"; - tls_cert = "~/.irssi/certs/tilde.pem"; - tls_verify = "yes"; - autoconnect = "yes"; - } -); - -chatnets = { - Freenode = { - type = "IRC"; - max_kicks = "1"; - max_msgs = "4"; - max_whois = "1"; - }; - OFTC = { - type = "IRC"; - nick = "rak"; - autosendcmd = "wait -oftc 2000"; - alternate_nick = "ryanakca"; - max_kicks = "1"; - max_msgs = "1"; - max_whois = "1"; - }; - Undernet = { - type = "IRC"; - max_kicks = "1"; - max_msgs = "1"; - max_whois = "1"; - }; - schmorp = { type = "IRC"; }; - snoonet = { type = "IRC"; nick = "ryanakca"; }; - EFNet = { - type = "IRC"; - nick = "ryanakca"; - alternate_nick = "ryanakca_"; - }; - tilde = { type = "IRC"; nick = "rak_"; alternate_nick = "rak__"; }; -}; - -aliases = { - ATAG = "WINDOW SERVER"; - ADDALLCHANS = "SCRIPT EXEC foreach my \\$channel (Irssi::channels()) { Irssi::command(\"CHANNEL ADD -auto \\$channel->{name} \\$channel->{server}->{tag} \\$channel->{key}\")\\;}"; - B = "BAN"; - BACK = "AWAY"; - BANS = "BAN"; - BYE = "QUIT"; - C = "CLEAR"; - CALC = "EXEC - if command -v bc >/dev/null 2>&1\\; then printf '%s=' '$*'\\; echo '$*' | bc -l\\; else echo bc was not found\\; fi"; - CHAT = "DCC CHAT"; - CUBES = "SCRIPT EXEC Irssi::active_win->print(\"%_bases\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { join '', map { \"%x0\\${_}0\\$_\" } '0'..'9','A'..'F' }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print(\"%_cubes\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { my \\$y = \\$_*6 \\; join '', map { my \\$x = \\$_ \\; map { \"%x\\$x\\$_\\$x\\$_\" } @{['0'..'9','A'..'Z']}[\\$y .. \\$y+5] } 1..6 }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) for 0..5 \\; Irssi::active_win->print(\"%_grays\", MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print( do { join '', map { \"%x7\\${_}7\\$_\" } 'A'..'X' }, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; Irssi::active_win->print(\"%_mIRC extended colours\", MSGLEVEL_CLIENTCRAP) \\; my \\$x \\; \\$x .= sprintf \"\00399,%02d%02d\",\\$_,\\$_ for 0..15 \\; Irssi::active_win->print(\\$x, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) \\; for my \\$z (0..6) { my \\$x \\; \\$x .= sprintf \"\00399,%02d%02d\",\\$_,\\$_ for 16+(\\$z*12)..16+(\\$z*12)+11 \\; Irssi::active_win->print(\\$x, MSGLEVEL_NEVER | MSGLEVEL_CLIENTCRAP) }"; - DATE = "TIME"; - DEHIGHLIGHT = "DEHILIGHT"; - DESCRIBE = "ACTION"; - DHL = "DEHILIGHT"; - EXEMPTLIST = "MODE $C +e"; - EXIT = "QUIT"; - GOTO = "SCROLLBACK GOTO"; - HIGHLIGHT = "HILIGHT"; - HL = "HILIGHT"; - HOST = "USERHOST"; - INVITELIST = "MODE $C +I"; - J = "JOIN"; - K = "KICK"; - KB = "KICKBAN"; - KN = "KNOCKOUT"; - LAST = "LASTLOG"; - LEAVE = "PART"; - M = "MSG"; - MUB = "UNBAN *"; - N = "NAMES"; - NMSG = "^MSG"; - P = "PART"; - Q = "QUERY"; - RESET = "SET -default"; - RUN = "SCRIPT LOAD"; - SAY = "MSG *"; - SB = "SCROLLBACK"; - SBAR = "STATUSBAR"; - SIGNOFF = "QUIT"; - SV = "MSG * Irssi $J ($V) - http://www.irssi.org"; - T = "TOPIC"; - UB = "UNBAN"; - UMODE = "MODE $N"; - UNSET = "SET -clear"; - W = "/window goto"; - WC = "WINDOW CLOSE"; - WG = "WINDOW GOTO"; - WJOIN = "JOIN -window"; - WI = "WHOIS"; - WII = "WHOIS $0 $0"; - WL = "WINDOW LIST"; - WQUERY = "QUERY -window"; - WW = "WHOWAS"; - 1 = "WINDOW GOTO 1"; - 2 = "WINDOW GOTO 2"; - 3 = "WINDOW GOTO 3"; - 4 = "WINDOW GOTO 4"; - 5 = "WINDOW GOTO 5"; - 6 = "WINDOW GOTO 6"; - 7 = "WINDOW GOTO 7"; - 8 = "WINDOW GOTO 8"; - 9 = "WINDOW GOTO 9"; - 10 = "WINDOW GOTO 10"; - 11 = "WINDOW GOTO 11"; - 12 = "WINDOW GOTO 12"; - 13 = "WINDOW GOTO 13"; - 14 = "WINDOW GOTO 14"; - 15 = "WINDOW GOTO 15"; - 16 = "WINDOW GOTO 16"; - 17 = "WINDOW GOTO 17"; - 18 = "WINDOW GOTO 18"; - 19 = "WINDOW GOTO 19"; - 20 = "WINDOW GOTO 20"; - 21 = "WINDOW GOTO 21"; - 22 = "WINDOW GOTO 22"; - 23 = "WINDOW GOTO 23"; - 24 = "WINDOW GOTO 24"; - 25 = "WINDOW GOTO 25"; - 26 = "WINDOW GOTO 26"; - 27 = "WINDOW GOTO 27"; - 28 = "WINDOW GOTO 28"; - 29 = "WINDOW GOTO 29"; - 30 = "WINDOW GOTO 30"; - 31 = "WINDOW GOTO 31"; - 32 = "WINDOW GOTO 32"; - 33 = "WINDOW GOTO 33"; - 34 = "WINDOW GOTO 34"; - 35 = "WINDOW GOTO 35"; - 36 = "WINDOW GOTO 36"; - 37 = "WINDOW GOTO 37"; - 38 = "WINDOW GOTO 38"; - 39 = "WINDOW GOTO 39"; - 40 = "WINDOW GOTO 40"; - 41 = "WINDOW GOTO 41"; - 42 = "WINDOW GOTO 42"; - 43 = "WINDOW GOTO 43"; - 44 = "WINDOW GOTO 44"; - 45 = "WINDOW GOTO 45"; - 46 = "WINDOW GOTO 46"; - 47 = "WINDOW GOTO 47"; - 48 = "WINDOW GOTO 48"; - 49 = "WINDOW GOTO 49"; - 50 = "WINDOW GOTO 50"; - 51 = "WINDOW GOTO 51"; - 52 = "WINDOW GOTO 52"; - 53 = "WINDOW GOTO 53"; - 54 = "WINDOW GOTO 54"; - 55 = "WINDOW GOTO 55"; - 56 = "WINDOW GOTO 56"; - 57 = "WINDOW GOTO 57"; - 58 = "WINDOW GOTO 58"; - 59 = "WINDOW GOTO 59"; - 60 = "WINDOW GOTO 60"; - 61 = "WINDOW GOTO 61"; - 62 = "WINDOW GOTO 62"; - 63 = "WINDOW GOTO 63"; - 64 = "WINDOW GOTO 64"; - 65 = "WINDOW GOTO 65"; - 66 = "WINDOW GOTO 66"; - 67 = "WINDOW GOTO 67"; - 68 = "WINDOW GOTO 68"; - 69 = "WINDOW GOTO 69"; - 70 = "WINDOW GOTO 70"; - 71 = "WINDOW GOTO 71"; - 72 = "WINDOW GOTO 72"; - 73 = "WINDOW GOTO 73"; - 74 = "WINDOW GOTO 74"; - 75 = "WINDOW GOTO 75"; - 76 = "WINDOW GOTO 76"; - 77 = "WINDOW GOTO 77"; - 78 = "WINDOW GOTO 78"; - 79 = "WINDOW GOTO 79"; - 80 = "WINDOW GOTO 80"; - 81 = "WINDOW GOTO 81"; - 82 = "WINDOW GOTO 82"; - 83 = "WINDOW GOTO 83"; - 84 = "WINDOW GOTO 84"; - 85 = "WINDOW GOTO 85"; - 86 = "WINDOW GOTO 86"; - 87 = "WINDOW GOTO 87"; - 88 = "WINDOW GOTO 88"; - 89 = "WINDOW GOTO 89"; - 90 = "WINDOW GOTO 90"; - 91 = "WINDOW GOTO 91"; - 92 = "WINDOW GOTO 92"; - 93 = "WINDOW GOTO 93"; - 94 = "WINDOW GOTO 94"; - 95 = "WINDOW GOTO 95"; - 96 = "WINDOW GOTO 96"; - 97 = "WINDOW GOTO 97"; - 98 = "WINDOW GOTO 98"; - 99 = "WINDOW GOTO 99"; - wn = "/window goto"; -}; - -statusbar = { - - items = { - - barstart = "{sbstart}"; - barend = "{sbend}"; - - topicbarstart = "{topicsbstart}"; - topicbarend = "{topicsbend}"; - - time = "{sb $Z}"; - user = "{sb {sbnickmode $cumode}$N{sbmode $usermode}{sbaway $A}}"; - - window = "{sb $winref:$tag/$itemname{sbmode $M}}"; - window_empty = "{sb $winref{sbservertag $tag}}"; - - prompt = "{prompt $[.15]itemname}"; - prompt_empty = "{prompt $winname}"; - - topic = " $topic"; - topic_empty = " Irssi v$J - http://www.irssi.org"; - - lag = "{sb Lag: $0-}"; - act = "{sb Act: $0-}"; - more = "-- more --"; - }; - - default = { - - window = { - - disabled = "no"; - type = "window"; - placement = "bottom"; - position = "1"; - visible = "active"; - - items = { - barstart = { priority = "100"; }; - time = { }; - user = { }; - window = { }; - window_empty = { }; - lag = { priority = "-1"; }; - more = { priority = "-1"; alignment = "right"; }; - barend = { priority = "100"; alignment = "right"; }; - usercount = { }; - }; - }; - - window_inact = { - - type = "window"; - placement = "bottom"; - position = "1"; - visible = "inactive"; - - items = { - barstart = { priority = "100"; }; - window = { }; - window_empty = { }; - more = { priority = "-1"; alignment = "right"; }; - barend = { priority = "100"; alignment = "right"; }; - }; - }; - - prompt = { - - type = "root"; - placement = "bottom"; - position = "100"; - visible = "always"; - - items = { - prompt = { priority = "-1"; }; - prompt_empty = { priority = "-1"; }; - input = { priority = "10"; }; - }; - }; - - topic = { - - type = "root"; - placement = "top"; - position = "1"; - visible = "always"; - - items = { - topicbarstart = { priority = "100"; }; - twtopic = { priority = "100"; }; - topicbarend = { priority = "100"; alignment = "right"; }; - }; - }; - awl_0 = { - items = { - barstart = { priority = "100"; }; - awl_0 = { }; - barend = { priority = "100"; alignment = "right"; }; - }; - }; - }; -}; -settings = { - core = { - real_name = "Ryan Kavanagh"; - user_name = "rak"; - nick = "rak"; - timestamp_format = "%H:%M"; - quit_message = ""; - }; - "fe-text" = { actlist_sort = "refnum"; }; - "fe-common/core" = { - autolog = "yes"; - autolog_path = "~/irclogs/$tag/$0.log"; - theme = "envy"; - }; - "perl/core/scripts" = { - awl_shared_sbar = "OFF"; - chansort_autosort = "yes"; - twtopic_size = "173"; - twtopic_instruct = "no"; - twtopic_auto_resize = "yes"; - twtopic_refresh = "500"; - twtopic_min_scroll = "no"; - twtopic_ar_padding = "0"; - twtopic_init_pause = "200"; - recdep_channels = "Freenode/ OFTC/ snoonet/"; - recdep_period = "3600"; - autoaway_timeout = "300"; - }; - "irc/core" = { alternate_nick = "ryanakca"; }; -}; -logs = { }; -hilights = ( - { text = "*ryanakca*"; nick = "no"; word = "yes"; }, - { text = "Ryan Kavanagh"; nick = "no"; word = "yes"; }, - { text = "ryanakca -word"; nick = "yes"; word = "yes"; }, - { - text = "[ ]rak[ :,.;@']"; - nick = "no"; - word = "yes"; - regexp = "yes"; - } -); -channels = ( - { name = "#rxvt-unicode"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#opensmtpd"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#kubuntu-devel"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#debian-devel"; chatnet = "OFTC"; autojoin = "yes"; }, - { - name = "#debian-private"; - chatnet = "OFTC"; - autojoin = "yes"; - }, - { name = "#schmorpforge"; chatnet = "schmorp"; autojoin = "yes"; }, - { name = "#debian-multimedia"; chatnet = "OFTC"; autojoin = "yes"; }, - { - name = "#debian-devel-changes"; - chatnet = "OFTC"; - autojoin = "yes"; - }, - { - name = "##computerscience"; - chatnet = "Freenode"; - autojoin = "yes"; - }, - { name = "##math"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#debian-quebec"; chatnet = "OFTC"; autojoin = "yes"; }, - { name = "##cclub"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#openbsd"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "##russian"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "##dependent"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "##typetheory"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "##logic"; chatnet = "Freenode"; autojoin = "yes"; }, - { - name = "##categorytheory"; - chatnet = "Freenode"; - autojoin = "yes"; - }, - { name = "#sml"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#personalfinance"; chatnet = "snoonet"; }, - { name = "#debian-haskell"; chatnet = "OFTC"; autojoin = "yes"; }, - { name = "#beer"; chatnet = "snoonet"; }, - { name = "#canada"; chatnet = "snoonet"; }, - { name = "#news"; chatnet = "snoonet"; autojoin = "yes"; }, - { name = "#reddit"; chatnet = "snoonet"; autojoin = "yes"; }, - { name = "#russian"; chatnet = "snoonet"; }, - { name = "#debian-offtopic"; chatnet = "OFTC"; autojoin = "yes"; }, - { name = "#debian-games"; chatnet = "OFTC"; autojoin = "yes"; }, - { name = "#neomutt"; chatnet = "Freenode"; autojoin = "yes"; }, - { name = "#rspamd"; chatnet = "freenode"; autojoin = "yes"; }, - { name = "#dovecot"; chatnet = "freenode"; autojoin = "yes"; }, - { name = "#debian-til"; chatnet = "OFTC"; autojoin = "yes"; }, - { - name = "#casualconversation"; - chatnet = "snoonet"; - autojoin = "yes"; - }, - { name = "#math"; chatnet = "snoonet"; autojoin = "yes"; }, - { name = "#talk"; chatnet = "snoonet"; autojoin = "yes"; }, - { name = "#org-mode"; chatnet = "freenode"; autojoin = "yes"; }, - { name = "#team"; chatnet = "tilde"; autojoin = "yes"; }, - { name = "#meta"; chatnet = "tilde"; autojoin = "yes"; }, - { name = "#gophernicus"; chatnet = "Freenode"; autojoin = "yes"; } -); -keyboard = ( - { key = "meta-1"; id = "change_window"; data = "1"; }, - { key = "meta-2"; id = "change_window"; data = "2"; }, - { key = "meta-3"; id = "change_window"; data = "3"; }, - { key = "meta-4"; id = "change_window"; data = "4"; }, - { key = "meta-5"; id = "change_window"; data = "5"; }, - { key = "meta-6"; id = "change_window"; data = "6"; }, - { key = "meta-7"; id = "change_window"; data = "7"; }, - { key = "meta-8"; id = "change_window"; data = "8"; }, - { key = "meta-9"; id = "change_window"; data = "9"; }, - { key = "meta-0"; id = "change_window"; data = "10"; }, - { key = "meta-&"; id = "change_window"; data = "1"; }, - { key = "meta-["; id = "change_window"; data = "2"; }, - { key = "meta-{"; id = "change_window"; data = "3"; }, - { key = "meta-}"; id = "change_window"; data = "4"; }, - { key = "meta-("; id = "change_window"; data = "5"; }, - { key = "meta-="; id = "change_window"; data = "6"; }, - { key = "meta-*"; id = "change_window"; data = "7"; }, - { key = "meta-)"; id = "change_window"; data = "8"; }, - { key = "meta-+"; id = "change_window"; data = "9"; }, - { key = "meta-]"; id = "change_window"; data = "10"; }, - { key = "meta-;"; id = "change_window"; data = "11"; }, - { key = "meta-,"; id = "change_window"; data = "12"; }, - { key = "meta-."; id = "change_window"; data = "13"; }, - { key = "meta-y"; id = "change_window"; data = "14"; }, - { key = "meta-g"; id = "change_window"; data = "15"; }, - { key = "meta-c"; id = "change_window"; data = "16"; }, - { key = "meta-r"; id = "change_window"; data = "17"; }, - { key = "meta-l"; id = "change_window"; data = "18"; } -); -windows = { - 1 = { immortal = "yes"; name = "(status)"; level = "ALL"; }; - 2 = { name = "hilight"; sticky = "yes"; }; - 3 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##categorytheory"; - tag = "Freenode"; - } - ); - }; - 4 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##cclub"; - tag = "Freenode"; - } - ); - }; - 5 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##computerscience"; - tag = "Freenode"; - } - ); - }; - 6 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##dependent"; - tag = "Freenode"; - } - ); - }; - 7 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##logic"; - tag = "Freenode"; - } - ); - }; - 8 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##math"; - tag = "Freenode"; - } - ); - }; - 9 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##russian"; - tag = "Freenode"; - } - ); - }; - 10 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "##typetheory"; - tag = "Freenode"; - } - ); - }; - 11 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#dovecot"; - tag = "Freenode"; - } - ); - }; - 12 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#kubuntu-devel"; - tag = "Freenode"; - } - ); - }; - 13 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#neomutt"; - tag = "Freenode"; - } - ); - }; - 14 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#openbsd"; - tag = "Freenode"; - } - ); - }; - 15 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#opensmtpd"; - tag = "Freenode"; - } - ); - }; - 16 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#rspamd"; - tag = "Freenode"; - } - ); - }; - 17 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#rxvt-unicode"; - tag = "Freenode"; - } - ); - }; - 18 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#sml"; - tag = "Freenode"; - } - ); - }; - 19 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-devel"; - tag = "OFTC"; - } - ); - }; - 20 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-devel-changes"; - tag = "OFTC"; - } - ); - }; - 21 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-games"; - tag = "OFTC"; - } - ); - }; - 22 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-haskell"; - tag = "OFTC"; - } - ); - }; - 23 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-multimedia"; - tag = "OFTC"; - } - ); - }; - 24 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-offtopic"; - tag = "OFTC"; - } - ); - }; - 25 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-private"; - tag = "OFTC"; - } - ); - }; - 26 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#debian-quebec"; - tag = "OFTC"; - } - ); - }; - 27 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#news"; - tag = "snoonet"; - } - ); - }; - 28 = { - items = ( - { - type = "CHANNEL"; - chat_type = "IRC"; - name = "#reddit"; - tag = "snoonet"; - } - ); - }; -}; -mainwindows = { - 21 = { first_line = "12"; lines = "74"; }; - 2 = { first_line = "1"; lines = "11"; }; -}; diff --git a/.irssi/default.theme b/.irssi/default.theme deleted file mode 100644 index 6b6aeab..0000000 --- a/.irssi/default.theme +++ /dev/null @@ -1,294 +0,0 @@ -# When testing changes, the easiest way to reload the theme is with /RELOAD. -# This reloads the configuration file too, so if you did any changes remember -# to /SAVE it first. Remember also that /SAVE overwrites the theme file with -# old data so keep backups :) - -# TEMPLATES: - -# The real text formats that irssi uses are the ones you can find with -# /FORMAT command. Back in the old days all the colors and texts were mixed -# up in those formats, and it was really hard to change the colors since you -# might have had to change them in tens of different places. So, then came -# this templating system. - -# Now the /FORMATs don't have any colors in them, and they also have very -# little other styling. Most of the stuff you need to change is in this -# theme file. If you can't change something here, you can always go back -# to change the /FORMATs directly, they're also saved in these .theme files. - -# So .. the templates. They're those {blahblah} parts you see all over the -# /FORMATs and here. Their usage is simply {name parameter1 parameter2}. -# When irssi sees this kind of text, it goes to find "name" from abstracts -# block below and sets "parameter1" into $0 and "parameter2" into $1 (you -# can have more parameters of course). Templates can have subtemplates. -# Here's a small example: -# /FORMAT format hello {colorify {underline world}} -# abstracts = { colorify = "%G$0-%n"; underline = "%U$0-%U"; } -# When irssi expands the templates in "format", the final string would be: -# hello %G%Uworld%U%n -# ie. underlined bright green "world" text. -# and why "$0-", why not "$0"? $0 would only mean the first parameter, -# $0- means all the parameters. With {underline hello world} you'd really -# want to underline both of the words, not just the hello (and world would -# actually be removed entirely). - -# COLORS: - -# You can find definitions for the color format codes in docs/formats.txt. - -# There's one difference here though. %n format. Normally it means the -# default color of the terminal (white mostly), but here it means the -# "reset color back to the one it was in higher template". For example -# if there was /FORMAT test %g{foo}bar, and foo = "%Y$0%n", irssi would -# print yellow "foo" (as set with %Y) but "bar" would be green, which was -# set at the beginning before the {foo} template. If there wasn't the %g -# at start, the normal behaviour of %n would occur. If you _really_ want -# to use the terminal's default color, use %N. - -############################################################################# - -# default foreground color (%N) - -1 is the "default terminal color" -default_color = "-1"; - -# print timestamp/servertag at the end of line, not at beginning -info_eol = "false"; - -# these characters are automatically replaced with specified color -# (dark grey by default) -replaces = { "[]=" = "%K$*%n"; }; - -abstracts = { - ## - ## generic - ## - - # text to insert at the beginning of each non-message line - line_start = "%B-%n!%B-%n "; - - # timestamp styling, nothing by default - timestamp = "$*"; - - # any kind of text that needs hilighting, default is to bold - hilight = "%_$*%_"; - - # any kind of error message, default is bright red - error = "%R$*%n"; - - # channel name is printed - channel = "%_$*%_"; - - # nick is printed - nick = "%_$*%_"; - - # nick host is printed - nickhost = "[$*]"; - - # server name is printed - server = "%_$*%_"; - - # some kind of comment is printed - comment = "[$*]"; - - # reason for something is printed (part, quit, kick, ..) - reason = "{comment $*}"; - - # mode change is printed ([+o nick]) - mode = "{comment $*}"; - - ## - ## channel specific messages - ## - - # highlighted nick/host is printed (joins) - channick_hilight = "%C$*%n"; - chanhost_hilight = "{nickhost %c$*%n}"; - - # nick/host is printed (parts, quits, etc.) - channick = "%c$*%n"; - chanhost = "{nickhost $*}"; - - # highlighted channel name is printed - channelhilight = "%c$*%n"; - - # ban/ban exception/invite list mask is printed - ban = "%c$*%n"; - - ## - ## messages - ## - - # the basic styling of how to print message, $0 = nick mode, $1 = nick - msgnick = "%K<%n$0$1-%K>%n %|"; - - # message from you is printed. "ownnick" specifies the styling of the - # nick ($0 part in msgnick) and "ownmsgnick" specifies the styling of the - # whole line. - - # Example1: You want the message text to be green: - # ownmsgnick = "{msgnick $0 $1-}%g"; - # Example2.1: You want < and > chars to be yellow: - # ownmsgnick = "%Y{msgnick $0 $1-%Y}%n"; - # (you'll also have to remove <> from replaces list above) - # Example2.2: But you still want to keep <> grey for other messages: - # pubmsgnick = "%K{msgnick $0 $1-%K}%n"; - # pubmsgmenick = "%K{msgnick $0 $1-%K}%n"; - # pubmsghinick = "%K{msgnick $1 $0$2-%n%K}%n"; - # ownprivmsgnick = "%K{msgnick $*%K}%n"; - # privmsgnick = "%K{msgnick %R$*%K}%n"; - - # $0 = nick mode, $1 = nick - ownmsgnick = "{msgnick $0 $1-}"; - ownnick = "%_$*%n"; - - # public message in channel, $0 = nick mode, $1 = nick - pubmsgnick = "{msgnick $0 $1-}"; - pubnick = "%N$*%n"; - - # public message in channel meant for me, $0 = nick mode, $1 = nick - pubmsgmenick = "{msgnick $0 $1-}"; - menick = "%Y$*%n"; - - # public highlighted message in channel - # $0 = highlight color, $1 = nick mode, $2 = nick - pubmsghinick = "{msgnick $1 $0$2-%n}"; - - # channel name is printed with message - msgchannel = "%K:%c$*%n"; - - # private message, $0 = nick, $1 = host - privmsg = "[%R$0%K(%r$1-%K)%n] "; - - # private message from you, $0 = "msg", $1 = target nick - ownprivmsg = "[%r$0%K(%R$1-%K)%n] "; - - # own private message in query - ownprivmsgnick = "{msgnick $*}"; - ownprivnick = "%_$*%n"; - - # private message in query - privmsgnick = "{msgnick %R$*%n}"; - - ## - ## Actions (/ME stuff) - ## - - # used internally by this theme - action_core = "%_ * $*%n"; - - # generic one that's used by most actions - action = "{action_core $*} "; - - # own action, both private/public - ownaction = "{action $*}"; - - # own action with target, both private/public - ownaction_target = "{action_core $0}%K:%c$1%n "; - - # private action sent by others - pvtaction = "%_ (*) $*%n "; - pvtaction_query = "{action $*}"; - - # public action sent by others - pubaction = "{action $*}"; - - - ## - ## other IRC events - ## - - # whois - whois = "%# $[8]0 : $1-"; - - # notices - ownnotice = "[%r$0%K(%R$1-%K)]%n "; - notice = "%K-%M$*%K-%n "; - pubnotice_channel = "%K:%m$*"; - pvtnotice_host = "%K(%m$*%K)"; - servernotice = "%g!$*%n "; - - # CTCPs - ownctcp = "[%r$0%K(%R$1-%K)] "; - ctcp = "%g$*%n"; - - # wallops - wallop = "%_$*%n: "; - wallop_nick = "%n$*"; - wallop_action = "%_ * $*%n "; - - # netsplits - netsplit = "%R$*%n"; - netjoin = "%C$*%n"; - - # /names list - names_prefix = ""; - names_nick = "[%_$0%_$1-] "; - names_nick_op = "{names_nick $*}"; - names_nick_halfop = "{names_nick $*}"; - names_nick_voice = "{names_nick $*}"; - names_users = "[%g$*%n]"; - names_channel = "%G$*%n"; - - # DCC - dcc = "%g$*%n"; - dccfile = "%_$*%_"; - - # DCC chat, own msg/action - dccownmsg = "[%r$0%K($1-%K)%n] "; - dccownnick = "%R$*%n"; - dccownquerynick = "%_$*%n"; - dccownaction = "{action $*}"; - dccownaction_target = "{action_core $0}%K:%c$1%n "; - - # DCC chat, others - dccmsg = "[%G$1-%K(%g$0%K)%n] "; - dccquerynick = "%G$*%n"; - dccaction = "%_ (*dcc*) $*%n %|"; - - ## - ## statusbar - ## - - # default background for all statusbars. You can also give - # the default foreground color for statusbar items. - sb_background = "%4%w"; - - # default backround for "default" statusbar group - #sb_default_bg = "%4"; - # background for prompt / input line - sb_prompt_bg = "%n"; - # background for info statusbar - sb_info_bg = "%8"; - # background for topicbar (same default) - #sb_topic_bg = "%4"; - - # text at the beginning of statusbars. sb-item already puts - # space there,so we don't use anything by default. - sbstart = ""; - # text at the end of statusbars. Use space so that it's never - # used for anything. - sbend = " "; - - topicsbstart = "{sbstart $*}"; - topicsbend = "{sbend $*}"; - - prompt = "[$*] "; - - sb = " %c[%n$*%c]%n"; - sbmode = "(%c+%n$*)"; - sbaway = " (%GzZzZ%n)"; - sbservertag = ":$0 (change with ^X)"; - sbnickmode = "$0"; - - # activity in statusbar - - # ',' separator - sb_act_sep = "%c$*"; - # normal text - sb_act_text = "%c$*"; - # public message - sb_act_msg = "%W$*"; - # hilight - sb_act_hilight = "%M$*"; - # hilight with specified color, $0 = color, $1 = text - sb_act_hilight_color = "$0$1-%n"; -}; diff --git a/.irssi/envy.theme b/.irssi/envy.theme deleted file mode 100644 index b415d77..0000000 --- a/.irssi/envy.theme +++ /dev/null @@ -1,502 +0,0 @@ -# ___ ___ ___ ___ -# /\ \ /\__\ /\__\ |\__\ -# /::\ \ /::| | /:/ / |:| | -# /:/\:\ \ /:|:| | /:/ / |:| | -# /::\~\:\ \ /:/|:| |__ /:/__/ ___ |:|__|__ -# /:/\:\ \:\__\ /:/ |:| /\__\ |:| | /\__\ /::::\__\ -# \:\~\:\ \/__/ \/__|:|/:/ / |:| |/:/ / /:/~~/~ -# \:\ \:\__\ |:/:/ / |:|__/:/ / /:/ / -# \:\ \/__/ |::/ / \::::/__/ \/__/ -# \:\__\ /:/ / ~~~~ -# \/__/ \/__/ v. 3.6 -# -# theme by rolle (rolle @ QuakeNet, rolle_ @ Ircnet) -# http://rollemaa.org/ -# -# you can find the most recent version here: -# http://rolle.tux.fi - -default_color = "-1"; -# Timestamp/servertag loppuun, ei alkuun -info_eol = "false"; -replaces = { "[]=" = "$*"; }; - -abstracts = { - line_start = "%K"; - timestamp = "%K$*%n"; - hilight = "$*"; - error = "$*"; - channel = "$*"; - nick = "$*"; - nickhost = "$*"; - server = "$*"; - comment = "$*"; - reason = "{comment $*}"; - mode = "{comment $*}"; - channick_hilight = "$*"; - chanhost_hilight = "{nickhost $*}"; - channick = "$*"; - chanhost = "{nickhost $*}"; - channelhilight = "$*"; - ban = "$*"; - # Kaikissa alemmissa: $0 = mode, $1 = nick - msgnick = "$0$1- %|"; - ownmsgnick = "{msgnick %K<$0 %G$1-%K>}%n"; - ownnick = "$*"; - pubmsgnick = "{msgnick %K<$0 %W$1-%K>}%n"; - pubnick = "$*"; - pubmsgmenick = "{msgnick %K<$0 %P$1-%K>}%P"; - menick = "%P$*%n"; - # $0 = hilightin väri, $1 = mode, $2 = nick - pubmsghinick = "{msgnick %K<$1 %P$2-%K>%P}"; - msgchannel = ":$*"; - # $0 = nick, $1 = hosti - privmsg = "[$0($1-)] "; - # $0 = "msg", $1 = target nick - ownprivmsg = "[$0($1-)] "; - ownprivmsgnick = "{msgnick $*}"; - ownprivnick = "%K<%G$*%K>%n"; - privmsgnick = "%K<%B$*%K>%n "; - action_core = " %r>%y>%g> %c$0-"; - action = "{action_core $*} "; - ownaction = "{action $*}"; - ownaction_target = "{action_core $*}:$1 "; - pvtaction = " (>>>) $* "; - pvtaction_query = "{action $*}"; - pubaction = "{action $*}"; - ownnotice = "[$0($1-)] "; - notice = "%g$*%K -> %G"; - whois = "%# $[8]0 : $1-"; - pubnotice_channel = ":$*"; - pvtnotice_host = "($*)"; - servernotice = "%r!$* %n"; - ownctcp = "[$0($1-)] "; - ctcp = "$*"; - wallop = "$*: "; - wallop_nick = "$*"; - wallop_action = " * $* "; - netsplit = "$*"; - netjoin = "%K::%g:%K $*"; - names_prefix = "%K"; - names_nick = "%K[$0$1-] "; - names_nick_op = "%K{names_nick $*}"; - names_nick_halfop = "%K{names_nick $*}"; - names_nick_voice = "%K{names_nick $*}"; - names_users = "%K[$*]"; - names_channel = "%K$*"; - dcc = "$*"; - dccfile = "$*"; - dccownmsg = "[$0($1-)] "; - dccownnick = "$*"; - dccownquerynick = "$*"; - dccownaction = "{action $*}"; - dccownaction_target = "{action_core $0}:$1 "; - dccmsg = "[$1-($0)] "; - dccquerynick = "$*"; - dccaction = " (*dcc*) $* %|"; - sb_background = ""; - sb_window_bg = "%n%2"; - sb_default_bg = ""; - sb_prompt_bg = "%0"; - sb_info_bg = ""; - sb_topic_bg = "%G"; - sbstart = ""; - sbend = " "; - topicsbstart = "{sbstart $*}"; - topicsbend = "{sbend $*}"; - prompt = "%R!%G$*%K: "; - sb = " %w/%W$*%w/%n"; - sbmode = ""; - sbaway = "%r>%n"; - sbservertag = "%W$0%n"; - sbnickmode = ""; - sb_act_sep = "%w$*%n"; - sb_act_text = "%G$*%n"; - sb_act_msg = "%G$*%n"; - sb_act_hilight = "%r($*)%n"; - sb_act_hilight_color = "%r$0$1-%n"; -}; -formats = { - "fe-common/core" = { - query_start = "%K:%K:%g:%K %gStarting query%K in {server $1} with {nick $0}"; - join = "%K::%g:%K {channick_hilight $0} [{chanhost_hilight $1}] has %gjoined%K {channel $2}"; - part = "%r:%K:: {channick $0} [{chanhost $1}] has %rleft%K {channel $2}"; - quit = "%r:%K:: {channick $0} [{chanhost $1}] has %rquit%k ({reason $2})"; - quit_once = "%r:%K:: {channick $0} [{chanhost $1}] has %rquit%K ({reason $2})"; - nick_changed = "%K:%y:%K: {channick_hilight $0} is %ynow known as%K {channick_hilight $1}"; - # own_msg = "{ownmsgnick $2 {ownnick $[-10]0}}$1"; - # own_msg_channel = "{ownmsgnick $3 {ownnick $[-10]0}{msgchannel $1}}$2"; - # pubmsg_me = "{pubmsgmenick $2 {menick $[-10]0}}$1"; - # pubmsg_me_channel = "{pubmsgmenick $3 {menick $[-10]0}{msgchannel $1}}$2"; - # pubmsg_hilight = "{pubmsghinick $0 $3 $[-10]1}$2"; - # pubmsg_hilight_channel = "{pubmsghinick $0 $4 $[-10]1{msgchannel $2}}$3"; - # pubmsg = "{pubmsgnick $2 {pubnick \0030$0}}$1"; - # pubmsg_channel = "{pubmsgnick $3 {pubnick $[-10]0}{msgchannel $1}}$2"; - # line_start = "{line_start}"; - # line_start_irssi = "{line_start}{hilight Irssi} %W|%n "; - line_start_irssi = "{line_start}"; - timestamp = "%K{timestamp $Z} "; - # servertag = "$[-11]0 %W|%n "; - servertag = ""; - daychange = "Day changed to %%d %%b %%Y %n"; - talking_with = "%r:%y:%g:%K You are now talking with {nick $0}"; - refnum_too_low = "%r:%K:: Window number must be greater than 1"; - error_server_sticky = "%r:%K:: Window's server is %rsticky%K and it cannot be changed without -unsticky option"; - set_server_sticky = "%K::%g:%K Window's server %gset sticky%K"; - unset_server_sticky = "%K::%g:%K Window's server isn't sticky anymore"; - window_name_not_unique = "%r:%K:: Window names must be unique"; - window_level = "%K::%g:%K Window level is now $0"; - windowlist_header = "Ref Name Active item Server Level"; - windowlist_line = "$[3]0 %|$[20]1 $[15]2 $[15]3 $4"; - windowlist_footer = ""; - windows_layout_saved = "%K::%g:%K Layout of windows is now %gremembered%K next time you start irssi"; - windows_layout_reset = "%K::%g:%K Layout of windows %greset%K to defaults"; - window_info_header = ""; - window_info_footer = ""; - window_info_refnum = "Window : {hilight #$0}"; - window_info_refnum_sticky = "Window : {hilight #$0 (sticky)}"; - window_info_name = "Name : $0"; - window_info_history = "History : $0"; - window_info_size = "Size : $0x$1"; - window_info_level = "Level : $0"; - window_info_server = "Server : $0"; - window_info_server_sticky = "Server : $0 (sticky)"; - window_info_theme = "Theme : $0$1"; - window_info_bound_items_header = "Bounds : {hilight Name Server tag}"; - window_info_bound_item = " : $[!30]0 $[!15]1 $2"; - window_info_bound_items_footer = ""; - window_info_items_header = "Items : {hilight Name Server tag}"; - window_info_item = " $[7]0: $[!30]1 $2"; - window_info_items_footer = ""; - looking_up = "%K::%g:%K %gLooking up%K {server $0}"; - connecting = "%K::%g:%K %gConnecting%K to {server $0} [$1] port {hilight $2}"; - connection_established = "%K::%g:%K Connection to {server $0} %gestablished%K"; - cant_connect = "%r:%K:: %rUnable to connect%K server {server $0} port {hilight $1} {reason $2}"; - connection_lost = "%r:%K:: %rConnection lost%K to {server $0}"; - lag_disconnected = "%r:%K:: %rNo PONG reply%K from server {server $0} in $1 seconds, disconnecting"; - disconnected = "%r:%K:: %rDisconnected%K from {server $0} {reason $1}"; - server_quit = "%r:%K:: %rDisconnecting%K from server {server $0}: {reason $1}"; - server_changed = "%K:%y:%K: %yChanged%K to {hilight $2} server {server $1}"; - unknown_server_tag = "%r:%K:: %rUnknown%K server tag {server $0}"; - no_connected_servers = "%r:%K:: %rNot connected%K to any servers"; - server_list = "{server $0}: $1:$2 ($3)"; - server_lookup_list = "{server $0}: $1:$2 ($3) (connecting...)"; - server_reconnect_list = "{server $0}: $1:$2 ($3) ($5 left before reconnecting)"; - server_reconnect_removed = "%K::%g:%K %gRemoved reconnection%K to server {server $0} port {hilight $1}"; - server_reconnect_not_found = "%r:%K:: Reconnection tag {server $0} %rnot found%K"; - setupserver_added = "%K::%g:%K Server {server $0} %gsaved%K"; - setupserver_removed = "%K::%g:%K Server {server $0} %gremoved%K"; - setupserver_not_found = "%r:%K:: Server {server $0} %rnot found%K"; - your_nick = "%r:%y:%g:%K Your nickname is {nick $0}"; - kick = "%r:%K:: {channick $0} was %rkicked%K from {channel $1} by {nick $2} ({reason $3})"; - invite = "%K:%y:%K: {channick_hilight $0} %yinvites%K you to {channel $1}"; - not_invited = "You have not been invited to a channel!"; - new_topic = "%K:%y:%K: {channick_hilight $0} %ychanged the topic%K of {channel $1} to: {hilight $2}"; - topic_unset = "%K:%y:%K: {channick_hilight $0} %yunset the topic%K on {channel $1}"; - your_nick_changed = "%K:%y:%K: You're %ynow known as%K {channick_hilight $1}"; - talking_in = "%r:%y:%g:%K You are now talking in {channel $0}"; - not_in_channels = "%r:%y:%g:%K You are not on any channels"; - current_channel = "%r:%y:%g:%K Current channel {channel $0}"; - names = "{names_users Users {names_channel $0}} {comment $1 total}"; - names_prefix = "{names_prefix $0}"; - names_nick_op = "{names_nick_op $0 $1}"; - names_nick_halfop = "{names_nick_halfop $0 $1}"; - names_nick_voice = "{names_nick_voice $0 $1}"; - names_nick = "{names_nick $0 $1}"; - endofnames = "%r:%y:%g:%K {channel $0}: Total of {hilight $1} nicks {comment {hilight $2} ops, {hilight $3} halfops, {hilight $4} voices, {hilight $5} normal}"; - chanlist_header = "%r:%y:%g:%K You are on the following channels:"; - chanlist_line = "{channel $[-9]0} %|+$1 ($2): $3"; - chansetup_not_found = "Channel {channel $0} not found"; - chansetup_added = "Channel {channel $0} saved"; - chansetup_removed = "Channel {channel $0} removed"; - chansetup_header = "Channel Network Password Settings"; - chansetup_line = "{channel $[15]0} %|$[10]1 $[10]2 $3"; - chansetup_footer = ""; - channel_move_notify = "{channel $0} is already joined in window $1, use \"/WINDOW ITEM MOVE $0\" to move it to this window"; - # own_msg_private = "{ownprivmsg msg $0}$1"; - # own_msg_private_query = "{ownprivmsgnick {ownprivnick $[-9]2}}$1"; - # msg_private = "{privmsg $0 $1}$2"; - # msg_private_query = "{privmsgnick $[-9]0}$2"; - no_msgs_got = "%r:%y:%g:%K You have not received a message from anyone yet"; - no_msgs_sent = "%r:%y:%g:%K You have not sent a message to anyone yet"; - query_stop = "%r:%y:%g:%K Closing query with {nick $0}"; - no_query = "%r:%y:%g:%K No query with {nick $0}"; - query_server_changed = "%K:%y:%K: Query with {nick $0} %ychanged%K to server {server $1}"; - query_move_notify = "%r:%y:%g:%K Query with {nick $0} is already created to window $1, use \"/WINDOW ITEM MOVE $0\" to move it to this window"; - hilight_header = "%r:%y:%g:%K Highlights:"; - hilight_line = "$[-4]0 $1 $2 $3$4$5"; - hilight_footer = ""; - hilight_not_found = "%r:%K:: Highlight %rnot found%K: $0"; - hilight_removed = "%K::%g:%K Highlight %gremoved%K: $0"; - alias_added = "%K::%g:%K Alias $0 %gadded%K"; - alias_removed = "%K::%g:%K Alias $0 %gremoved%K"; - alias_not_found = "%r:%K:: %rNo such%K alias: $0"; - aliaslist_header = "%r:%y:%g:%K Aliases:"; - aliaslist_line = "$[10]0 $1"; - aliaslist_footer = ""; - log_opened = "%K::%g:%K Log file {hilight $0} %gopened%K"; - log_closed = "%K::%g:%K Log file {hilight $0} %gclosed%K"; - log_create_failed = "%r:%K:: %rCouldn't create%K log file {hilight $0}: $1"; - log_locked = "%r:%K:: Log file {hilight $0} is %rlocked%K, probably by another running Irssi"; - log_not_open = "%r:%K:: Log file {hilight $0} %rnot open%K"; - log_started = "%K::%g:%K %gStarted%K logging to file {hilight $0}"; - log_stopped = "%r:%K:: %rStopped%K logging to file {hilight $0}"; - log_list_header = "%r:%y:%g:%K Logs:"; - log_list = "$0 $1: $2 $3$4"; - log_list_footer = ""; - windowlog_file = "%K::%g:%K Window LOGFILE set to $0"; - windowlog_file_logging = "%r:%K:: %rCan't change%K window's logfile while log is on"; - no_away_msgs = "%r:%K:: %rNo new%K messages in awaylog"; - away_msgs = "%K::%g:%K {hilight $1} %gnew messages%K in awaylog:"; - module_header = "Module Type Submodules"; - module_line = "$[!20]0 $[7]1 $2"; - module_footer = ""; - module_already_loaded = "%r:%K:: Module {hilight $0/$1} already loaded"; - module_not_loaded = "%r:%K:: Module {hilight $0/$1} %ris not loaded%K"; - module_load_error = "%r:%K:: %rError%K loading module {hilight $0/$1}: $2"; - module_invalid = "%r:%K:: {hilight $0/$1} isn't Irssi module"; - module_loaded = "%K::%g:%K %gLoaded%K module {hilight $0/$1}"; - module_unloaded = "%r:%K:: %rUnloaded%K module {hilight $0/$1}"; - command_unknown = "%r:%K:: %rUnknown%K command: $0"; - command_ambiguous = "%r:%K:: %rAmbiguous%K command: $0"; - option_unknown = "%r:%K:: %rUnknown%K option: $0"; - option_ambiguous = "%r:%K:: %rAmbiguous%K option: $0"; - option_missing_arg = "%r:%K:: %rMissing%K required argument for: $0"; - not_enough_params = "%r:%K:: %rNot enough%K parameters given"; - not_connected = "%r:%K:: %rNot connected%K to server"; - not_joined = "%r:%K:: %rNot joined%K to any channel"; - chan_not_found = "%r:%K:: %rNot joined%K to such channel"; - chan_not_synced = "%r:%K:: Channel %rnot fully synchronized%K yet, try again after a while"; - illegal_proto = "%r:%K:: Command isn't designed for the chat protocol of the active server"; - not_good_idea = "%r:%K:: Doing this is %rnot a good idea%K. Add -YES if you really mean it"; - theme_saved = "%K::%g:%K Theme %gsaved%K to $0"; - theme_save_failed = "%r:%K:: %rError%K saving theme to $0: $1"; - theme_not_found = "%r:%K:: Theme {hilight $0} %rnot found%K"; - theme_changed = "%K:%y:%K: %yUsing%K now theme {hilight $0} ($1)"; - window_theme = "%K::%g:%K %gUsing%K theme {hilight $0} in this window"; - window_theme_default = "%r:%K:: %rNo theme is set%K for this window"; - window_theme_changed = "%K:%y:%K: %yUsing%K now theme {hilight $0} ($1) in this window"; - window_theme_removed = "%K::%g:%K %gRemoved%K theme from this window"; - format_title = "%:[{hilight $0}] - [{hilight $1}]%:"; - format_subtitle = "[{hilight $0}]"; - format_item = "$0 = $1"; - ignored = "%K::%g:%K %gIgnoring%K {hilight $1} from {nick $0}"; - unignored = "%K::%g:%K %gUnignored%K {nick $0}"; - ignore_not_found = "%K::%g:%K {nick $0} %gis not%K being ignored"; - ignore_no_ignores = "%r:%y:%g:%K There are no ignores"; - ignore_header = "%r:%y:%g:%K Ignorance List:"; - ignore_line = "$[-4]0 $1: $2 $3 $4"; - ignore_footer = ""; - unknown_chat_protocol = "%r:%K:: %rUnknown%K chat protocol: $0"; - unknown_chatnet = "%r:%K:: %rUnknown%K chat network: $0 (create it with /IRCNET ADD)"; - not_toggle = "%r:%K:: Value must be either ON, OFF or TOGGLE"; - perl_error = "%r:%K:: Perl %rerror%K: $0"; - bind_key = "$[!20]0 $1 $2"; - bind_unknown_id = "%r:%K:: %rUnknown%K bind action: $0"; - config_saved = "%K::%g:%K %gSaved%K configuration to file $0"; - config_reloaded = "%K::%g:%K %gReloaded%K configuration"; - config_modified = "%r:%y:%g:%K Configuration file was modified since irssi was last started - do you want to overwrite the possible changes?"; - glib_error = "{error GLib $0} $1"; - overwrite_config = "%r:%y:%g:%K Overwrite config (%gy%K/%rN%K)?"; - set_title = "[{hilight $0}]"; - set_item = "$0 = $1"; - set_unknown = "%r:%K:: %rUnknown%K setting $0"; - set_not_boolean = "%r:%K:: Setting {hilight $0} isn't boolean, use /SET"; - translation_not_found = "%r:%K:: %rError%K opening translation table file $0: $1"; - translation_file_error = "%r:%K:: %rError%K parsing translation table file $0"; - pubmsg = "{pubmsgnick $2 {pubnick \00306$[0]0}}$1"; - own_msg = "{ownmsgnick $2 {ownnick $[0]0}}$1"; - }; - "fe-common/irc/dcc" = { - dcc_list_header = "{line_start_irssi}{dcc DCC connections:}"; - dcc_list_footer = "{line_start_irssi}{dcc ];}"; - # own_dcc = "{dccownmsg dcc {dccownnick $1}}$2"; - # own_dcc_action = "{dccownaction_target $0 $1}$2"; - # own_dcc_action_query = "{dccownaction $0}$2"; - # own_dcc_ctcp = "{ownctcp ctcp $0}$1 $2"; - # dcc_msg = "{dccmsg dcc $0}$1"; - # action_dcc = "{dccaction $0}$1"; - # action_dcc_query = "{dccaction $0}$1"; - # own_dcc_query = "{ownmsgnick {dccownquerynick $0}}$2"; - # dcc_msg_query = "{privmsgnick $0}$1"; - dcc_ctcp = "%K::%g:%K {dcc >>> DCC CTCP {hilight $1} %greceived%K from {hilight $0}: $2}"; - dcc_chat = "%K::%g:%K {dcc DCC CHAT from {nick $0} [$1 port $2]}"; - dcc_chat_channel = "%K::%g:%K {dcc DCC CHAT from {nick $0} [$1 port $2] %grequested%K in channel {channel $3}}"; - dcc_chat_not_found = "%K::%g:%K {dcc No DCC CHAT %gconnection open%K to {nick $0}}"; - dcc_chat_connected = "%K::%g:%K {dcc DCC CHAT connection with {nick $0} [$1 port $2] %gestablished%K}"; - dcc_chat_disconnected = "%r:%K:: {dcc DCC %rlost chat%K to {nick $0}}"; - dcc_send = "%K::%g:%K {dcc DCC SEND from {nick $0} [$1 port $2]: $3 [$4 bytes]}"; - dcc_send_channel = "%K::%g:%K {dcc DCC SEND from {nick $0} [$1 port $2]: $3 [$4 bytes] %grequested%K in channel {channel $5}}"; - dcc_send_exists = "%r:%K:: {dcc DCC %ralready sending%K file {dccfile $0} for {nick $1}}"; - dcc_send_not_found = "%r:%K:: {dcc DCC %rnot sending%K file {dccfile $1} to {nick $0}}"; - dcc_send_file_open_error = "%r:%K:: {dcc DCC %rcan't open%K file {dccfile $0}: $1}"; - dcc_send_connected = "%K::%g:%K {dcc DCC %gsending%K file {dccfile $0} for {nick $1} [$2 port $3]}"; - dcc_send_complete = "%K::%g:%K {dcc DCC %gsent%K file {dccfile $0} [{hilight $1}kB] for {nick $2} in {hilight $3} secs [{hilight $4kB/s}]}"; - dcc_send_aborted = "%r:%K:: {dcc DCC %raborted%K sending file {dccfile $0} for {nick $1}}"; - dcc_get_not_found = "%r:%K:: {dcc DCC no file offered by {nick $0}}"; - dcc_get_connected = "%K::%g:%K {dcc DCC %greceiving%K file {dccfile $0} from {nick $1} [$2 port $3]}"; - dcc_get_complete = "%K::%g:%K {dcc DCC %greceived%K file {dccfile $0} [$1kB] from {nick $2} in {hilight $3} secs [$4kB/s]}"; - dcc_get_aborted = "%r:%K:: {dcc DCC %raborted%K receiving file {dccfile $0} from {nick $1}}"; - dcc_unknown_ctcp = "%r:%K:: {dcc DCC unknown ctcp {hilight $0} from {nick $1} [$2]}"; - dcc_unknown_reply = "%r:%K:: {dcc DCC unknown reply {hilight $0} from {nick $1} [$2]}"; - dcc_unknown_type = "%r:%K:: {dcc DCC unknown type {hilight $0}}"; - dcc_invalid_ctcp = "%r:%K:: {dcc DCC received CTCP {hilight $0} with %rinvalid%K parameters from {nick $1}}"; - dcc_connect_error = "%r:%K:: {dcc DCC %rcan't connect%K to {hilight $0} port {hilight $1}}"; - dcc_cant_create = "%r:%K:: {dcc DCC %rcan't create%K file {dccfile $0}}"; - dcc_rejected = "%r:%K:: {dcc DCC $0 was %rrejected%K by {nick $1} [{hilight $2}]}"; - dcc_request_send = "%K::%g:%K {dcc DCC $0 %grequest sent%K to {nick $1}: $2"; - dcc_close = "{dcc DCC $0 close for {nick $1} [{hilight $2}]}"; - dcc_lowport = "{dcc Warning: Port sent with DCC request is a lowport ({hilight $0, $1}) - this isn't normal. It is possible the address/port is faked (or maybe someone is just trying to bypass firewall)}"; - dcc_list_line_chat = "%WChat ->%n {dcc $0 $1}"; - dcc_list_line_file = "%WFile ->%n {dcc $0 $1 : $2k of $3k ($4%%) - $5kB/s - $6}"; - }; - "fe-text" = { - lastlog_too_long = "%r:%y:%g:%K /LASTLOG would print $0 lines. If you really want to print all these lines use -force option."; - lastlog_count = "{hilight Lastlog}: $0 lines"; - lastlog_start = "{hilight Lastlog}:"; - lastlog_end = "{hilight End of Lastlog}"; - refnum_not_found = "%r:%K::%K Window number $0 %rnot found%K"; - window_too_small = "%r:%K::%K %rNot enough room%K to resize this window"; - cant_hide_last = "%r:%K::%K You %rcan't hide%K the last window"; - cant_hide_sticky_windows = "%r:%K::%K You %rcan't hide%K sticky windows (use /WINDOW STICK OFF)"; - cant_show_sticky_windows = "%r:%K::%K You %rcan't show%K sticky windows (use /WINDOW STICK OFF)"; - window_not_sticky = "%r:%K::%K Window %ris not%K sticky"; - window_set_sticky = "%K::%g:%K Window %gset%K sticky"; - window_unset_sticky = "%K::%g:%K Window %gis not%K sticky anymore"; - window_info_sticky = "Sticky : $0"; - window_scroll = "%K::%g:%K Window scroll mode is now $0"; - window_scroll_unknown = "%r:%K:: %rUnknown%K scroll mode $0, must be ON, OFF or DEFAULT"; - }; - "fe-common/irc" = { - netsplit = "%r:%K:: %r{netsplit netsplit}%K %|{server $0} <-> {server $1} %rquits%K: $2"; - netsplit_more = "%r:%K:: %r{netsplit netsplit}%K %|{server $0} <-> {server $1} %rquits:%K $2 (+$3 more, use /NETSPLIT to show all of them)"; - netsplit_join = "%K::%g:%K %g{netjoin netsplit}%K - %|%gjoins:%K $0"; - netsplit_join_more = "%%K::%g:%K %g{netjoin netsplit}%K - %|over, %gjoins:%K $0 (+$1 more)"; - no_netsplits = "%r:%y:%g:%K There are no netsplits"; - netsplits_header = "Nick Channel Server Splitted server"; - netsplits_line = "$[9]0 $[10]1 $[20]2 $3"; - netsplits_footer = ""; - ircnet_added = "%K::%g:%K Ircnet $0 %gsaved%K"; - ircnet_removed = "%K::%g:%K Ircnet $0 %gremoved%K"; - ircnet_not_found = "%r:%K:: Ircnet $0 %rnot found%K"; - ircnet_header = "%r:%y:%g:%K Ircnets:"; - ircnet_line = "$0: $1"; - ircnet_footer = ""; - setupserver_header = "Server Port Network Settings"; - setupserver_line = "%|$[!20]0 $[5]1 $[10]2 $3"; - setupserver_footer = ""; - joinerror_toomany = "%r:%K:: Join %rfails%K: {channel $0} (You have joined to too many channels)"; - joinerror_full = "%r:%K:: Join %rfails%K: {channel $0} (Channel is full)"; - joinerror_invite = "%r:%K:: Join %rfails%K: {channel $0} (You must be invited)"; - joinerror_banned = "%r:%K:: Join %rfails%K: {channel $0} (You are banned)"; - joinerror_bad_key = "%r:%K:: Join %rfails%K: {channel $0} (Wrong channel key)"; - joinerror_bad_mask = "%r:%K:: Join %rfails%K: {channel $0} (Bad channel mask)"; - joinerror_unavail = "%r:%K:: Join %rfails%K: {channel $0} (Channel is temporarily unavailable)"; - joinerror_duplicate = "%r:%K:: Channel {channel $0} already exists - %rcannot create%K it"; - channel_rejoin = "%r:%K:: Channel {channel $0} is temporarily %runavailable%K. Setting up a rejoin, to not rejoin, use /rmrejoins."; - inviting = "%K::%g:%K %gInviting%K {nick $0} to {channel $1}"; - channel_created = "%r:%y:%g:%K Channel {channel $0} created %_$1%_"; - url = "%r:%y:%g:%K Home page for {channelhilight $0}: $1"; - topic = "%r:%y:%g:%K Topic for {channel $0}: %_$1%_"; - no_topic = "%r:%y:%g:%K No topic set for %_$0%_"; - topic_info = "%r:%y:%g:%K Topic set by {channick_hilight $0} {mode $1}"; - chanmode_change = "%K:%y:%K: %ymode%K/{channel $0} [{mode $1}] by {nick $2}"; - server_chanmode_change = "%K::%g: {netsplit ServerMode}%K/{channelhilight $0}: {mode $1} by {nick $2}"; - channel_mode = "%K:%y:%K: %ymode%K/{channelhilight $0} [{mode $1}]"; - bantype = "%K:%y:%K: Ban type %ychanged%K to {channel $0}"; - no_bans = "%r:%y:%g:%K No bans in channel {channel $0}"; - banlist = "$0 - {channel $1}: ban {ban $2}"; - banlist_long = "$0 - {channel $1}: ban {ban $2} {comment by {nick $3}, $4 secs ago}"; - ebanlist = "{channel $0}: ban exception {ban $1}"; - ebanlist_long = "{channel $0}: ban exception {ban $1} {comment by {nick $2}, $3 secs ago}"; - no_invitelist = "%r:%y:%g:%K Invite list is empty in channel {channel $0}"; - invitelist = "{channel $0}: invite {ban $1}"; - no_such_channel = "%r:%K::%K {channel $0}: %rNo such%K channel"; - channel_change = "%K:%y:%K: %ymode%K/{channel $0} [{mode $1}]"; - channel_synced = "%r:%y:%g:%K Join to {channel $0} was synced in {hilight $1} secs"; - usermode_change = "%K:%y:%K: %ymode%K/{channel $0} [{mode $0}] by {channick_hilight $1}"; - user_mode = "%r:%y:%g:%K Your user mode is {mode $0}"; - away = "%K::%g:%K You have been %gmarked%K as being away"; - unaway = "%K::%g:%K You are %gno longer marked%K as being away"; - nick_away = "%r:%K::%K {nick $0} is %raway%K: $1"; - no_such_nick = "%r:%K::%K {nick $0}: %rNo such%K nick/channel"; - nick_in_use = "%r:%K::%K Nick {nick $0} is %ralready in use%K"; - nick_unavailable = "%r:%K::%K Nick {nick $0} is temporarily %runavailable%K"; - your_nick_owned = "%r:%K::%K Your nick is %rowned%K by {nick $3} {comment $1@$2}"; - whois = "%K:%K:%g:%K %g%U{nick $0}%U%K ({nickhost $1@$2})%:%r:%y:%g:%K ircname: $3"; - whowas = "%r:%y:%g:%K {nick $0} {nickhost $1@$2}%:%r:%y:%g:%K {whois ircname $3}"; - whois_idle = "%r:%y:%g:%K Idle: %|since $1 days $2 hours $3 mins $4 secs"; - whois_idle_signon = "%r:%y:%g:%K Idle: %|since $1 days $2 hours $3 mins $4 secs {comment Signed on: $5}"; - whois_server = "%r:%y:%g:%K Server: %|$1 {comment $2}"; - whois_oper = "%r:%y:%g:%K Info: %|{hilight $1}"; - whois_registered = "%r:%y:%g:%K Info: %|has registered this nick"; - whois_help = "%r:%y:%g:%K Info: %|available for help"; - whois_modes = "%r:%y:%g:%K Modes: %|{mode $1}"; - whois_realhost = "%r:%y:%g:%K Hostname: %|{hilight $1-}"; - whois_usermode = "%r:%y:%g:%K Usermode: %|{mode $1}"; - whois_channels = "%r:%y:%g:%K Channels: %|{channel $1}"; - whois_away = "%r:%y:%g:%K Away: %|$1"; - whois_special = "%r:%y:%g:%K Info: %|$1"; - whois_extra = "%r:%y:%g:%K Info: %|$1"; - end_of_whois = "%r:%K::%K %rEnd%K of WHOIS%K"; - end_of_whowas = "%r:%y:%g:%K End of WHOWAS"; - whois_not_found = "%r:%K::%K There is %rno such%K nick {channick_hilight $0}"; - who = "{channelhilight $[-10]0} %|{nick $[!9]1} $[!3]2 $[!2]3 $4@$5 {comment {hilight $6}}"; - end_of_who = "%r:%y:%g:%K End of /WHO list"; - own_notice = "{ownnotice notice $0}$1"; - # own_action = "{nick $[-11]0}%n $1"; - # own_action_target = "{ownaction_target $0 $2}$1"; - own_ctcp = "{ownctcp ctcp $0}$1 $2"; - notice_server = "{servernotice $0}$1"; - notice_public = "{notice $0{pubnotice_channel $1}}$2"; - notice_private = "{notice $0{pvtnotice_host $1}}$2"; - # action_private = "{pvtaction $0}$2"; - # action_private_query = "{pvtaction_query $0}$2"; - # action_public = " {nick $[-11]0}%n $1"; - # action_public_channel = "{pubaction $0{msgchannel $1}}$2"; - ctcp_reply = "%K::%g:%K %gCTCP%K {hilight $0} reply from {channick_hilight $1}: $2"; - ctcp_reply_channel = "%K::%g:%K %gCTCP {hilight $0} reply%K from {channick_hilight $1} in channel {channel $3}: $2"; - ctcp_ping_reply = "%K::%g:%K %gCTCP {hilight PING} reply%K from {channick_hilight $0}: $1.$[-3.0]2 seconds"; - ctcp_requested = "%K::%g:%K %K{ctcp {hilight $0} {comment $1} %grequested%K {hilight $2} from {nick $3}}"; - ctcp_requested_unknown = ""; - online = "%r:%y:%g:%K Users online: {hilight $0}"; - pong = "%K::%g:%K PONG %greceived%K from $0: $1"; - wallops = "{wallop WALLOP {wallop_nick $0}} $1"; - action_wallops = "{wallop WALLOP {wallop_action $0}} $1"; - kill = "%r:%K:: You were %r{error killed}%K by {nick $0} {nickhost $1} {reason $2} {comment Path: $3}"; - kill_server = "%r:%K:: You were %r{error killed}%K by {server $0} {reason $1} {comment Path: $2}"; - error = "%r:%K:: %r{error ERROR}%K $0"; - unknown_mode = "%r:%K:: %rUnknown%K mode character $0"; - not_chanop = "%r:%K:: You're %rnot channel operator%K in {channel $0}"; - silenced = "%K::%g:%K %gSilenced%K {nick $0}"; - unsilenced = "%K::%g:%K %gUnsilenced%K {nick $0}"; - silence_line = "{nick $0}: silence {ban $1}"; - ask_oper_pass = "%r:%y:%g:%K Operator password:"; - }; - "fe-common/perl" = { - script_not_found = "%r:%K:: Script {hilight $0} %rnot found%K"; - script_not_loaded = "%r:%K:: Script {hilight $0} %ris not%K loaded"; - script_loaded = "%K::%g:%K %gLoaded%K script {hilight $0}"; - script_unloaded = "%r:%K:: %rUnloaded%K script {hilight $0}"; - no_scripts_loaded = "%r:%y:%g:%K No scripts are loaded"; - script_list_header = "%r:%y:%g:%K Loaded scripts:"; - script_list_line = "$[!15]0 $1"; - script_list_footer = ""; - script_error = "{error %r:%K:: %rError%K in script {hilight $0}:}"; - }; - # "fe-common/irc/notifylist" = { - # notify_join = "{nick $0} [$1@$2] [{hilight $3}] has joined to $4"; - # notify_part = "{nick $0} has left $4"; - # notify_away = "{nick $0} [$5] [$1@$2] [{hilight $3}] is now away: $4"; - # notify_unaway = "{nick $0} [$4] [$1@$2] [{hilight $3}] is now unaway"; - # notify_unidle = "{nick $0} [$5] [$1@$2] [{hilight $3}] just stopped idling"; - # notify_online = "On $0: {hilight $1}"; - # notify_offline = "Offline: $0"; - # notify_list = "$0: $1 $2 $3"; - # notify_list_empty = "The notify list is empty"; - # }; - "Irssi::Script::adv_windowlist" = { - awl_display_key = "$N${cumode_space}$H$C$S"; - }; -}; - diff --git a/.irssi/scripts/adv_windowlist.pl b/.irssi/scripts/adv_windowlist.pl deleted file mode 100644 index 91afa1c..0000000 --- a/.irssi/scripts/adv_windowlist.pl +++ /dev/null @@ -1,2555 +0,0 @@ -use strict; -use warnings; - -our $VERSION = '1.5'; # 5df597ac461465e -our %IRSSI = ( - authors => 'Nei', - contact => 'Nei @ anti@conference.jabber.teamidiot.de', - url => "http://anti.teamidiot.de/", - name => 'adv_windowlist', - description => 'Adds a permanent advanced window list on the right or in a status bar.', - sbitems => 'awl_shared', - license => 'GNU GPLv2 or later', - ); - -# UPGRADE NOTE -# ============ -# for users of 0.7 or earlier series, please note that appearance -# settings have moved to /format, i.e. inside your theme! -# the fifo (screen) has been replaced by an external viewer script - -# Usage -# ===== -# copy the script to ~/.irssi/scripts/ -# -# In irssi: -# -# /run adv_windowlist -# -# In your shell (for example a tmux split): -# -# perl ~/.irssi/scripts/adv_windowlist.pl -# -# To use sbar mode instead: -# -# /toggle awl_viewer -# -# Hint: to get rid of the old [Act:] display -# /statusbar window remove act -# -# to get it back: -# /statusbar window add -after lag -priority 10 act - -# Options -# ======= -# formats can be cleared with /format -delete -# -# /format awl_display_(no)key(_active|_visible) <string> -# * string : Format String for one window. The following $'s are expanded: -# $C : Name -# $N : Number of the Window -# $Q : meta-Keymap -# $H : Start hilighting -# $S : Stop hilighting -# /+++++++++++++++++++++++++++++++++, -# | **** I M P O R T A N T : **** | -# | | -# | don't forget to use $S if you | -# | used $H before! | -# | | -# '+++++++++++++++++++++++++++++++++/ -# key : a key binding that goes to this window could be detected in /bind -# nokey : no such key binding was detected -# active : window would receive the input you are currently typing -# visible : window is also visible on screen but not active (a split window) -# -# /format awl_name_display <string> -# * string : Format String for window names -# $0 : name as formatted by the settings -# -# /format awl_display_header <string> -# * string : Format String for this header line. The following $'s are expanded: -# $C : network tag -# -# /format awl_separator(2) <string> -# * string : Character to use between the channel entries -# variant 2 can be used for alternating separators (only in status bar -# without block display) -# -# /format awl_abbrev_chars <string> -# * string : Character to use when shortening long names. The second character -# will be used if two blocks need to be filled. -# -# /format awl_title <string> -# * string : Text to display in the title string or title bar -# -# /format awl_viewer_item_bg <string> -# * string : Format String specifying the viewer's item background colour -# -# /set awl_prefer_name <ON|OFF> -# * this setting decides whether awl will use the active_name (OFF) or the -# window name as the name/caption in awl_display_*. -# That way you can rename windows using /window name myownname. -# -# /set awl_hide_empty <num> -# * if visible windows without items should be hidden from the window list -# set it to 0 to show all windows -# 1 to hide visible windows without items (negative exempt -# active window) -# -# /set awl_hide_data <num> -# * num : hide the window if its data_level is below num -# set it to 0 to basically disable this feature, -# 1 if you don't want windows without activity to be shown -# 2 to show only those windows with channel text or hilight -# 3 to show only windows with hilight (negative exempt active window) -# -# /set awl_hide_name_data <num> -# * num : hide the name of the window if its data_level is below num -# (only works in status bar without block display) -# you will want to change your formats to add $H...$S around $Q or $N -# if you plan to use this -# -# /set awl_maxlines <num> -# * num : number of lines to use for the window list (0 to disable, negative -# lock) -# -# /set awl_maxcolumns <num> -# * num : number of columns to use for the window list when using the -# tmux integration (0 to disable) -# -# /set awl_block <num> -# * num : width of a column in viewer mode (negative values = block -# display in status bar mode) -# /+++++++++++++++++++++++++++++++++, -# | ****** W A R N I N G ! ****** | -# | | -# | If your block display looks | -# | DISTORTED, you need to add the | -# | following line to your .theme | -# | file under | -# | abstracts = { : | -# | | -# | sb_act_none = "%K$*"; | -# | | -# '+++++++++++++++++++++++++++++++++/ -# -# /set awl_sbar_maxlength <ON|OFF> -# * if you enable the maxlength setting, the block width will be used as a -# maximum length for the non-block status bar mode too. -# -# /set awl_height_adjust <num> -# * num : how many lines to leave empty in viewer mode -# -# /set awl_sort <-data_level|-last_line|refnum> -# * you can change the window sort order with this variable -# -data_level : sort windows with hilight first -# -last_line : sort windows in order of activity -# refnum : sort windows by window number -# active/server/tag : sort by server name -# "-" reverses the sort order -# typechecks are supported via ::, e.g. active::Query or active::Irc::Query -# undefinedness can be checked with ~, e.g. ~active -# string comparison can be done with =, e.g. name=(status) -# to make sort case insensitive, use #i, e.g. name#i -# any key in the window hash can be tested, e.g. active/chat_type=XMPP -# multiple criteria can be separated with , or +, e.g. -data_level+-last_line -# -# /set awl_placement <top|bottom> -# /set awl_position <num> -# * these settings correspond to /statusbar because awl will create -# status bars for you -# (see /help statusbar to learn more) -# -# /set awl_all_disable <ON|OFF> -# * if you set awl_all_disable to ON, awl will also remove the -# last status bar it created if it is empty. -# As you might guess, this only makes sense with awl_hide_data > 0 ;) -# -# /set awl_viewer <ON|OFF> -# * enable the external viewer script -# -# /set awl_viewer_launch <ON|OFF> -# * try to auto-launch the viewer under tmux or with a shell command -# /awl restart is required all auto-launch related settings to take -# effect -# -# /set awl_viewer_tmux_position <left|top|right|bottom|custom> -# * try to split in this direction when using tmux for the viewer -# custom : use custom_command setting -# -# /set awl_viewer_xwin_command <shell command> -# * custom command to run in order to start the viewer when irssi is -# running under X -# %A - gets replaced by the command to run the viewer -# %qA - additionally quote the command -# -# /set awl_viewer_custom_command <shell command> -# * custom command to run in order to start the viewer -# -# /set awl_viewer_launch_env <string> -# * specific environment settings for use on viewer auto-launch, -# without the AWL_ prefix -# -# /set awl_shared_sbar <left<right|OFF> -# * share a status bar for the first awl item, you will need to manually -# /statusbar window add -after lag -priority 10 awl_shared -# left : space in cells occupied on the left of status bar -# right : space occupied on the right -# Note: you need to replace "left" AND "right" with the appropriate numbers! -# -# /set awl_path <path> -# * path to the file which the viewer script reads -# -# /set fancy_abbrev <no|head|strict|fancy> -# * how to shorten too long names -# no : shorten in the middle -# head : always cut off the ends -# strict : shorten repeating substrings -# fancy : combination of no+strict -# -# /set awl_custom_xform <perl code> -# * specify a custom routine to transform window names -# example: s/^#// remove the #-mark of IRC channels -# the special flags $CHANNEL / $TAG / $QUERY / $NAME can be -# tested in conditionals -# -# /set awl_last_line_shade <timeout> -# * set timeout to shade activity base colours, to enable -# you also need to add +-last_line to awl_sort -# (requires 256 colour support) -# -# /set awl_no_mode_hint <ON|OFF> -# * whether to show the hint of running the viewer script in the -# status bar -# -# /set awl_mouse <ON|OFF> -# * enable the terminal mouse in irssi -# (use the awl-patched mouse.pl for gestures and commands if you need -# them and disable mouse_escape) -# -# /set awl_mouse_offset <num> -# * specifies where on the screen is the awl status bar -# (0 = on top/bottom, 1 = one additional line in between, -# e.g. prompt) -# you MUST set this correctly otherwise the mouse coordinates will -# be off -# -# /set mouse_scroll <num> -# * how many lines the mouse wheel scrolls -# -# /set mouse_escape <num> -# * seconds to disable the mouse, when not clicked on the windowlist -# - -# Commands -# ======== -# /awl redraw -# * redraws the windowlist. There may be occasions where the -# windowlist can get destroyed so you can use this command to -# force a redraw. -# -# /awl restart -# * restart the connection to the viewer script. - -# Viewer script -# ============= -# When run from the command line, adv_windowlist acts as the viewer -# script to be used together with the irssi script to display the -# window list in a sidebar/terminal of its own. -# -# One optional parameter is accepted, the awl_path -# -# The viewer can be configured by three environment variables: -# -# AWL_HI9=1 -# * interpret %9 as high-intensity toggle instead of bold. This had -# been the default prior to version 0.9b8 -# -# AWL_AUTOFOCUS=0 -# * disable auto-focus behaviour when activating a window -# -# AWL_NOTITLE=1 -# * disable the title bar - -# Nei =^.^= ( anti@conference.jabber.teamidiot.de ) - -no warnings 'redefine'; -use constant IN_IRSSI => __PACKAGE__ ne 'main' || $ENV{IRSSI_MOCK}; -use constant SCRIPT_FILE => __FILE__; -no if !IN_IRSSI, strict => (qw(subs refs)); -use if IN_IRSSI, Irssi => (); -use if IN_IRSSI, 'Irssi::TextUI' => (); -use v5.10; -use Encode; -use Storable (); -use IO::Socket::UNIX; -use List::Util qw(min max reduce); -use Hash::Util qw(lock_keys); -use Text::ParseWords qw(shellwords); - -BEGIN { - if ($] < 5.012) { - *CORE::GLOBAL::length = *CORE::GLOBAL::length = sub (_) { - defined $_[0] ? CORE::length($_[0]) : undef - }; - *Irssi::active_win = {}; # hide incorrect warning - } -} - -unless (IN_IRSSI) { - local *_ = \@ARGV; - &AwlViewer::main; - exit; -} - - -use constant GLOB_QUEUE_TIMER => 100; - -our $BLOCK_ALL; # localized blocker -my @actString; # status bar texts -my @win_items; -my $currentLines = 0; -my %awins; -my $globTime; # timer to limit remake calls - -my %CHANGED; -my $VIEWER_MODE; -my $MOUSE_ON; -my %mouse_coords; -my %statusbars; -my %S; # settings -my $settings_str = ''; -my $window_sort_func; -my $custom_xform; -my ($sb_base_width, $sb_base_width_pre, $sb_base_width_post); -my $print_text_activity; -my $shade_line_timer; -my ($screenHeight, $screenWidth); -my %viewer; - -my (%keymap, %nummap, %wnmap, %specialmap, %wnmap_exp, %custom_key_map); -my %banned_channels; -my %abbrev_cache; - -use constant setc => 'awl'; - -sub set ($) { - setc . '_' . $_[0] -} - -sub add_statusbar { - for (@_) { - # add subs - my $l = set $_; - { - my $close = $_; - no strict 'refs'; - *{$l} = sub { awl($close, @_) }; - } - Irssi::command("statusbar $l reset"); - Irssi::command("statusbar $l enable"); - if (lc $S{placement} eq 'top') { - Irssi::command("statusbar $l placement top"); - } - if (my $x = $S{position}) { - Irssi::command("statusbar $l position $x"); - } - Irssi::command("statusbar $l add -priority 100 -alignment left barstart"); - Irssi::command("statusbar $l add $l"); - Irssi::command("statusbar $l add -priority 100 -alignment right barend"); - Irssi::command("statusbar $l disable"); - Irssi::statusbar_item_register($l, '$0', $l); - $statusbars{$_} = 1; - Irssi::command("statusbar $l enable"); - } -} - -sub remove_statusbar { - for (@_) { - my $l = set $_; - Irssi::command("statusbar $l disable"); - Irssi::command("statusbar $l reset"); - Irssi::statusbar_item_unregister($l); - { - no strict 'refs'; - undef &{$l}; - } - delete $statusbars{$_}; - } -} - -my $awl_shared_empty = sub { - return if $BLOCK_ALL; - my ($item, $get_size_only) = @_; - $item->default_handler($get_size_only, '', '', 0); -}; - -sub syncLines { - my $maxLines = $S{maxlines}; - my $newLines = ($maxLines > 0 and @actString > $maxLines) ? - $maxLines : - ($maxLines < 0) ? - -$maxLines : - @actString; - $currentLines = 1 if !$currentLines && $S{shared_sbar}; - if ($S{shared_sbar} && !$statusbars{shared}) { - my $l = set 'shared'; - { - no strict 'refs'; - *{$l} = sub { - return if $BLOCK_ALL; - my ($item, $get_size_only) = @_; - - my $text = $actString[0]; - my $title = _get_format(set 'title'); - if (length $title) { - $title =~ s{\\(.)|(.)}{ - defined $2 ? quotemeta $2 - : $1 eq 'V' ? '\u' - : $1 eq ':' ? quotemeta ':%n' - : $1 =~ /^[uUFQE]$/ ? "\\$1" - : quotemeta "\\$1" - }sge; - $title = eval qq{"$title"}; - $title .= ' '; - } - my $pat = defined $text ? "{sb $title\$*}" : '{sb }'; - $text //= ''; - $item->default_handler($get_size_only, $pat, $text, 0); - }; - } - $statusbars{shared} = 1; - remove_statusbar (0) if $statusbars{0}; - } - elsif ($statusbars{shared} && !$S{shared_sbar}) { - add_statusbar (0) if $currentLines && $newLines; - delete $statusbars{shared}; - my $l = set 'shared'; - { - no strict 'refs'; - *{$l} = $awl_shared_empty; - } - } - if ($currentLines == $newLines) { return; } - elsif ($newLines > $currentLines) { - add_statusbar ($currentLines .. ($newLines - 1)); - } - else { - remove_statusbar (reverse ($newLines .. ($currentLines - 1))); - } - $currentLines = $newLines; -} - -sub awl { - return if $BLOCK_ALL; - my ($line, $item, $get_size_only) = @_; - - my $text = $actString[$line]; - my $pat = defined $text ? '{sb $*}' : '{sb }'; - $text //= ''; - $item->default_handler($get_size_only, $pat, $text, 0); -} - -# remove old statusbars -{ my %killBar; - sub get_old_status { - my ($textDest, $cont, $cont_stripped) = @_; - if ($textDest->{level} == 524288 and $textDest->{target} eq '' and !defined $textDest->{server}) { - my $name = quotemeta(set ''); - if ($cont_stripped =~ m/^$name(\d+)\s/) { $killBar{$1} = 1; } - Irssi::signal_stop; - } - } - sub killOldStatus { - %killBar = (); - Irssi::signal_add_first('print text' => 'get_old_status'); - Irssi::command('statusbar'); - Irssi::signal_remove('print text' => 'get_old_status'); - remove_statusbar(keys %killBar); - } -} - -sub _add_map { - my ($type, $target, $map) = @_; - ($type->{$target}) = sort { length $a <=> length $b || $a cmp $b } - $map, exists $type->{$target} ? $type->{$target} : (); -} - -sub get_keymap { - my ($textDest, undef, $cont_stripped) = @_; - if ($textDest->{level} == 524288 and $textDest->{target} eq '' and !defined $textDest->{server}) { - my $one_meta_or_ctrl_key = qr/((?:meta-)*?)(?:(meta-|\^)(\S)|(\w+))/; - $cont_stripped = as_uni($cont_stripped); - if ($cont_stripped =~ m/((?:$one_meta_or_ctrl_key-)*$one_meta_or_ctrl_key)\s+(.*)$/) { - my ($combo, $command) = ($1, $10); - my $map = ''; - while ($combo =~ s/(?:-|^)$one_meta_or_ctrl_key$//) { - my ($level, $ctl, $key, $nkey) = ($1, $2, $3, $4); - my $numlevel = ($level =~ y/-//); - $ctl = '' if !$ctl || $ctl ne '^'; - $map = ('-' x ($numlevel%2)) . ('+' x ($numlevel/2)) . - $ctl . (defined $key ? $key : "\01$nkey\01") . $map; - } - for ($command) { - last unless length $map; - if (/^change_window (\d+)/i) { - _add_map(\%nummap, $1, $map); - } - elsif (/^(?:command window goto|change_window) (\S+)/i) { - my $window = $1; - if ($window !~ /\D/) { - _add_map(\%nummap, $window, $map); - } - elsif (lc $window eq 'active') { - _add_map(\%specialmap, '_active', $map); - } - else { - _add_map(\%wnmap, $window, $map); - } - } - elsif (/^(?:active_window|command (ack))/i) { - _add_map(\%specialmap, '_active', $map); - $viewer{use_ack} = !!$1; - } - elsif (/^command window last/i) { - _add_map(\%specialmap, '_last', $map); - } - elsif (/^(?:upper_window|command window up)/i) { - _add_map(\%specialmap, '_up', $map); - } - elsif (/^(?:lower_window|command window down)/i) { - _add_map(\%specialmap, '_down', $map); - } - elsif (/^key\s+(\w+)/i) { - $custom_key_map{$1} = $map; - } - } - } - Irssi::signal_stop; - } -} - -sub update_keymap { - %nummap = %wnmap = %specialmap = %custom_key_map = (); - Irssi::signal_remove('command bind' => 'watch_keymap'); - Irssi::signal_add_first('print text' => 'get_keymap'); - Irssi::command('bind'); - Irssi::signal_remove('print text' => 'get_keymap'); - for (keys %custom_key_map) { - if (exists $custom_key_map{$_} && - $custom_key_map{$_} =~ s/\01(\w+)\01/exists $custom_key_map{$1} ? $custom_key_map{$1} : "\02"/ge) { - if ($custom_key_map{$_} =~ /\02/) { - delete $custom_key_map{$_}; - } - else { - redo; - } - } - } - for my $keymap (\(%specialmap, %wnmap, %nummap)) { - for (keys %$keymap) { - if ($keymap->{$_} =~ s/\01(\w+)\01/exists $custom_key_map{$1} ? $custom_key_map{$1} : "\02"/ge) { - if ($keymap->{$_} =~ /\02/) { - delete $keymap->{$_}; - } - } - } - } - Irssi::signal_add('command bind' => 'watch_keymap'); - delete $viewer{client_keymap}; - &wl_changed; -} - -# watch keymap changes -sub watch_keymap { - Irssi::timeout_add_once(1000, 'update_keymap', undef); -} - -{ my %strip_table = ( - # fe-common::core::formats.c:format_expand_styles - # delete format_backs format_fores bold_fores other stuff - (map { $_ => '' } (split //, '04261537' . 'kbgcrmyw' . 'KBGCRMYW' . 'U9_8I:|FnN>#[' . 'pP')), - # escape - (map { $_ => $_ } (split //, '{}%')), - ); - sub ir_strip_codes { # strip %codes - my $o = shift; - $o =~ s/(%(%|Z.{6}|z.{6}|X..|x..|.))/exists $strip_table{$2} ? $strip_table{$2} : - $2 =~ m{x(?:0[a-f]|[1-6][0-9a-z]|7[a-x])|z[0-9a-f]{6}}i ? '' : $1/gex; - $o - } -} -## ir_parse_special -- wrapper around parse_special -## $i - input format -## $args - array ref of arguments to format -## $win - different target window (default current window) -## $flags - different kind of escape flags (default 4|8) -## returns formatted str -sub ir_parse_special { - my $o; - my $i = shift; - my $args = shift // []; - y/ /\177/ for @$args; # hack to escape spaces - my $win = shift || Irssi::active_win; - my $flags = shift // 0x4|0x8; - my @cmd_args = ($i, (join ' ', @$args), $flags); - my $server = Irssi::active_server(); - if (ref $win and ref $win->{active}) { - $o = $win->{active}->parse_special(@cmd_args); - } - elsif (ref $win and ref $win->{active_server}) { - $o = $win->{active_server}->parse_special(@cmd_args); - } - elsif (ref $server) { - $o = $server->parse_special(@cmd_args); - } - else { - $o = &Irssi::parse_special(@cmd_args); - } - $o =~ y/\177/ /; - $o -} - -sub sb_format_expand { # Irssi::current_theme->format_expand wrapper - Irssi::current_theme->format_expand( - $_[0], - ( - Irssi::EXPAND_FLAG_IGNORE_REPLACES - | - ($_[1] ? 0 : Irssi::EXPAND_FLAG_IGNORE_EMPTY) - ) - ) -} - -{ my $term_type = Irssi::version > 20040819 ? 'term_charset' : 'term_type'; - local $@; - eval { require Text::CharWidth; }; - unless ($@) { - *screen_length = sub { Text::CharWidth::mbswidth($_[0]) }; - } - else { - my $err = $@; chomp $err; $err =~ s/\sat .* line \d+\.$//; - #Irssi::print("%_$IRSSI{name}: warning:%_ Text::CharWidth module failed to load. Length calculation may be off! Error was:"); - print "%_$IRSSI{name}:%_ $err"; - *screen_length = sub { - my $temp = shift; - if (lc Irssi::settings_get_str($term_type) eq 'utf-8') { - Encode::_utf8_on($temp); - } - length($temp) - }; - } - sub as_uni { - no warnings 'utf8'; - Encode::decode(Irssi::settings_get_str($term_type), $_[0], 0) - } - sub as_tc { - Encode::encode(Irssi::settings_get_str($term_type), $_[0], 0) - } -} - -sub sb_length { - screen_length(ir_strip_codes($_[0])) -} - -sub run_custom_xform { - local $@; - eval { - $custom_xform->() - }; - if ($@) { - $@ =~ /^(.*)/; - print '%_'.(set 'custom_xform').'%_ died (disabling): '.$1; - $custom_xform = undef; - } -} - -sub remove_uniform { - my $o = shift; - $o =~ s/^xmpp:(.*?[%@]).+\.[^.]+$/$1/ or - $o =~ s#^psyc://.+\.[^.]+/([@~].*)$#$1#; - if ($custom_xform) { - run_custom_xform() for $o; - } - $o -} - -sub remove_uniform_vars { - my $win = shift; - my $name = __PACKAGE__ . '::custom_xform::' . $win->{active}{type} - if ref $win->{active} && $win->{active}{type}; - no strict 'refs'; - local ${$name} = 1 if $name; - remove_uniform(+shift); -} - -sub lc1459 { - my $x = shift; - $x =~ y/][\\^/}{|~/; - lc $x -} - -sub window_list { - sort $window_sort_func Irssi::windows; -} - -sub _calculate_abbrev { - my ($wins, $abbrevList) = @_; - if ($S{fancy_abbrev} !~ /^(no|off|head)/i) { - my @nameList = map { ref $_ ? remove_uniform_vars($_, as_uni($_->get_active_name) // '') : '' } @$wins; - for (my $i = 0; $i < @nameList - 1; ++$i) { - my ($x, $y) = ($nameList[$i], $nameList[$i + 1]); - s/^[+#!=]// for $x, $y; - my $res = exists $abbrev_cache{$x}{$y} ? $abbrev_cache{$x}{$y} - : $abbrev_cache{$x}{$y} = string_LCSS($x, $y); - if (defined $res) { - for ($nameList[$i], $nameList[$i + 1]) { - $abbrevList->{$_} //= int((index $_, $res) + (length $res) / 2); - } - } - } - } -} - -my %act_last_line_shades = ( - r => [qw[ 50 40 30 20 ]], - g => [qw[ 1O 1I 1C 16 ]], - y => [qw[ 5O 4I 3C 26 ]], - b => [qw[ 15 14 13 12 ]], - m => [qw[ 54 43 32 21 ]], - c => [qw[ 1S 1L 1E 17 ]], - w => [qw[ 7W 7T 7Q 3E ]], - K => [qw[ 7M 7K 27 7H ]], - R => [qw[ 60 50 40 30 ]], - G => [qw[ 1U 1O 1I 1C ]], - Y => [qw[ 6U 5O 4I 3C ]], - B => [qw[ 2B 2A 29 28 ]], - M => [qw[ 65 54 43 32 ]], - C => [qw[ 1Z 1S 1L 1E ]], - W => [qw[ 6Z 5S 7R 7O ]], - ); - -sub _format_display { - my (undef, $format, $cformat, $hilight, $name, $number, $key, $win) = @_; - if ($print_text_activity && $S{line_shade}) { - my @hilight_code = split /\177/, sb_format_expand("{$hilight \177}"), 2; - my $max_time = max(1, log($S{line_shade}) - log(1000)); - my $time_delta = min(3, min($max_time, log(max(1, time - $win->{last_line}))) / $max_time * 3); - if ($hilight_code[0] =~ /%(.)/ && exists $act_last_line_shades{$1}) { - $hilight = 'sb_act_hilight_color %X'.$act_last_line_shades{$1}[$time_delta]; - } - } - $cformat = '$0' unless length $cformat; - my %map = ('$C' => $cformat, '$N' => '$1', '$Q' => '$2'); - $format =~ s<(\$.)><$map{$1}//$1>ge; - $format =~ s<\$H((?:\$.|[^\$])*?)\$S><{$hilight $1%n}>g; - my @ret = ir_parse_special(sb_format_expand($format), [$name, $number, $key], $win); - @ret -} - -sub _get_format { - Irssi::current_theme->get_format(__PACKAGE__, @_) -} - -sub _calculate_items { - my ($wins, $abbrevList) = @_; - - my $display_header = _get_format(set 'display_header'); - my $name_format = _get_format(set 'name_display'); - my $abbrev_chars = as_uni(_get_format(set 'abbrev_chars')); - - my %displays; - - my $active = Irssi::active_win; - @win_items = (); - %keymap = (%nummap, %wnmap_exp); - - my ($numPad, $keyPad) = (0, 0); - if ($VIEWER_MODE or $S{block} < 0) { - $numPad = length((sort { length $b <=> length $a } keys %keymap)[0]) // 0; - $keyPad = length((sort { length $b <=> length $a } values %keymap)[0]) // 0; - } - my $last_net; - my ($abbrev1, $abbrev2) = $abbrev_chars =~ /(\X)(.*)/; - my @abbrev_chars = ('~', "\x{301c}"); - unless (defined $abbrev1 && screen_length(as_tc($abbrev1)) == 1) { $abbrev1 = $abbrev_chars[0] } - unless (length $abbrev2) { - $abbrev2 = $abbrev1; - if ($abbrev1 eq $abbrev_chars[0]) { - $abbrev2 = $abbrev_chars[1]; - } - else { - $abbrev2 = $abbrev1; - } - } - if (screen_length(as_tc($abbrev2)) == 1) { - $abbrev2 x= 2; - } - while (screen_length(as_tc($abbrev2)) > 2) { - chop $abbrev2; - } - unless (screen_length(as_tc($abbrev2)) == 2) { - $abbrev2 = $abbrev_chars[1]; - } - for my $win (@$wins) { - my $global_tag_header_mode; - - next unless ref $win; - - my $backup_win = Storable::dclone($win); - delete $backup_win->{active} unless ref $backup_win->{active}; - - $global_tag_header_mode = - $display_header && ($last_net // '') ne ($backup_win->{active}{server}{tag} // ''); - - if ($win->{data_level} < abs $S{hide_data} - && ($win->{refnum} != $active->{refnum} || 0 <= $S{hide_data})) { - next; } - elsif (exists $awins{$win->{refnum}} && $S{hide_empty} && !$win->items - && ($win->{refnum} != $active->{refnum} || 0 <= $S{hide_empty})) { - next; } - - my $colour = $win->{hilight_color} // ''; - my $hilight = do { - if ($win->{data_level} == 0) { 'sb_act_none'; } - elsif ($win->{data_level} == 1) { 'sb_act_text'; } - elsif ($win->{data_level} == 2) { 'sb_act_msg'; } - elsif ($colour ne '') { "sb_act_hilight_color $colour"; } - elsif ($win->{data_level} == 3) { 'sb_act_hilight'; } - else { 'sb_act_special'; } - }; - my $number = $win->{refnum}; - - my ($name, $display, $cdisplay); - if ($global_tag_header_mode) { - $display = $display_header; - $name = as_uni($backup_win->{active}{server}{tag}) // ''; - if ($custom_xform) { - no strict 'refs'; - local ${ __PACKAGE__ . '::custom_xform::TAG' } = 1; - run_custom_xform() for $name; - } - } - else { - my @display = ('display_nokey'); - if (defined $keymap{$number} and $keymap{$number} ne '') { - unshift @display, map { (my $cpy = $_) =~ s/_no/_/; $cpy } @display; - } - if (exists $awins{$number}) { - unshift @display, map { my $cpy = $_; $cpy .= '_visible'; $cpy } @display; - } - if ($active->{refnum} == $number) { - unshift @display, map { my $cpy = $_; $cpy .= '_active'; $cpy } - grep { !/_visible$/ } @display; - } - $display = (grep { length $_ } - map { $displays{$_} //= _get_format(set $_) } - @display)[0]; - $cdisplay = $name_format; - $name = as_uni($win->get_active_name) // ''; - $name = '*' if $S{banned_on} and exists $banned_channels{lc1459($name)}; - $name = remove_uniform_vars($win, $name) if $name ne '*'; - if ($name ne '*' and $win->{name} ne '' and $S{prefer_name}) { - $name = as_uni($win->{name}); - if ($custom_xform) { - no strict 'refs'; - local ${ __PACKAGE__ . '::custom_xform::NAME' } = 1; - run_custom_xform() for $name; - } - } - - if (!$VIEWER_MODE && $S{block} >= 0 && $S{hide_name} - && $win->{data_level} < abs $S{hide_name} - && ($win->{refnum} != $active->{refnum} || 0 <= $S{hide_name})) { - $name = ''; - $cdisplay = ''; - } - } - - $display = "$display%n"; - my $num_ent = (' 'x max(0,$numPad - length $number)) . $number; - my $key_ent = exists $keymap{$number} ? ((' 'x max(0,$keyPad - length $keymap{$number})) . $keymap{$number}) : ' 'x$keyPad; - if ($VIEWER_MODE or $S{sbar_maxlen} or $S{block} < 0) { - my $baseLength = sb_length(_format_display( - '', $display, $cdisplay, $hilight, - 'x', # placeholder - $num_ent, - $key_ent, - $win)) - 1; - my $diff = (abs $S{block}) - (screen_length(as_tc($name)) + $baseLength); - if ($diff < 0) { # too long - my $screen_length = screen_length(as_tc($name)); - if ((abs $diff) >= $screen_length) { $name = '' } # forget it - elsif ((abs $diff) + screen_length(as_tc(substr($name, 0, 1))) >= $screen_length) { $name = substr($name, 0, 1); } - else { - my $ulen = length $name; - my $middle2 = exists $abbrevList->{$name} ? - ($S{fancy_strict}) ? - 2* $abbrevList->{$name} : - (2*($abbrevList->{$name} + $ulen) / 3) : - ($S{fancy_head}) ? - 2*$ulen : - $ulen; - my $first = 1; - while (length $name > 1) { - my $cp = $middle2 >= 0 ? $middle2/2 : -1; # clearing position - my $rm = 2; - # if character at end is wider than 1 cell -> replace it with ~ - if (screen_length(as_tc(substr $name, $cp, 1)) > 1) { - if ($first || $cp < 0) { - $rm = 1; - $first = undef; - } - } - elsif ($cp < 0) { # elsif at end -> replace last 2 characters - --$cp; - } - (substr $name, $cp, $rm) = $abbrev1; - if ($cp > -1 && $rm > 1) { - --$middle2; - } - my $sl = screen_length(as_tc($name)); - if ($sl + $baseLength < abs $S{block}) { - (substr $name, ($middle2+1)/2, 1) = $abbrev2; - last; - } - elsif ($sl + $baseLength == abs $S{block}) { - last; - } - } - } - } - elsif ($VIEWER_MODE or $S{block} < 0) { - $name .= (' ' x $diff); - } - } - - push @win_items, _format_display( - '', $display, $cdisplay, $hilight, - as_tc($name), - $num_ent, - as_tc($key_ent), - $win); - - if ($global_tag_header_mode) { - $last_net = $backup_win->{active}{server}{tag}; - redo; - } - - $mouse_coords{refnum}{$#win_items} = $number; - } -} - -sub _spread_items { - my $width = $screenWidth - $sb_base_width - 1; - my @separator = _get_format(set 'separator'); - if ($S{block} >= 0) { - my $sep2 = _get_format(set 'separator2'); - push @separator, $sep2 if length $sep2 && $sep2 ne $separator[0]; - } - $separator[0] .= '%n'; - my @sepLen = map { sb_length($_) } @separator; - - @actString = (); - my $curLine; - my $curLen = 0; - if ($S{shared_sbar}) { - $curLen += $S{shared_sbar}[0] + 2; - $width -= $S{shared_sbar}[2]; - } - my $mouse_header_check = 0; - for my $it (@win_items) { - my $itemLen = sb_length($it); - if ($curLen) { - if ($curLen + $itemLen + $sepLen[$mouse_header_check % @sepLen] > $width) { - $width += $S{shared_sbar}[2] - if !@actString && $S{shared_sbar}; - push @actString, $curLine; - $curLine = undef; - $curLen = 0; - } - elsif (defined $curLine) { - $curLine .= $separator[$mouse_header_check % @separator]; - $curLen += $sepLen[$mouse_header_check % @sepLen]; - } - } - $curLine .= $it; - if (exists $mouse_coords{refnum}{$mouse_header_check}) { - $mouse_coords{scalar @actString}{ $_ } = $mouse_coords{refnum}{$mouse_header_check} - for $curLen .. $curLen + $itemLen - 1; - } - $curLen += $itemLen; - } - continue { - ++$mouse_header_check; - } - $curLen -= $S{shared_sbar}[0] - if !@actString && $S{shared_sbar}; - push @actString, $curLine if $curLen; -} - -sub remake { - my %abbrevList; - my @wins = window_list(); - if ($VIEWER_MODE or $S{sbar_maxlen} or $S{block} < 0) { - _calculate_abbrev(\@wins, \%abbrevList); - } - - %mouse_coords = ( refnum => +{} ); - _calculate_items(\@wins, \%abbrevList); - - unless ($VIEWER_MODE) { - _spread_items(); - - push @actString, undef unless @actString || $S{all_disable}; - } -} - -sub update_wl { - return if $BLOCK_ALL; - remake(); - - Irssi::statusbar_items_redraw(set $_) for keys %statusbars; - - unless ($VIEWER_MODE) { - Irssi::timeout_add_once(100, 'syncLines', undef); - } - else { - syncViewer(); - } -} - -sub screenFullRedraw { - my ($window) = @_; - if (!ref $window or $window->{refnum} == Irssi::active_win->{refnum}) { - $viewer{fullRedraw} = 1 if $viewer{client}; - $settings_str = ''; - &setup_changed; - } -} - -sub restartViewerServer { - if ($VIEWER_MODE) { - stop_viewer(); - start_viewer(); - } -} - -sub _simple_quote { - my @r = map { - my $x = $_; - $x =~ s/'/'"'"'/g; - $x = "'$x'"; - } @_; - wantarray ? @r : shift @r -} - -sub _viewer_command_replace_format { - my ($ecmd, @args) = @_; - my $file = _simple_quote(SCRIPT_FILE()); - my $path = _simple_quote($viewer{path}); - my @env; - for my $env (shellwords($S{viewer_launch_env})) { - if ($env =~ /^(\w+)(?:=(.*))$/) { - push @env, "AWL_$1=$2" - } - } - my $cmd = join ' ', - (@env ? ('env', _simple_quote(@env)) : ()), - 'perl', $file, '-1', _simple_quote(@args), $path; - $ecmd =~ s{%(%|\w+)}{ - my $sub = $1; - if ($sub eq '%') { - '%' - } - elsif ($sub =~ /^(q*)A(.*)/) { - my $ret = $cmd; - for (1..length $1) { - $ret = _simple_quote($ret); - } - "$ret$2" - } - else { - "%$sub" - } - }gex; - $ecmd -} - -sub start_viewer { - unlink $viewer{path} if -S $viewer{path} || -p _; - - $viewer{server} = IO::Socket::UNIX->new( - Type => SOCK_STREAM, - Local => $viewer{path}, - Listen => 1 - ); - unless ($viewer{server}) { - $viewer{msg} = "Viewer: $!"; - $viewer{retry} = Irssi::timeout_add_once(5000, 'retry_viewer', 1); - return; - } - $viewer{server}->blocking(0); - set_viewer_mode_hint(); - $viewer{server_tag} = Irssi::input_add($viewer{server}->fileno, INPUT_READ, 'vi_connected', undef); - - if ($S{viewer_launch}) { - if (length $ENV{TMUX_PANE} && length $ENV{TMUX} && lc $S{viewer_tmux_position} ne 'custom') { - my $cmd = _viewer_command_replace_format('%qA', '-p', lc $S{viewer_tmux_position}); - Irssi::command("exec - tmux neww -d $cmd 2>&1 &"); - } - elsif (length $ENV{WINDOWID} && length $ENV{DISPLAY} && length $S{viewer_xwin_command} && $S{viewer_xwin_command} =~ /\S/) { - my $cmd = _viewer_command_replace_format($S{viewer_xwin_command}); - Irssi::command("exec - $cmd 2>&1 &"); - } - elsif (length $S{viewer_custom_command} && $S{viewer_custom_command} =~ /\S/) { - my $cmd = _viewer_command_replace_format($S{viewer_custom_command}); - Irssi::command("exec - $cmd 2>&1 &"); - } - } -} - -sub set_viewer_mode_hint { - return unless $viewer{server}; - if ($S{no_mode_hint}) { - $viewer{msg} = undef; - } - else { - my ($name) = __PACKAGE__ =~ /::([^:]+)$/; - $viewer{msg} = "Run $name from the shell or switch to sbar mode"; - } -} - -sub retry_viewer { - start_viewer(); -} - -sub vi_close_client { - Irssi::input_remove(delete $viewer{client_tag}) if exists $viewer{client_tag}; - $viewer{client}->close if $viewer{client}; - delete $viewer{client}; - delete $viewer{client_keymap}; - delete $viewer{client_settings}; - delete $viewer{client_env}; - delete $viewer{fullRedraw}; -} - -sub vi_connected { - vi_close_client(); - $viewer{client} = $viewer{server}->accept or return; - $viewer{client}->blocking(0); - $viewer{client_tag} = Irssi::input_add($viewer{client}->fileno, INPUT_READ, 'vi_clientinput', undef); - syncViewer(); -} - -use constant VIEWER_BLOCK_SIZE => 1024; -sub vi_clientinput { - if ($viewer{client}->read(my $buf, VIEWER_BLOCK_SIZE)) { - $viewer{rcvbuf} .= $buf; - if ($viewer{rcvbuf} =~ s/^(?:(active|\d+)|(last|up|down))\n//igm) { - if (defined $2) { - Irssi::command("window $2"); - } - elsif (lc $1 eq 'active' && $viewer{use_ack}) { - Irssi::command("ack"); - } - else { - Irssi::command("window goto $1"); - } - } - } - else { - vi_close_client(); - Irssi::timeout_add_once(100, 'syncViewer', undef); - } -} - -sub stop_viewer { - Irssi::timeout_remove(delete $viewer{retry}) if exists $viewer{retry}; - vi_close_client(); - Irssi::input_remove(delete $viewer{server_tag}) if exists $viewer{server_tag}; - return unless $viewer{server}; - $viewer{server}->close; - delete $viewer{server}; -} -sub _encode_var { - my $str; - while (@_) { - my ($name, $var) = splice @_, 0, 2; - my $type = ref $var ? $var =~ /HASH/ ? 'map' : $var =~ /ARRAY/ ? 'list' : '' : ''; - $str .= "\n\U$name$type\_begin\n"; - if ($type eq 'map') { - no warnings 'numeric'; - $str .= " $_\n ${$var}{$_}\n" for sort { $a <=> $b || $a cmp $b } keys %$var; - } - elsif ($type eq 'list') { - $str .= " $_\n" for @$var; - } - else { - $str .= " $var\n"; - } - $str .= "\U$name$type\_end\n"; - } - $str -} -sub syncViewer { - if ($viewer{client}) { - @actString = (); - if ($currentLines) { - killOldStatus(); - $currentLines = 0; - } - my $str; - unless ($viewer{client_keymap}) { - $str .= _encode_var('key', +{ %nummap, %specialmap }); - $viewer{client_keymap} = 1; - } - unless ($viewer{client_settings}) { - $str .= _encode_var( - block => $S{block}, - ha => $S{height_adjust}, - mc => $S{maxcolumns}, - ml => $S{maxlines}, - ); - $viewer{client_settings} = 1; - } - unless ($viewer{client_env}) { - $str .= _encode_var(irssienv => +{ - length $ENV{TMUX_PANE} && length $ENV{TMUX} ? - (tmux_pane => $ENV{TMUX_PANE}, - tmux_srv => $ENV{TMUX}) : (), - length $ENV{WINDOWID} ? - (xwinid => $ENV{WINDOWID}) : (), - }); - $viewer{client_env} = 1; - } - my $separator = _get_format(set 'separator'); - my $sepLen = sb_length($separator); - my $item_bg = _get_format(set 'viewer_item_bg'); - my $title = _get_format(set 'title'); - if (length $title) { - $title =~ s{\\(.)|(.)}{ - defined $2 ? quotemeta $2 - : $1 eq 'V' ? '\U' - : $1 eq ':' ? quotemeta '%N' - : $1 =~ /^[uUFQE]$/ ? "\\$1" - : quotemeta "\\$1" - }sge; - $title = eval qq{"$title"}; - } - $str .= _encode_var(redraw => 1) if delete $viewer{fullRedraw}; - $str .= _encode_var(separator => $separator, - seplen => $sepLen, - itembg => $item_bg, - title => $title, - mouse => $mouse_coords{refnum}, - key2 => \%wnmap_exp, - win => \@win_items); - - my $was = $viewer{client}->blocking(1); - $viewer{client}->print($str); - $viewer{client}->blocking($was); - } - elsif ($viewer{server}) { - if (defined $viewer{msg}) { - @actString = ((uc setc()).": $viewer{msg}"); - } - else { - @actString = (); - } - } - elsif (defined $viewer{msg}) { - @actString = ((uc setc()).": $viewer{msg}"); - } - if (@actString) { - Irssi::timeout_add_once(100, 'syncLines', undef); - } - elsif ($currentLines) { - killOldStatus(); - $currentLines = 0; - } -} - -sub reset_awl { - Irssi::timeout_remove($shade_line_timer) if $shade_line_timer; $shade_line_timer = undef; - my $was_sort = $S{sort} // ''; - my $was_xform = $S{xform} // ''; - my $was_shared = $S{shared_sbar}; - my $was_no_hint = $S{no_mode_hint}; - %S = ( - sort => Irssi::settings_get_str( set 'sort'), - fancy_abbrev => Irssi::settings_get_str('fancy_abbrev'), - xform => Irssi::settings_get_str( set 'custom_xform'), - block => Irssi::settings_get_int( set 'block'), - banned_on => Irssi::settings_get_bool('banned_channels_on'), - prefer_name => Irssi::settings_get_bool(set 'prefer_name'), - hide_data => Irssi::settings_get_int( set 'hide_data'), - hide_name => Irssi::settings_get_int( set 'hide_name_data'), - hide_empty => Irssi::settings_get_int( set 'hide_empty'), - sbar_maxlen => Irssi::settings_get_bool(set 'sbar_maxlength'), - placement => Irssi::settings_get_str( set 'placement'), - position => Irssi::settings_get_int( set 'position'), - maxlines => Irssi::settings_get_int( set 'maxlines'), - maxcolumns => Irssi::settings_get_int( set 'maxcolumns'), - all_disable => Irssi::settings_get_bool(set 'all_disable'), - height_adjust => Irssi::settings_get_int( set 'height_adjust'), - mouse_offset => Irssi::settings_get_int( set 'mouse_offset'), - mouse_scroll => Irssi::settings_get_int( 'mouse_scroll'), - mouse_escape => Irssi::settings_get_int( 'mouse_escape'), - line_shade => Irssi::settings_get_time(set 'last_line_shade'), - no_mode_hint => Irssi::settings_get_bool(set 'no_mode_hint'), - viewer_launch => Irssi::settings_get_bool(set 'viewer_launch'), - viewer_launch_env => Irssi::settings_get_str(set 'viewer_launch_env'), - viewer_xwin_command => Irssi::settings_get_str(set 'viewer_xwin_command'), - viewer_custom_command => Irssi::settings_get_str(set 'viewer_custom_command'), - viewer_tmux_position => Irssi::settings_get_str(set 'viewer_tmux_position'), - ); - $S{fancy_strict} = $S{fancy_abbrev} =~ /^strict/i; - $S{fancy_head} = $S{fancy_abbrev} =~ /^head/i; - my $shared = Irssi::settings_get_str(set 'shared_sbar'); - if ($shared =~ /^(\d+)([<])(\d+)$/) { - $S{shared_sbar} = [$1, $2, $3]; - } - else { - Irssi::settings_set_str(set 'shared_sbar', 'OFF'); - $S{shared_sbar} = undef; - } - lock_keys(%S); - if ($was_sort ne $S{sort}) { - $print_text_activity = undef; - my @sort_order = grep { @$_ > 4 } map { - s/^\s*//; - my $reverse = s/^\W*\K[-!]//; - my $undef_check = s/^\W*\K~// ? 1 : undef; - my $equal_check = s/=(.*)\s?$// ? $1 : undef; - s/\s*$//; - my $ignore_case = s/#i$// ? 1 : undef; - - $print_text_activity = 1 if $_ eq 'last_line'; - - my @path = split '/'; - my $class_check = @path && $path[-1] =~ s/(::.*)$// ? $1 : undef; - - [ $reverse ? -1 : 1, $undef_check, $equal_check, $class_check, $ignore_case, @path ] - } "$S{sort}," =~ /([^+,]*|[^+,]*=[^,]*?\s(?=\+)|[^+,]*=[^,]*)[+,]/g; - $window_sort_func = sub { - no warnings qw(numeric uninitialized); - for my $so (@sort_order) { - my @x = map { - my $ret = 0; - $_ = lc1459($_) if defined $_ && !ref $_ && $so->[4]; - $ret = $_ eq ($so->[4] ? lc1459($so->[2]) : $so->[2]) ? 1 : -1 if defined $so->[2]; - $ret = defined $_ ? ($ret || -3) : 3 if $so->[1]; - $ret = ref $_ && $_->isa('Irssi'.$so->[3]) ? 2 : ($ret || -2) if $so->[3]; - -$ret || $_ - } - map { - reduce { return unless ref $a; $a->{$b} } $_, @{$so}[5..$#$so] - } $a, $b; - return ((($x[0] <=> $x[1] || $x[0] cmp $x[1]) * $so->[0]) || next); - } - return ($a->{refnum} <=> $b->{refnum}); - }; - } - if ($was_xform ne $S{xform}) { - if ($S{xform} !~ /\S/) { - $custom_xform = undef; - } - else { - my $script_pkg = __PACKAGE__ . '::custom_xform'; - local $@; - $custom_xform = eval qq{ -package $script_pkg; -use strict; -no warnings; -our (\$QUERY, \$CHANNEL, \$TAG, \$NAME); -return sub { -# line 1 @{[ set 'custom_xform' ]}\n$S{xform}\n}}; - if ($@) { - $@ =~ /^(.*)/; - print '%_'.(set 'custom_xform').'%_ did not compile: '.$1; - } - } - } - - my $new_settings = join "\n", $VIEWER_MODE - ? ("\\", $S{block}, $S{height_adjust}, $S{maxlines}, $S{maxcolumns}) - : ("!", $S{placement}, $S{position}); - - if ($settings_str ne $new_settings) { - @actString = (); - %abbrev_cache = (); - $currentLines = 0; - killOldStatus(); - delete $viewer{client_settings}; - $settings_str = $new_settings; - } - - my $was_mouse_mode = $MOUSE_ON; - if ($MOUSE_ON = Irssi::settings_get_bool(set 'mouse') and !$was_mouse_mode) { - install_mouse(); - } - elsif ($was_mouse_mode and !$MOUSE_ON) { - uninstall_mouse(); - } - - my $path = Irssi::settings_get_str(set 'path'); - my $was_viewer_mode = $VIEWER_MODE; - if ($was_viewer_mode && - defined $viewer{path} && $viewer{path} ne $path) { - stop_viewer(); - $was_viewer_mode = 0; - } - elsif ($was_viewer_mode && $S{no_mode_hint} != $was_no_hint + 0) { - set_viewer_mode_hint(); - } - $viewer{path} = $path; - if ($VIEWER_MODE = Irssi::settings_get_bool(set 'viewer') and !$was_viewer_mode) { - start_viewer(); - } - elsif ($was_viewer_mode and !$VIEWER_MODE) { - stop_viewer(); - } - - %banned_channels = map { lc1459(to_uni($_)) => undef } - split ' ', Irssi::settings_get_str('banned_channels'); - - my @sb_base = split /\177/, sb_format_expand("{sbstart}{sb \177}{sbend}"), 2; - $sb_base_width_pre = sb_length($sb_base[0]); - $sb_base_width_post = max 0, sb_length($sb_base[1])-1; - $sb_base_width = $sb_base_width_pre + $sb_base_width_post; - - if ($print_text_activity && $S{line_shade}) { - $shade_line_timer = Irssi::timeout_add(max(10 * GLOB_QUEUE_TIMER, 100*$S{line_shade}**(1/3)), 'wl_changed', undef); - } - - $CHANGED{AWINS} = 1; -} - -sub stop_mouse_tracking { - print STDERR "\e[?1005l\e[?1000l"; -} -sub start_mouse_tracking { - print STDERR "\e[?1000h\e[?1005h"; -} -sub install_mouse { - Irssi::command_bind('mouse_xterm' => 'mouse_xterm'); - Irssi::command('^bind meta-[M command mouse_xterm'); - Irssi::signal_add_first('gui key pressed' => 'mouse_key_hook'); - start_mouse_tracking(); -} -sub uninstall_mouse { - stop_mouse_tracking(); - Irssi::signal_remove('gui key pressed' => 'mouse_key_hook'); - Irssi::command('^bind -delete meta-[M'); - Irssi::command_unbind('mouse_xterm' => 'mouse_xterm'); -} - -sub awl_mouse_event { - return if $VIEWER_MODE; - if ((($_[0] == 3 and $_[3] == 0) - || $_[0] == 64 || $_[0] == 65) and - $_[1] == $_[4] and $_[2] == $_[5]) { - my $top = lc $S{placement} eq 'top'; - my ($pos, $line) = @_[1 .. 2]; - unless ($top) { - $line -= $screenHeight; - $line += $currentLines; - $line += $S{mouse_offset}; - } - else { - $line -= $S{mouse_offset}; - } - $pos -= $sb_base_width_pre; - return if $line < 0 || $line >= $currentLines; - if ($_[0] == 64) { - Irssi::command('window up'); - } - elsif ($_[0] == 65) { - Irssi::command('window down'); - } - elsif (exists $mouse_coords{$line}{$pos}) { - my $win = $mouse_coords{$line}{$pos}; - Irssi::command('window ' . $win); - } - Irssi::signal_stop; - } -} - -sub mouse_scroll_event { - return unless $S{mouse_scroll}; - if (($_[3] == 64 or $_[3] == 65) and - $_[0] == $_[3] and $_[1] == $_[4] and $_[2] == $_[5]) { - my $cmd = 'scrollback goto ' . ($_[3] == 64 ? '-' : '+') . $S{mouse_scroll}; - Irssi::active_win->command($cmd); - Irssi::signal_stop; - } - elsif ($_[0] == 64 or $_[0] == 65) { - Irssi::signal_stop; - } -} - -sub mouse_escape { - return unless $S{mouse_escape} > 0; - if ($_[0] == 3) { - my $tm = $S{mouse_escape}; - $tm *= 1000 if $tm < 1000; - stop_mouse_tracking(); - Irssi::timeout_add_once($tm, 'start_mouse_tracking', undef); - Irssi::signal_stop; - } -} - -sub UNLOAD { - @actString = (); - killOldStatus(); - stop_viewer() if $VIEWER_MODE; - uninstall_mouse() if $MOUSE_ON; -} - -sub addPrintTextHook { # update on print text - return unless defined $^S; - return if $BLOCK_ALL; - return unless $print_text_activity; - return if $_[0]->{level} == 262144 and $_[0]->{target} eq '' - and !defined($_[0]->{server}); - &wl_changed; -} - -sub block_event_window_change { - Irssi::signal_stop; -} - -sub update_awins { - my @wins = Irssi::windows; - local $BLOCK_ALL = 1; - Irssi::signal_add_first('window changed' => 'block_event_window_change'); - my $bwin = - my $awin = Irssi::active_win; - my $lwin; - my $defer_irssi_broken_last; - unless ($wins[0]{refnum} == $awin->{refnum}) { - # special case: more than 1 last win, so /win last; - # /win last doesn't come back to the current window. eg. after - # connect & autojoin; we can't handle this situation, bail out - $defer_irssi_broken_last = 1; - } - else { - $awin->command('window last'); - $lwin = Irssi::active_win; - $lwin->command('window last'); - $defer_irssi_broken_last = $lwin->{refnum} == $bwin->{refnum}; - } - my $awin_counter = 0; - Irssi::signal_remove('window changed' => 'block_event_window_change'); - unless ($defer_irssi_broken_last) { - # we need to keep the fe-windows code running here - Irssi::signal_add_priority('window changed' => 'block_event_window_change', -99); - %awins = %wnmap_exp = (); - do { - Irssi::active_win->command('window up'); - $awin = Irssi::active_win; - $awins{$awin->{refnum}} = undef; - ++$awin_counter; - } until ($awin->{refnum} == $bwin->{refnum} || $awin_counter >= @wins); - Irssi::signal_remove('window changed' => 'block_event_window_change'); - - Irssi::signal_add_first('window changed' => 'block_event_window_change'); - for my $key (keys %wnmap) { - next unless Irssi::window_find_name($key) || Irssi::window_find_item($key); - $awin->command("window goto $key"); - my $cwin = Irssi::active_win; - $wnmap_exp{ $cwin->{refnum} } = $wnmap{$key}; - $cwin->command('window last') - if $cwin->{refnum} != $awin->{refnum}; - } - for my $win (reverse @wins) { # restore original window order - Irssi::active_win->command('window '.$win->{refnum}); - } - $awin->command('window '.$lwin->{refnum}); # restore last win - Irssi::active_win->command('window last'); - Irssi::signal_remove('window changed' => 'block_event_window_change'); - } - $CHANGED{WL} = 1; -} - -sub resizeTerm { - if (defined (my $r = `stty size 2>/dev/null`)) { - ($screenHeight, $screenWidth) = split ' ', $r; - $CHANGED{SETUP} = 1; - } - else { - $CHANGED{SIZE} = 1; - } -} - -sub awl_refresh { - $globTime = undef; - resizeTerm() if delete $CHANGED{SIZE}; - reset_awl() if delete $CHANGED{SETUP}; - update_awins() if delete $CHANGED{AWINS}; - update_wl() if delete $CHANGED{WL}; -} - -sub termsize_changed { $CHANGED{SIZE} = 1; &queue_refresh; } -sub setup_changed { $CHANGED{SETUP} = 1; &queue_refresh; } -sub awins_changed { $CHANGED{AWINS} = 1; &queue_refresh; } -sub wl_changed { $CHANGED{WL} = 1; &queue_refresh; } - -sub window_changed { - &awins_changed if $_[1]; -} - -sub queue_refresh { - return if $BLOCK_ALL; - Irssi::timeout_remove($globTime) - if defined $globTime; # delay the update further - $globTime = Irssi::timeout_add_once(GLOB_QUEUE_TIMER, 'awl_refresh', undef); -} - -sub awl_init { - termsize_changed(); - update_keymap(); -} - -sub runsub { - my $cmd = shift; - sub { - my ($data, $server, $item) = @_; - Irssi::command_runsub($cmd, $data, $server, $item); - }; -} - -Irssi::signal_register({ - 'gui mouse' => [qw/int int int int int int/], - }); -{ my $broken_expandos = (Irssi::version >= 20081128 && Irssi::version < 20110210) - ? sub { my $x = shift; $x =~ s/\$\{cumode_space\}/ /; $x } : undef; - Irssi::theme_register([ - map { $broken_expandos ? $broken_expandos->($_) : $_ } - set 'display_nokey' => '$N${cumode_space}$H$C$S', - set 'display_key' => '$Q${cumode_space}$H$C$S', - set 'display_nokey_visible' => '%2$N${cumode_space}$H$C$S', - set 'display_key_visible' => '%2$Q${cumode_space}$H$C$S', - set 'display_nokey_active' => '%1$N${cumode_space}$H$C$S', - set 'display_key_active' => '%1$Q${cumode_space}$H$C$S', - set 'display_header' => '%8$C|${N}', - set 'name_display' => '$0', - set 'separator' => ' ', - set 'separator2' => '', - set 'abbrev_chars' => "~\x{301c}", - set 'viewer_item_bg' => sb_format_expand('{sb_background}'), - set 'title' => '\V'.setc().'\:', - ]); -} -Irssi::settings_add_bool(setc, set 'prefer_name', 0); # -Irssi::settings_add_int( setc, set 'hide_empty', 0); # -Irssi::settings_add_int( setc, set 'hide_data', 0); # -Irssi::settings_add_int( setc, set 'hide_name_data', 0); # -Irssi::settings_add_int( setc, set 'maxlines', 9); # -Irssi::settings_add_int( setc, set 'maxcolumns', 4); # -Irssi::settings_add_int( setc, set 'block', 15); # -Irssi::settings_add_bool(setc, set 'sbar_maxlength', 1); # -Irssi::settings_add_int( setc, set 'height_adjust', 2); # -Irssi::settings_add_str( setc, set 'sort', 'refnum'); # -Irssi::settings_add_str( setc, set 'placement', 'bottom'); # -Irssi::settings_add_int( setc, set 'position', 0); # -Irssi::settings_add_bool(setc, set 'all_disable', 1); # -Irssi::settings_add_bool(setc, set 'viewer', 1); # -Irssi::settings_add_str( setc, set 'shared_sbar', 'OFF'); # -Irssi::settings_add_bool(setc, set 'mouse', 0); # -Irssi::settings_add_str( setc, set 'path', Irssi::get_irssi_dir . '/_windowlist'); # -Irssi::settings_add_str( setc, set 'custom_xform', ''); # -Irssi::settings_add_time(setc, set 'last_line_shade', '0'); # -Irssi::settings_add_int( setc, set 'mouse_offset', 1); # -Irssi::settings_add_int( setc, 'mouse_scroll', 3); # -Irssi::settings_add_int( setc, 'mouse_escape', 1); # -Irssi::settings_add_str( setc, 'banned_channels', ''); -Irssi::settings_add_bool(setc, 'banned_channels_on', 1); -Irssi::settings_add_str( setc, 'fancy_abbrev', 'fancy'); # -Irssi::settings_add_bool(setc, set 'no_mode_hint', 0); # -Irssi::settings_add_bool(setc, set 'viewer_launch', 1); # -Irssi::settings_add_str( setc, set 'viewer_launch_env', ''); # -Irssi::settings_add_str( setc, set 'viewer_tmux_position', 'left'); # -Irssi::settings_add_str( setc, set 'viewer_xwin_command', 'xterm +sb -e %A'); # -Irssi::settings_add_str( setc, set 'viewer_custom_command', ''); # - -Irssi::signal_add_last({ - 'setup changed' => 'setup_changed', - 'print text' => 'addPrintTextHook', - 'terminal resized' => 'termsize_changed', - 'setup reread' => 'screenFullRedraw', - 'window hilight' => 'wl_changed', - 'command format' => 'wl_changed', -}); -Irssi::signal_add({ - 'window changed' => 'window_changed', - 'window item changed' => 'wl_changed', - 'window changed automatic' => 'window_changed', - 'window created' => 'awins_changed', - 'window destroyed' => 'awins_changed', - 'window name changed' => 'wl_changed', - 'window refnum changed' => 'wl_changed', -}); -Irssi::signal_add_last('gui mouse' => 'mouse_escape'); -Irssi::signal_add_last('gui mouse' => 'mouse_scroll_event'); -Irssi::signal_add_last('gui mouse' => 'awl_mouse_event'); -Irssi::command_bind( setc() => runsub(setc()) ); -Irssi::command_bind( setc() . ' redraw' => 'screenFullRedraw' ); -Irssi::command_bind( setc() . ' restart' => 'restartViewerServer' ); - -{ - my $l = set 'shared'; - { - no strict 'refs'; - *{$l} = $awl_shared_empty; - } - Irssi::statusbar_item_register($l, '$0', $l); -} - -awl_init(); - -# Mouse script based on irssi mouse patch by mirage -{ my $mouse_status = -1; # -1:off 0,1,2:filling mouse_combo - my @mouse_combo; # 0:button 1:x 2:y - my @mouse_previous; # previous contents of mouse_combo - - sub mouse_xterm_off { - $mouse_status = -1; - } - sub mouse_xterm { - $mouse_status = 0; - Irssi::timeout_add_once(10, 'mouse_xterm_off', undef); - } - - sub mouse_key_hook { - my ($key) = @_; - if ($mouse_status != -1) { - if ($mouse_status == 0) { - @mouse_previous = @mouse_combo; - #if @mouse_combo && $mouse_combo[0] < 64; - } - $mouse_combo[$mouse_status] = $key - 32; - $mouse_status++; - if ($mouse_status == 3) { - $mouse_status = -1; - # match screen coordinates - $mouse_combo[1]--; - $mouse_combo[2]--; - Irssi::signal_emit('gui mouse', @mouse_combo[0 .. 2], @mouse_previous[0 .. 2]); - } - Irssi::signal_stop; - } - } -} - -sub string_LCSS { - my $str = join "\0", @_; - (sort { length $b <=> length $a } $str =~ /(?=(.+).*\0.*\1)/g)[0] -} - -# workaround for issue #271 -{ package Irssi::Nick } - -# workaround for issue #572 -@Irssi::UI::Exec::ISA = 'Irssi::Windowitem' - if Irssi::version >= 20140822 && Irssi::version <= 20161101 && !@Irssi::UI::Exec::ISA; - -UNITCHECK -{ package AwlViewer; - use strict; - use warnings; - no warnings 'redefine'; - use Encode; - use IO::Socket::UNIX; - use IO::Select; - use List::Util qw(max); - use constant BLOCK_SIZE => 1024; - use constant RECONNECT_TIME => 5; - - my $sockpath; - - our $VERSION = '0.8'; - - our ($got_int, $resized, $timeout); - - my %vars; - my (%c2w, @seqlist); - my %mouse_coords; - my (@mouse, @last_mouse); - my ($err, $sock, $loop); - my ($keybuf, $rcvbuf); - my @screen; - my ($screenHeight, $screenWidth); - my ($disp_update, $fs_open, $one_shot_integration, $one_shot_resize); - my $integration_position; - my $show_title_bar; - - sub connect_it { - $sock = IO::Socket::UNIX->new( - Type => SOCK_STREAM, - Peer => $sockpath, - ); - unless ($sock) { - $err = $!; - return; - } - $sock->blocking(0); - $loop->add($sock); - } - - sub remove_conn { - my $fh = shift; - $loop->remove($fh); - $fh->close; - $sock = undef; - %vars = (); - @screen = (); - } - - { package Terminfo; # xterm - sub civis { "\e[?25l" } - sub sc { "\e7" } - sub cup { "\e[" . ($_[0] + 1) . ';' . ($_[1] + 1) . 'H' } - sub el { "\e[K" } - sub rc { "\e8" } - sub cnorm { "\e[?25h" } - sub setab { "\e[4" . $_[0] . 'm' } - sub setaf { "\e[3" . $_[0] . 'm' } - sub setaf16 { "\e[9" . $_[0] . 'm' } - sub setab16 { "\e[10" . $_[0] . 'm' } - sub setaf256 { "\e[38;5;" . $_[0] . 'm' } - sub setab256 { "\e[48;5;" . $_[0] . 'm' } - sub sgr0 { "\e[0m" } - sub bold { "\e[1m" } - sub it { "\e[3m" } - sub ul { "\e[4m" } - sub blink { "\e[5m" } - sub rev { "\e[7m" } - sub op { "\e[39;49m" } - sub exit_bold { "\e[22m" } - sub exit_it { "\e[23m" } - sub exit_ul { "\e[24m" } - sub exit_blink { "\e[25m" } - sub exit_rev { "\e[27m" } - sub smcup { "\e[?1049h" } - sub rmcup { "\e[?1049l" } - sub smmouse { "\e[?1000h\e[?1005h" } - sub rmmouse { "\e[?1005l\e[?1000l" } - } - - sub init { - $sockpath = shift // "$ENV{HOME}/.irssi/_windowlist"; - STDOUT->autoflush(1); - printf "\r%swaiting for %s...", Terminfo::sc, $::IRSSI{name}; - - `stty -icanon -echo`; - - $loop = IO::Select->new; - STDIN->blocking(0); - $loop->add(\*STDIN); - - $SIG{INT} = sub { - $got_int = 1 - }; - $SIG{WINCH} = sub { - $resized = 1 - }; - - $resized = 3; - - $disp_update = 2; - - $show_title_bar = 1; - } - - sub enter_fs { - return if $fs_open; - safe_print(Terminfo::rc, Terminfo::smcup, Terminfo::civis, Terminfo::smmouse); - $fs_open = 1; - } - - sub leave_fs { - return unless $fs_open; - safe_print(Terminfo::rmmouse, Terminfo::cnorm, Terminfo::rmcup); - safe_print(sprintf "\r%swaiting for %s...", Terminfo::sc, $::IRSSI{name}) if $_[0]; - - $fs_open = 0; - } - - sub end_prog { - leave_fs(); - STDIN->blocking(1); - `stty sane`; - printf "\r%s%sthanks for using %s\n", Terminfo::rc, Terminfo::el, $::IRSSI{name}; - } - - sub safe_print { - my $st = STDIN->blocking(1); - print @_; - STDIN->blocking($st); - } - - sub safe_qx { - my $st = STDIN->blocking(1); - my $ret = `$_[0]`; - STDIN->blocking($st); - $ret - } - - sub safe_print_sock { - return unless $sock; - my $was = $sock->blocking(1); - $sock->print(@_); - $sock->blocking($was); - } - - sub process_recv { - my $need = 0; - while ($rcvbuf =~ s/\n(.+)_BEGIN\n((?: .*\n)*)\1_END\n//) { - my $var = lc $1; - my $data = $2; - my @data = split "\n ", "\n$data ", -1; - shift @data; pop @data; - my $itembg = $vars{itembg}; - if ($var =~ s/list$//) { - $vars{$var} = \@data; - } - elsif ($var =~ s/map$//) { - $vars{$var} = +{ @data }; - } - else { - $vars{$var} = join "\n", @data; - } - $need = 1 if $var eq 'win'; - $need = 1 if $var eq 'redraw' && $vars{$var}; - if (($itembg//'') ne ($vars{itembg}//'')) { - $need = $vars{redraw} = 1; - } - _build_keymap() if $var eq 'key2'; - } - $need - } - - { my %ansi_table; - my ($i, $j, $k) = (0, 0, 0); - my %term_state; - sub reset_term_state { my %old_term = %term_state; %term_state = (); %old_term } - sub set_term_state { my %old_term = %term_state; %term_state = @_; %old_term } - %ansi_table = ( - # fe-common::core::formats.c:format_expand_styles - (map { my $t = $i++; ($_ => sub { my $n = $term_state{hicolor} ? \&Terminfo::setab16 : \&Terminfo::setab; - $n->($t) }) } (split //, '01234567' )), - (map { my $t = $j++; ($_ => sub { my $n = $term_state{hicolor} ? \&Terminfo::setaf16 : \&Terminfo::setaf; - $n->($t) }) } (split //, 'krgybmcw' )), - (map { my $t = $k++; ($_ => sub { my $n = $term_state{hicolor} ? \&Terminfo::setaf : \&Terminfo::setaf16; - $n->($t) }) } (split //, 'KRGYBMCW')), - # reset - n => sub { $term_state{hicolor} = 0; my $r = Terminfo::op; - for (qw(blink rev bold)) { - $r .= Terminfo->can("exit_$_")->() if delete $term_state{$_}; - } - { - local $ansi_table{n} = $ansi_table{N}; - $r .= formats_to_ansi_basic($vars{itembg}); - } - $r - }, - N => sub { reset_term_state(); Terminfo::sgr0 }, - # flash/bright - F => sub { my $n = 'blink'; my $e = ($term_state{$n} ^= 1) ? $n : "exit_$n"; Terminfo->can($e)->() }, - # reverse - 8 => sub { my $n = 'rev'; my $e = ($term_state{$n} ^= 1) ? $n : "exit_$n"; Terminfo->can($e)->() }, - # bold - "_" => sub { my $n = 'bold'; my $e = ($term_state{$n} ^= 1) ? $n : "exit_$n"; Terminfo->can($e)->() }, - # underline - U => sub { my $n = 'ul'; my $e = ($term_state{$n} ^= 1) ? $n : "exit_$n"; Terminfo->can($e)->() }, - # italic - I => sub { my $n = 'it'; my $e = ($term_state{$n} ^= 1) ? $n : "exit_$n"; Terminfo->can($e)->() }, - # bold, used as colour modifier if AWL_HI9 is set - 9 => $ENV{AWL_HI9} ? sub { $term_state{hicolor} ^= 1; '' } - : sub { my $n = 'bold'; my $e = ($term_state{$n} ^= 1) ? $n : "exit_$n"; Terminfo->can($e)->() }, - # delete other stuff - (map { $_ => sub { '' } } (split //, ':|>#[')), - # escape - (map { my $close = $_; $_ => sub { $close } } (split //, '{}%')), - ); - for my $base (0 .. 15) { - my $close = $base; - my $idx = ($close&8) | ($close&4)>>2 | ($close&2) | ($close&1)<<2; - $ansi_table{ (sprintf "x0%x", $close) } = - $ansi_table{ (sprintf "x0%X", $close) } = - sub { Terminfo::setab256($idx) }; - $ansi_table{ (sprintf "X0%x", $close) } = - $ansi_table{ (sprintf "X0%X", $close) } = - sub { Terminfo::setaf256($idx) }; - } - for my $plane (1 .. 6) { - for my $coord (0 .. 35) { - my $close = 16 + ($plane-1) * 36 + $coord; - my $ch = $coord < 10 ? $coord : chr( $coord - 10 + ord 'a' ); - $ansi_table{ "x$plane$ch" } = - $ansi_table{ "x$plane\U$ch" } = - sub { Terminfo::setab256($close) }; - $ansi_table{ "X$plane$ch" } = - $ansi_table{ "X$plane\U$ch" } = - sub { Terminfo::setaf256($close) }; - } - } - for my $gray (0 .. 23) { - my $close = 232 + $gray; - my $ch = chr( $gray + ord 'a' ); - $ansi_table{ "x7$ch" } = - $ansi_table{ "x7\U$ch" } = - sub { Terminfo::setab256($close) }; - $ansi_table{ "X7$ch" } = - $ansi_table{ "X7\U$ch" } = - sub { Terminfo::setaf256($close) }; - } - sub formats_to_ansi_basic { - my $o = shift; - $o =~ s/(%(X..|x..|.))/exists $ansi_table{$2} ? $ansi_table{$2}->() : $1/gex; - $o - } - } - - sub _header { - my $str = $vars{title} // uc ::setc(); - my $ccs = qr/%(?:X(?:[1-6][0-9A-Z]|7[A-X])|[0-9BCFGIKMNRUWY_])/i; - (my $stripstr = $str) =~ s/($ccs)//g; - my $space = int( ((abs $vars{block}) - length $stripstr) / (1 + length $stripstr)); - if ($space > 0) { - my $ss = ' ' x $space; - my @x = $str =~ /((?:$ccs)*\X(?:(?:$ccs)*$)?)/g; - $str = join $ss, '', @x, ''; - } - ($stripstr = $str) =~ s/($ccs)//g; - my $pad = max 0, (abs $vars{block}) - length $stripstr; - $str = ' ' x ($pad/2) . $str . ' ' x ($pad/2 + $pad%2); - $str - } - - sub _add_item { - my ($i, $j, $c, $wi, $screen, $mouse) = @_; - $screen->[$i][$j] = "%N%n$wi"; - if (exists $vars{mouse}{$c - 1}) { - $mouse->[$i][$j] = $vars{mouse}{$c - 1}; - } - } - sub update_screen { - $disp_update = 0; - unless ($sock && exists $vars{seplen} && exists $vars{block}) { - leave_fs(1); - return; - } - enter_fs(); - @screen = () if delete $vars{redraw}; - %mouse_coords = (); - my $ncols = ($vars{seplen} + abs $vars{block}) ? - int( ($screenWidth + $vars{seplen}) / ($vars{seplen} + abs $vars{block}) ) : 0; - my $xenl = ($vars{seplen} + abs $vars{block}) - && $ncols > int( ($screenWidth + $vars{seplen} - 1) / ($vars{seplen} + abs $vars{block}) ); - my $nrows = $screenHeight - $vars{ha}; - my @wi = @{$vars{win}//[]}; - my $max_items = $ncols * $nrows; - my $c = $show_title_bar ? 1 : 0; - my $items = @wi + $c; - my $titems = $items > $max_items ? $max_items : $items; - my $i = 0; - my $j = 0; - my @new_screen; - my @new_mouse; - $new_screen[0][0] = _header() #. ' ' x $vars{seplen} - if $show_title_bar; - unless ($nrows > $ncols) { # line layout - ++$j if $show_title_bar; - for my $wi (@wi) { - if ($j >= $ncols) { - $j = 0; - ++$i; - } - last if $i >= $nrows; - _add_item($i, $j, $show_title_bar ? $c : $c + 1, - $wi, \@new_screen, \@new_mouse); - if ($c + 1 < $titems && $j + 1 < $ncols) { - $new_screen[$i][$j] .= $vars{separator}; - } - ++$j; - ++$c; - } - } - else { # column layout - ++$i if $show_title_bar; - for my $wi (@wi) { - if ($i >= $nrows) { - $i = 0; - ++$j; - } - last if $j >= $ncols; - _add_item($i, $j, $show_title_bar ? $c : $c + 1, - $wi, \@new_screen, \@new_mouse); - if ($c + $nrows < $titems) { - $new_screen[$i][$j] .= $vars{separator}; - } - ++$i; - ++$c; - } - } - my $step = $vars{seplen} + abs $vars{block}; - $i = 0; - my $str = Terminfo::sc . Terminfo::sgr0; - for (my $i = 0; $i < @new_screen; ++$i) { - for (my $j = 0; $j < @{$new_screen[$i]}; ++$j) { - if (defined $new_mouse[$i] && defined $new_mouse[$i][$j]) { - my $from = $j * $step; - $mouse_coords{$i}{$_} = $new_mouse[$i][$j] - for $from .. $from + abs $vars{block}; - } - next if defined $screen[$i] && defined $screen[$i][$j] - && $screen[$i][$j] eq $new_screen[$i][$j]; - $str .= Terminfo::cup($i, $j * $step) - . formats_to_ansi_basic($new_screen[$i][$j]) - . Terminfo::sgr0; - $str .= Terminfo::el if $j == $#{$new_screen[$i]} && (!$xenl || $j + 1 != $ncols); - } - } - for (@new_screen .. $screenHeight - 1) { - if (!@screen || defined $screen[$_]) { - $str .= Terminfo::cup($_, 0) . Terminfo::sgr0 . Terminfo::el; - } - } - $str .= Terminfo::rc; - safe_print $str; - @screen = @new_screen; - } - - sub handle_resize { - if (defined (my $r = safe_qx('stty size'))) { - ($screenHeight, $screenWidth) = split ' ', $r; - $resized = 0; - @screen = (); - $disp_update = 1; - if ($one_shot_integration == 2) { - $one_shot_resize--; - } - } - else { - } - } - - sub _build_keymap { - %c2w = reverse( %{$vars{key}}, %{$vars{key2}} ); - if (!grep { /^[+-]./ } keys %c2w) { - %c2w = (%c2w, map { ("-$_" => $c2w{$_}) } grep { !/^\^./ } keys %c2w); - } - %c2w = map { - my $key = $_; - s{^(-)?(\+)?(\^)?(.)}{ - join '', ( - ($1 ? "\e" : ''), - ($2 ? "\e\e" : ''), - ($3 ? "$4"^"@" : $4) - ) - }e; - $_ => $c2w{$key} - } keys %c2w; - @seqlist = sort { length $b <=> length $a } keys %c2w; - } - - sub _match_tmux { - length $ENV{TMUX} && exists $vars{irssienv}{tmux_srv} && length $vars{irssienv}{tmux_pane} - && $ENV{TMUX} eq $vars{irssienv}{tmux_srv} - } - - sub process_keys { - Encode::_utf8_on($keybuf); - my $win; - my $use_mouse; - my $maybe; - KEY: while (length $keybuf && !$maybe) { - $maybe = 0; - if ($keybuf =~ s/^\e\[M(.)(.)(.)//) { - @last_mouse = @mouse;# if @mouse && $mouse[0] < 64; - @mouse = map { -32 + ord } ($1, $2, $3); - $use_mouse = 1; - next KEY; - } - for my $s (@seqlist) { - if ($keybuf =~ s/^\Q$s//) { - $win = $c2w{$s}; - $use_mouse = 0; - next KEY; - } - elsif (length $keybuf < length $s && $s =~ /^\Q$keybuf/) { - $maybe = 1; - } - } - unless ($maybe) { - substr $keybuf, 0, 1, ''; - } - } - if ($use_mouse && @mouse && @last_mouse && - $mouse[2] == $last_mouse[2] && - $mouse[1] == $last_mouse[1] && - ($mouse[0] == 3 || $mouse[0] == 64 || $mouse[0] == 65)) { - if ($mouse[0] == 64) { - $win = 'up'; - } - elsif ($mouse[0] == 65) { - $win = 'down'; - } - elsif (exists $mouse_coords{$mouse[2] - 1}{$mouse[1] - 1}) { - $win = $mouse_coords{$mouse[2] - 1}{$mouse[1] - 1}; - } - elsif ($mouse[2] == 1 && $mouse[1] <= abs $vars{block}) { - $win = $last_mouse[0] != 0 ? 'last' : 'active'; - } - else { - } - } - if (defined $win) { - $win =~ s/^_//; - safe_print_sock("$win\n"); - if (!exists $ENV{AWL_AUTOFOCUS} || $ENV{AWL_AUTOFOCUS}) { - if (_match_tmux()) { - safe_qx("tmux selectp -t $vars{irssienv}{tmux_pane} 2>&1"); - } - elsif (exists $vars{irssienv}{xwinid}) { - safe_qx("wmctrl -ia $vars{irssienv}{xwinid} 2>/dev/null"); - } - } - } - Encode::_utf8_off($keybuf); - } - - sub check_integration { - return unless $vars{irssienv}; - return unless $sock && exists $vars{seplen} && exists $vars{block}; - if ($one_shot_integration == 1) { - my $nrows = $screenHeight - $vars{ha}; - my $ncols = ($vars{seplen} + abs $vars{block}) ? int( ($screenWidth + $vars{seplen}) / ($vars{seplen} + abs $vars{block}) ) : 0; - my $items = ($show_title_bar ? 1 : 0) + @{$vars{win}//[]}; - my $dcols_required = $nrows ? int($items/$nrows) + !!($items%$nrows) : 0; - my $rows_required = $ncols ? int($items/$ncols) + !!($items%$ncols) : 0; - $rows_required = abs $vars{ml} - if ($vars{ml} < 0 || ($vars{ml} > 0 && $rows_required > $vars{ml})); - $dcols_required = abs $vars{mc} - if ($vars{mc} < 0 || ($vars{mc} > 0 && $dcols_required > $vars{mc})); - my $rows = $rows_required + $vars{ha}; - my $cols = ($dcols_required * ($vars{seplen} + abs $vars{block})) - $vars{seplen}; - if (_match_tmux()) { - # int( ($screenWidth + $vars{seplen}) / ($vars{seplen} + abs $vars{block}) ); - my ($pos_flag, $before); - if ($integration_position eq 'left') { - $pos_flag = 'h'; - $before = 1; - } - elsif ($integration_position eq 'top') { - $pos_flag = 'v'; - $before = 1; - } - elsif ($integration_position eq 'right') { - $pos_flag = 'h'; - } - else { - $pos_flag = 'v'; - } - my @cmd = "joinp -d$pos_flag -s $ENV{TMUX_PANE} -t $vars{irssienv}{tmux_pane}"; - push @cmd, "swapp -d -t $ENV{TMUX_PANE} -s $vars{irssienv}{tmux_pane}" - if $before; - $cols = max($cols, 2); - $rows = max($rows, 2); - - safe_qx("tmux " . (join " \\\; ", @cmd) . " 2>&1"); - } - else { - $resized = 1; - #safe_qx("resize -s $screenHeight $cols 2>&1") - # if $cols > 0; - } - $one_shot_integration++; - if ($resized == 1) { - handle_resize(); - resize_integration(); - } - } - elsif ($one_shot_integration == 2) { - resize_integration(1); - } - } - - sub resize_integration { - return unless $one_shot_integration; - return unless ($one_shot_resize//0) < 0 || shift; - my $nrows = $screenHeight - $vars{ha}; - my $ncols = ($vars{seplen} + abs $vars{block}) ? int( ($screenWidth + $vars{seplen}) / ($vars{seplen} + abs $vars{block}) ) : 0; - my $items = ($show_title_bar ? 1 : 0) + @{$vars{win}//[]}; - my $dcols_required = $nrows ? (int($items/$nrows) + !!($items%$nrows)) : 0; - my $rows_required = $ncols ? int($items/$ncols) + !!($items%$ncols) : 0; - $rows_required = abs $vars{ml} - if ($vars{ml} < 0 || ($vars{ml} > 0 && $rows_required > $vars{ml})); - $dcols_required = abs $vars{mc} - if ($vars{mc} < 0 || ($vars{mc} > 0 && $dcols_required > $vars{mc})); - my $rows = $rows_required + $vars{ha}; - my $cols = ($dcols_required * ($vars{seplen} + abs $vars{block})) - $vars{seplen}; - if (_match_tmux()) { - my $pos_flag; - my $before = 0; - if ($integration_position eq 'left') { - $pos_flag = 'h'; - $before = 1; - } - elsif ($integration_position eq 'top') { - $pos_flag = 'v'; - $before = 1; - } - elsif ($integration_position eq 'right') { - $pos_flag = 'h'; - } - else { - $pos_flag = 'v'; - } - my @cmd; - # hard tmux limits - $cols = max($cols, 2); - $rows = max($rows, 2); - if ($pos_flag eq 'h' && $cols != $screenWidth) { - my $change = $screenWidth - $cols; - my $dir = ($before ^ ($change<0)) ? 'L' : 'R'; - push @cmd, "resizep -$dir -t $ENV{TMUX_PANE} @{[abs $change]}"; - #push @cmd, "resizep -x $cols -t $ENV{TMUX_PANE}"; - $one_shot_resize = 1; - } - if ($pos_flag eq 'v' && $rows != $screenHeight) { - #push @cmd, "resizep -y $rows -t $ENV{TMUX_PANE}"; - my $change = $screenHeight - $rows; - my $dir = ($before ^ ($change<0)) ? 'U' : 'D'; - push @cmd, "resizep -$dir -t $ENV{TMUX_PANE} @{[abs $change]}"; - $one_shot_resize = 1; - } - - safe_qx("tmux " . (join " \\\; ", @cmd) . " 2>&1") - if @cmd; - } - else { - $cols = max($cols, 1); - $rows = max($rows, 1); - unless ($nrows > $ncols) { # line layout - if ($rows != $screenHeight) { - safe_qx("resize -s $rows $screenWidth 2>&1"); - $one_shot_resize = 1; - } - } - else { - if ($cols != $screenWidth) { - safe_qx("resize -s $screenHeight $cols 2>&1"); - $one_shot_resize = 1; - } - } - } - if ($resized == 1) { - handle_resize(); - } - } - - sub init_integration { - return unless $one_shot_integration; - if (_match_tmux()) { - } - else { - } - safe_print("\e]2;".(uc ::setc())."\e\\"); - } - - sub main { - require Getopt::Std; - my %opts; - Getopt::Std::getopts('1p:', \%opts); - my $one_shot = $opts{1}; - $integration_position = $opts{p}; - $one_shot_integration = 0+!!$one_shot; - #shift if @_ && $_[0] eq '--'; - &init; - $show_title_bar = 0 if $ENV{AWL_NOTITLE}; - init_integration(); - until ($got_int) { - $timeout = undef; - if ($resized) { - if ($resized == 1) { - $timeout = 1; - $resized++; - } - else { - handle_resize(); - resize_integration(); - } - } - unless ($sock || $timeout) { - connect_it(); - } - $timeout ||= RECONNECT_TIME unless $sock; - update_screen() if $disp_update; - SELECT: while (my @read = $loop->can_read($timeout)) { - for my $fh (@read) { - if ($fh == \*STDIN) { - if (read STDIN, my $buf, BLOCK_SIZE) { - do { - $keybuf .= $buf; - } while read STDIN, $buf, BLOCK_SIZE; - } - else { - $got_int = 1; - last SELECT; - } - } - else { - if ($fh->read(my $buf, BLOCK_SIZE)) { - do { - $rcvbuf .= $buf; - } while $fh->read($buf, BLOCK_SIZE); - } - else { - $disp_update = 1; - remove_conn($fh); - if ($one_shot) { - $got_int = 1; - last SELECT; - } - $timeout ||= RECONNECT_TIME; - } - } - } - $disp_update |= process_recv() if length $rcvbuf; - process_keys() if length $keybuf; - check_integration() if $one_shot; - update_screen() if $disp_update; - } - continue { - } - } - end_prog(); - } -} - -1; - -# Changelog -# ========= -# 1.5 - improve compat. with sideways splits -# -# 1.4 -# - fix line wrapping in some themes, reported by justanotherbody -# - fix named window key detection, reported by madduck -# - make title (in viewer and shared_sbar) configurable -# -# 1.3 - workaround for irssi issue #572 -# 1.2 - new format to choose abbreviation character -# 1.1 - infinite loop on shortening certain window names reported by Kalan -# -# 1.0 -# - new awl_viewer_launch setting and an array of related settings -# - fixed regression bug /exec -interactive -# - fixed some warnings in perl 5.10 reported by kl3 -# - workaround for crash due to infinite recursion in irssi's Perl -# error handling -# -# 0.9 -# - fix endless loop in awin detection code! -# - correct colour swap in awl_viewer -# - fix passing of alternate socket path to the viewer -# - potential undefinedness in mouse refnum hinted at by Canopus -# - fixed regression bug /exec -interactive -# - add case-insensitive modifier to awl_sort -# - run custom_xform on awl_prefer_name also -# - avoid inconsistent active window state after awin detection -# reported by ss -# - revert %9-hack in the viewer prompted by discussion with pierrot -# - fix new warning in perl 5.22 -# -# 0.8 -# - replace fifo mode with external viewer script -# - remove bundled cpan modules -# - work around bogus irssi warning -# - improve mouse support -# - workaround for broken cumode in irssi 0.8.15 -# - fix handling of non-meta windows (uninitialized warning) -# - add 256 colour support, strip true colour codes -# - fix totally bogus $N padding reported by Ed S. -# - make /window goto #name mappings work but ignore non-existant ones -# - improve incomplete reads reported by bcode -# - fix single % in awl_viewer reported by bcode -# - add support for key bindings by nike and ferret -# - coerce utf8 key binds -# - add settings: custom_xform, last_line_shade, hide_name_data -# - abbreviations were broken in some cases -# - fix some misuse of / as cmdchar in mouse script reported by bcode -# - add shared status bar mode -# - ${type} variables for custom_xform setting -# - crash if custom_xform had runtime error -# - update sorting documentation -# - fix odd case in size calculation noted by lasers -# - add missing font styles to the viewer reported by ishanyx -# - add italic -# -# 0.7g -# - remove screen support and replace it with fifo support -# - add double-width support to the shortener -# - correct documentation regarding $T vs. display_header -# - add missing refresh for window item changed (thanks vague) -# - add visible windows -# - add exemptions for active window -# - workaround for hiding the window changes from trackbar -# - hack to force 16colours in screen mode -# - remember last window (reported by earthnative) -# - wrong window focus on new queries (reported by emsid) -# - dataloss bug on trying to remember last window -# -# 0.6d+ -# - add support for network headers -# - fixed regression bug /exec -interactive -# -# 0.6ca+ -# - add screen support (from nicklist.pl) -# - names can now have a max length and window names can be used -# - fixed a bug with block display in screen mode and status bar mode -# - added space handling to ir_fe and removed it again -# - now handling formats on my own -# - started to work on $tag display -# - added warning about missing sb_act_none abstract leading to -# - display*active settings -# - added warning about the bug in awl_display_(no)key_active settings -# - mouse hack -# -# 0.5d -# - add setting to also hide the last status bar if empty (awl_all_disable) -# - reverted to old utf8 code to also calculate broken utf8 length correctly -# - simplified dealing with status bars in wlreset -# - added a little tweak for the renamed term_type somewhere after Irssi 0.8.9 -# - fixed bug in handling channel #$$ -# - reset background colour at the beginning of an entry -# -# 0.4d -# - fixed order of disabling status bars -# - several attempts at special chars, without any real success -# and much more weird new bugs caused by this -# - setting to specify sort order -# - reduced timeout values -# - added awl_hide_data -# - make it so the dynamic sub is actually deleted -# - fix a bug with removing of the last separator -# - take into consideration parse_special -# -# 0.3b -# - automatically kill old status bars -# - reset on /reload -# - position/placement settings -# -# 0.2 -# - automated retrieval of key bindings (thanks grep.pl authors) -# - improved removing of status bars -# - got rid of status chop -# -# 0.1 -# - Based on chanact.pl which was apparently based on lightbar.c and -# nicklist.pl with various other ideas from random scripts. diff --git a/.irssi/scripts/autoaway.pl b/.irssi/scripts/autoaway.pl deleted file mode 100644 index ef3c485..0000000 --- a/.irssi/scripts/autoaway.pl +++ /dev/null @@ -1,133 +0,0 @@ -# /AUTOAWAY <n> - Mark user away after <n> seconds of inactivity -# /AWAY - play nice with autoaway -# New, brighter, whiter version of my autoaway script. Actually works :) -# (c) 2000 Larry Daffner (vizzie@airmail.net) -# You may freely use, modify and distribute this script, as long as -# 1) you leave this notice intact -# 2) you don't pretend my code is yours -# 3) you don't pretend your code is mine -# -# share and enjoy! - -# A simple script. /autoaway <n> will mark you as away automatically if -# you have not typed any commands in <n> seconds. (<n>=0 disables the feature) -# It will also automatically unmark you away the next time you type a command. -# Note that using the /away command will disable the autoaway mechanism, as -# well as the autoreturn. (when you unmark yourself, the autoaway wil -# restart again) - -# Thanks to Adam Monsen for multiserver and config file fix - -use strict; -use Irssi; -use Irssi::Irc; - -use vars qw($VERSION %IRSSI); -$VERSION = "0.4"; -%IRSSI = ( - authors => 'Larry "Vizzie" Daffner', - contact => 'vizzie@airmail.net', - name => 'Automagic away setting', - description => 'Automatically goes away after defined inactivity', - license => 'BSD', - url => 'http://www.flamingpackets.net/~vizzie/irssi/', - changed => 'Tue Apr 26 19:30:00 CDT 2016', - changes => 'Applied multiserver/store config patch from Adam Monsen' -); - -my ($autoaway_sec, $autoaway_to_tag, $autoaway_state); -$autoaway_state = 0; - -# -# /AUTOAWAY - set the autoaway timeout -# -sub cmd_autoaway { - my ($data, $server, $channel) = @_; - - if (!($data =~ /^[0-9]+$/)) { - Irssi::print("autoaway: usage: /autoaway <seconds>"); - return 1; - } - - $autoaway_sec = $data; - - if ($autoaway_sec) { - Irssi::settings_set_int("autoaway_timeout", $autoaway_sec); - Irssi::print("autoaway timeout set to $autoaway_sec seconds"); - } else { - Irssi::print("autoway disabled"); - } - - if (defined($autoaway_to_tag)) { - Irssi::timeout_remove($autoaway_to_tag); - $autoaway_to_tag = undef; - } - - if ($autoaway_sec) { - $autoaway_to_tag = - Irssi::timeout_add($autoaway_sec*1000, "auto_timeout", ""); - } -} - -# -# away = Set us away or back, within the autoaway system -sub cmd_away { - my ($data, $server, $channel) = @_; - - if ($data eq "") { - $autoaway_state = 0; - } else { - if ($autoaway_state eq 0) { - Irssi::timeout_remove($autoaway_to_tag); - $autoaway_to_tag = undef; - $autoaway_state = 2; - } - } -} - -sub auto_timeout { - my ($data, $server) = @_; - - # we're in the process.. don't touch anything. - $autoaway_state = 3; - foreach my $server (Irssi::servers()) { - $server->command("/AWAY autoaway after $autoaway_sec seconds"); - } - - Irssi::timeout_remove($autoaway_to_tag); - $autoaway_state = 1; -} - -sub reset_timer { - if ($autoaway_state eq 1) { - $autoaway_state = 3; - foreach my $server (Irssi::servers()) { - $server->command("/AWAY"); - } - - $autoaway_state = 0; - } - if ($autoaway_state eq 0) { - if (defined($autoaway_to_tag)) { - Irssi::timeout_remove($autoaway_to_tag); - $autoaway_to_tag = undef(); - } - if ($autoaway_sec) { - $autoaway_to_tag = Irssi::timeout_add($autoaway_sec*1000 - , "auto_timeout", ""); - } - } -} - -Irssi::settings_add_int("misc", "autoaway_timeout", 0); - -my $autoaway_default = Irssi::settings_get_int("autoaway_timeout"); -if ($autoaway_default) { - $autoaway_to_tag = - Irssi::timeout_add($autoaway_default*1000, "auto_timeout", ""); - -} - -Irssi::command_bind('autoaway', 'cmd_autoaway'); -Irssi::command_bind('away', 'cmd_away'); -Irssi::signal_add('send command', 'reset_timer'); diff --git a/.irssi/scripts/autorun/adv_windowlist.pl b/.irssi/scripts/autorun/adv_windowlist.pl deleted file mode 120000 index d210a5c..0000000 --- a/.irssi/scripts/autorun/adv_windowlist.pl +++ /dev/null @@ -1 +0,0 @@ -../adv_windowlist.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/autoaway.pl b/.irssi/scripts/autorun/autoaway.pl deleted file mode 120000 index a6c9910..0000000 --- a/.irssi/scripts/autorun/autoaway.pl +++ /dev/null @@ -1 +0,0 @@ -../autoaway.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/chansort.pl b/.irssi/scripts/autorun/chansort.pl deleted file mode 120000 index 8b25183..0000000 --- a/.irssi/scripts/autorun/chansort.pl +++ /dev/null @@ -1 +0,0 @@ -../chansort.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/dispatch.pl b/.irssi/scripts/autorun/dispatch.pl deleted file mode 120000 index fbc8677..0000000 --- a/.irssi/scripts/autorun/dispatch.pl +++ /dev/null @@ -1 +0,0 @@ -../dispatch.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/go.pl b/.irssi/scripts/autorun/go.pl deleted file mode 120000 index c516cee..0000000 --- a/.irssi/scripts/autorun/go.pl +++ /dev/null @@ -1 +0,0 @@ -../go.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/hilightwin.pl b/.irssi/scripts/autorun/hilightwin.pl deleted file mode 120000 index fb9568b..0000000 --- a/.irssi/scripts/autorun/hilightwin.pl +++ /dev/null @@ -1 +0,0 @@ -../hilightwin.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/nickcolor.pl b/.irssi/scripts/autorun/nickcolor.pl deleted file mode 120000 index f4f7c6f..0000000 --- a/.irssi/scripts/autorun/nickcolor.pl +++ /dev/null @@ -1 +0,0 @@ -../nickcolor.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/recentdepart.pl b/.irssi/scripts/autorun/recentdepart.pl deleted file mode 120000 index cafd41b..0000000 --- a/.irssi/scripts/autorun/recentdepart.pl +++ /dev/null @@ -1 +0,0 @@ -../recentdepart.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/splitlong.pl b/.irssi/scripts/autorun/splitlong.pl deleted file mode 120000 index f2fa101..0000000 --- a/.irssi/scripts/autorun/splitlong.pl +++ /dev/null @@ -1 +0,0 @@ -../splitlong.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/tmux_away.pl b/.irssi/scripts/autorun/tmux_away.pl deleted file mode 120000 index 70df40e..0000000 --- a/.irssi/scripts/autorun/tmux_away.pl +++ /dev/null @@ -1 +0,0 @@ -../tmux_away.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/trackbar.pl b/.irssi/scripts/autorun/trackbar.pl deleted file mode 120000 index 8c5a483..0000000 --- a/.irssi/scripts/autorun/trackbar.pl +++ /dev/null @@ -1 +0,0 @@ -../trackbar.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/twtopic.pl b/.irssi/scripts/autorun/twtopic.pl deleted file mode 120000 index a283269..0000000 --- a/.irssi/scripts/autorun/twtopic.pl +++ /dev/null @@ -1 +0,0 @@ -../twtopic.pl
\ No newline at end of file diff --git a/.irssi/scripts/autorun/usercount.pl b/.irssi/scripts/autorun/usercount.pl deleted file mode 120000 index 1afd2ea..0000000 --- a/.irssi/scripts/autorun/usercount.pl +++ /dev/null @@ -1 +0,0 @@ -../usercount.pl
\ No newline at end of file diff --git a/.irssi/scripts/chansort.pl b/.irssi/scripts/chansort.pl deleted file mode 100644 index 814d041..0000000 --- a/.irssi/scripts/chansort.pl +++ /dev/null @@ -1,103 +0,0 @@ -#! /usr/bin/perl -# -# $Id: chansort.pl,v 1.4 2004/11/02 22:52:33 peder Exp $ -# -# Copyright (C) 2004 by Peder Stray <peder@gzip.ninja.no> -# - -use strict; -use Irssi; -use Irssi::Irc; - -# ======[ Script Header ]=============================================== - -use vars qw{$VERSION %IRSSI}; -($VERSION) = '$Revision: 1.4 $' =~ / (\d+\.\d+) /; -%IRSSI = ( - name => 'chansort', - authors => 'Peder Stray', - contact => 'peder@ninja.no', - url => 'http://ninja.no/irssi/chansort.pl', - license => 'GPL', - description => 'Sort all channel and query windows', - ); - -# ======[ Hooks ]======================================================= - -# --------[ sig_sort_trigger ]------------------------------------------ - -sub sig_sort_trigger { - return unless Irssi::settings_get_bool('chansort_autosort'); - cmd_chansort(); -} - -# ======[ Commands ]==================================================== - -# --------[ CHANSORT ]-------------------------------------------------- - -# Usage: /CHANSORT -sub cmd_chansort { - my(@windows); - my($minwin); - - for my $win (Irssi::windows()) { - my $act = $win->{active}; - my $key; - - if ($act->{type} eq 'CHANNEL') { - $key = "C".$act->{server}{tag}.' '.substr($act->{visible_name}, 1); - } - elsif ($act->{type} eq 'QUERY') { - $key = "Q".$act->{server}{tag}.' '.$act->{visible_name}; - } - else { - next; - } - if (!defined($minwin) || $minwin > $win->{refnum}) { - $minwin = $win->{refnum}; - } - push @windows, [ lc $key, $win ]; - - } - - for (sort {$a->[0] cmp $b->[0]} @windows) { - my($key,$win) = @$_; - my($act) = $win->{active}; - -# printf("win[%d->%d]: t[%s] [%s] [%s] {%s}\n", -# $win->{refnum}, -# $minwin, -# $act->{type}, -# $act->{visible_name}, -# $act->{server}{tag}, -# $key, -# ); - - $win->command("window move $minwin"); - $minwin++; - } -} - -# ======[ Setup ]======================================================= - -# --------[ Register commands ]----------------------------------------- - -Irssi::command_bind('chansort', 'cmd_chansort'); - -# --------[ Register settings ]----------------------------------------- - -Irssi::settings_add_bool('chansort', 'chansort_autosort', 0); - -# --------[ Register signals ]------------------------------------------ - -Irssi::signal_add_last('window item name changed', 'sig_sort_trigger'); -Irssi::signal_add_last('channel created', 'sig_sort_trigger'); -Irssi::signal_add_last('query created', 'sig_sort_trigger'); - -# ======[ END ]========================================================= - -# Local Variables: -# header-initial-hide: t -# mode: header-minor -# end: - diff --git a/.irssi/scripts/dispatch.pl b/.irssi/scripts/dispatch.pl deleted file mode 100644 index 6050520..0000000 --- a/.irssi/scripts/dispatch.pl +++ /dev/null @@ -1,26 +0,0 @@ -use strict; -use warnings; -use Irssi; -use Irssi::Irc; -use vars qw($VERSION %IRSSI); - -$VERSION = "0.0.2"; -%IRSSI = ( - authors => "Sebastian 'yath' Schmidt", - contact => "yathen\@web.de", - name => "Command dispatcher", - description => "This scripts sends unknown commands to the server", - license => "GNU GPLv2", - changed => "Tue Mar 5 14:55:29 CET 2002", -); - -sub event_default_command { - my ($command, $server) = @_; - return if (Irssi::settings_get_bool("dispatch_unknown_commands") == 0 - || !$server); - $server->send_raw($command); - Irssi::signal_stop(); -} - -Irssi::settings_add_bool("misc", "dispatch_unknown_commands", 1); -Irssi::signal_add_first("default command", "event_default_command"); diff --git a/.irssi/scripts/go.pl b/.irssi/scripts/go.pl deleted file mode 100644 index 0b0a2a2..0000000 --- a/.irssi/scripts/go.pl +++ /dev/null @@ -1,105 +0,0 @@ -use strict; -use vars qw($VERSION %IRSSI); -use Irssi; -use Irssi::Irc; - -# Usage: -# /script load go.pl -# If you are in #irssi you can type /go #irssi or /go irssi or even /go ir ... -# also try /go ir<tab> and /go <tab> (that's two spaces) -# -# The following settings exist: -# -# /SET go_match_case_sensitive [ON|OFF] -# Match window/item names sensitively (the default). Turning this off -# means e.g. "/go foo" would jump to a window named "Foobar", too. -# -# /SET go_match_anchored [ON|OFF] -# Match window/names only at the start of the word (the default). Turning -# this off will mean that strings can match anywhere in the window/names. -# The leading '#' of channel names is optional either way. -# -# /SET go_complete_case_sensitive [ON|OFF] -# When using tab-completion, match case-insensitively (the default). -# Turning this on means that "/go foo<tab>" will *not* suggest "Foobar". -# -# /SET go_complete_anchored [ON|OFF] -# Match window/names only at the start of the word. The default is 'off', -# which causes completion to match anywhere in the window/names during -# completion. The leading '#' of channel names is optional either way. -# - -$VERSION = '1.1'; - -%IRSSI = ( - authors => 'nohar', - contact => 'nohar@freenode', - name => 'go to window', - description => 'Implements /go command that activates a window given a name/partial name. It features a nice completion.', - license => 'GPLv2 or later', - changed => '2017-02-02' -); - -sub _make_regexp { - my ($name, $ci, $aw) = @_; - my $re = "\Q${name}\E"; - $re = "(?i:$re)" unless $ci; - $re = "^#?$re" if $aw; - return $re; -} - -sub signal_complete_go { - my ($complist, $window, $word, $linestart, $want_space) = @_; - my $channel = $window->get_active_name(); - my $k = Irssi::parse_special('$k'); - - return unless ($linestart =~ /^\Q${k}\Ego\b/i); - - my $re = _make_regexp($word, - Irssi::settings_get_bool('go_complete_case_sensitive'), - Irssi::settings_get_bool('go_complete_anchored')); - @$complist = (); - foreach my $w (Irssi::windows) { - my $name = $w->get_active_name(); - if ($word ne "") { - if ($name =~ $re) { - push(@$complist, $name) - } - } else { - push(@$complist, $name); - } - } - Irssi::signal_stop(); -}; - -sub cmd_go -{ - my($chan,$server,$witem) = @_; - - $chan =~ s/ *//g; - my $re = _make_regexp($chan, - Irssi::settings_get_bool('go_match_case_sensitive'), - Irssi::settings_get_bool('go_match_anchored')); - - foreach my $w (Irssi::windows) { - my $name = $w->get_active_name(); - if ($name =~ $re) { - $w->set_active(); - return; - } - } -} - -Irssi::command_bind("go", "cmd_go"); -Irssi::signal_add_first('complete word', 'signal_complete_go'); -Irssi::settings_add_bool('go', 'go_match_case_sensitive', 1); -Irssi::settings_add_bool('go', 'go_complete_case_sensitive', 0); -Irssi::settings_add_bool('go', 'go_match_anchored', 1); -Irssi::settings_add_bool('go', 'go_complete_anchored', 0); - -# Changelog -# -# 2017-02-02 1.1 martin f. krafft <madduck@madduck.net> -# - made case-sensitivity of match configurable -# - made anchoring of search strings configurable -# diff --git a/.irssi/scripts/hilightwin.pl b/.irssi/scripts/hilightwin.pl deleted file mode 100644 index 3bb2863..0000000 --- a/.irssi/scripts/hilightwin.pl +++ /dev/null @@ -1,85 +0,0 @@ -# -# Print hilighted messages & private messages to window named "hilight" for -# irssi 0.7.99 by Timo Sirainen -# -# Modded a tiny bit by znx to stop private messages entering the hilighted -# window (can be toggled) and to put up a timestamp. -# -# Changed a little by rummik to optionally show network name. Enable with -# `/set hilightwin_shownetwork on` -# - -use strict; -use Irssi; -use POSIX; -use vars qw($VERSION %IRSSI); - -$VERSION = "1.00"; -%IRSSI = ( - authors => "Timo \'cras\' Sirainen, Mark \'znx\' Sangster, Kimberly \'rummik\' Zick", - contact => "tss\@iki.fi, znxster\@gmail.com, git\@zick.kim", - name => "hilightwin", - description => "Print hilighted messages to window named \"hilight\"", - license => "Public Domain", - url => "http://irssi.org/", - changed => "Thu Apr 6 15:30:25 EDT 2017" -); - -sub is_ignored { - my ($dest) = @_; - - my @ignore = split(' ', Irssi::settings_get_str('hilightwin_ignore_targets')); - return 0 if (!@ignore); - - my %targets = map { $_ => 1 } @ignore; - - return 1 if exists($targets{"*"}); - return 1 if exists($targets{$dest->{target}}); - - if ($dest->{server}) { - my $tag = $dest->{server}->{tag}; - return 1 if exists($targets{$tag . "/*"}); - return 1 if exists($targets{$tag . "/" . $dest->{target}}); - } - - return 0; -} - -sub sig_printtext { - my ($dest, $text, $stripped) = @_; - - my $opt = MSGLEVEL_HILIGHT; - my $shownetwork = Irssi::settings_get_bool('hilightwin_show_network'); - - if(Irssi::settings_get_bool('hilightwin_showprivmsg')) { - $opt = MSGLEVEL_HILIGHT|MSGLEVEL_MSGS; - } - - if( - ($dest->{level} & ($opt)) && - ($dest->{level} & MSGLEVEL_NOHILIGHT) == 0 && - (!is_ignored($dest)) - ) { - my $window = Irssi::window_find_name('hilight'); - - if ($dest->{level} & MSGLEVEL_PUBLIC) { - $text = $dest->{target}.": ".$text; - $text = $dest->{server}->{tag} . "/" . $text if ($shownetwork); - } elsif ($shownetwork) { - $text = $dest->{server}->{tag} . ": " . $text; - } - $text =~ s/%/%%/g; - $window->print($text, MSGLEVEL_CLIENTCRAP) if ($window); - } -} - -my $window = Irssi::window_find_name('hilight'); -Irssi::print("Create a window named 'hilight'") if (!$window); - -Irssi::settings_add_bool('hilightwin','hilightwin_showprivmsg',1); -Irssi::settings_add_str('hilightwin', 'hilightwin_ignore_targets', ''); -Irssi::settings_add_bool('hilightwin','hilightwin_show_network', 0); - -Irssi::signal_add('print text', 'sig_printtext'); - -# vim:set ts=4 sw=4 et: diff --git a/.irssi/scripts/nickcolor.pl b/.irssi/scripts/nickcolor.pl deleted file mode 100644 index 95b7b63..0000000 --- a/.irssi/scripts/nickcolor.pl +++ /dev/null @@ -1,253 +0,0 @@ -use strict; -use Irssi 20020101.0250 (); -use vars qw($VERSION %IRSSI); -$VERSION = "2.1"; -%IRSSI = ( - authors => "Timo Sirainen, Ian Peters, David Leadbeater, Bruno Cattáneo", - contact => "tss\@iki.fi", - name => "Nick Color", - description => "assign a different color for each nick", - license => "Public Domain", - url => "http://irssi.org/", - changed => "Mon 08 Jan 21:28:53 BST 2018", -); - -# Settings: -# nickcolor_colors: List of color codes to use. -# e.g. /set nickcolor_colors 2 3 4 5 6 7 9 10 11 12 13 -# (avoid 8, as used for hilights in the default theme). -# -# nickcolor_enable_prefix: Enables prefix for same nick. -# -# nickcolor_enable_truncate: Enables nick truncation. -# -# nickcolor_prefix_text: Prefix text for succesive messages. -# e.g. /set nickcolor_prefix_text - -# -# nickcolor_truncate_value: Truncate nick value. -# e.g. /set nickcolor_truncate_value -7 -# This will truncate nicknames at 7 characters and make them right aligned - -my %saved_colors; -my %session_colors = {}; -my %saved_nicks; # To store each channel's last nickname - -sub load_colors { - open my $color_fh, "<", "$ENV{HOME}/.irssi/saved_colors"; - while (<$color_fh>) { - chomp; - my($nick, $color) = split ":"; - $saved_colors{$nick} = $color; - } -} - -sub save_colors { - open COLORS, ">", "$ENV{HOME}/.irssi/saved_colors"; - - foreach my $nick (keys %saved_colors) { - print COLORS "$nick:$saved_colors{$nick}\n"; - } - - close COLORS; -} - -# If someone we've colored (either through the saved colors, or the hash -# function) changes their nick, we'd like to keep the same color associated -# with them (but only in the session_colors, ie a temporary mapping). - -sub sig_nick { - my ($server, $newnick, $nick, $address) = @_; - my $color; - - $newnick = substr ($newnick, 1) if ($newnick =~ /^:/); - - if ($color = $saved_colors{$nick}) { - $session_colors{$newnick} = $color; - } elsif ($color = $session_colors{$nick}) { - $session_colors{$newnick} = $color; - } -} - -# This gave reasonable distribution values when run across -# /usr/share/dict/words - -sub simple_hash { - my ($string) = @_; - chomp $string; - my @chars = split //, $string; - my $counter; - - foreach my $char (@chars) { - $counter += ord $char; - } - - my @colors = split / /, Irssi::settings_get_str('nickcolor_colors'); - $counter = $colors[$counter % @colors]; - - return $counter; -} - -# process public (others) messages -sub sig_public { - my ($server, $msg, $nick, $address, $target) = @_; - - my $enable_prefix = Irssi::settings_get_bool('nickcolor_enable_prefix'); - my $enable_truncate = Irssi::settings_get_bool('nickcolor_enable_truncate'); - my $prefix_text = Irssi::settings_get_str('nickcolor_prefix_text'); - my $truncate_value = Irssi::settings_get_int('nickcolor_truncate_value'); - - # Reference for server/channel - my $tagtarget = "$server->{tag}/$target"; - - # Set default nick truncate value to 0 if option is disabled - $truncate_value = 0 if (!$enable_truncate); - - # Has the user assigned this nick a color? - my $color = $saved_colors{$nick}; - - # Have -we- already assigned this nick a color? - if (!$color) { - $color = $session_colors{$nick}; - } - - # Let's assign this nick a color - if (!$color) { - $color = simple_hash $nick; - $session_colors{$nick} = $color; - } - - $color = sprintf "\003%02d", $color; - - # Optional: We check if it's the same nickname for current target - if ($saved_nicks{$tagtarget} eq $nick && $enable_prefix) - { - # Grouped message - Irssi::command('/^format pubmsg ' . $prefix_text . '$1'); - } - else - { - # Normal message - Irssi::command('/^format pubmsg {pubmsgnick $2 {pubnick ' . $color . '$[' . $truncate_value . ']0}}$1'); - - # Save nickname for next message - $saved_nicks{$tagtarget} = $nick; - } - -} - -# process public (me) messages -sub sig_me { - my ($server, $msg, $target) = @_; - my $nick = $server->{nick}; - - my $enable_prefix = Irssi::settings_get_bool('nickcolor_enable_prefix'); - my $enable_truncate = Irssi::settings_get_bool('nickcolor_enable_truncate'); - my $prefix_text = Irssi::settings_get_str('nickcolor_prefix_text'); - my $truncate_value = Irssi::settings_get_int('nickcolor_truncate_value'); - - # Reference for server/channel - my $tagtarget = "$server->{tag}/$target"; - - # Set default nick truncate value to 0 if option is disabled - $truncate_value = 0 if (!$enable_truncate); - - # Optional: We check if it's the same nickname for current target - if ($saved_nicks{$tagtarget} eq $nick && $enable_prefix) - { - # Grouped message - Irssi::command('/^format own_msg ' . $prefix_text . '$1'); - } - else - { - # Normal message - Irssi::command('/^format own_msg {ownmsgnick $2 {ownnick $[' . $truncate_value . ']0}}$1'); - - # Save nickname for next message - $saved_nicks{$tagtarget} = $nick; - } - -} - -# process public (others) actions -sub sig_action_public { - my ($server, $msg, $nick, $address, $target) = @_; - - my $enable_prefix = Irssi::settings_get_bool('nickcolor_enable_prefix'); - - # Reference for server/channel - my $tagtarget = "$server->{tag}/$target"; - - # Empty current target nick if prefix option is enabled - $saved_nicks{$tagtarget} = '' if ($enable_prefix); - -} - -# process public (me) actions -sub sig_action_me { - my ($server, $msg, $target) = @_; - my $nick = $server->{nick}; - - my $enable_prefix = Irssi::settings_get_bool('nickcolor_enable_prefix'); - - # Reference for server/channel - my $tagtarget = "$server->{tag}/$target"; - - # Empty current target nick if prefix option is enabled - $saved_nicks{$tagtarget} = '' if ($enable_prefix); - -} - -sub cmd_color { - my ($data, $server, $witem) = @_; - my ($op, $nick, $color) = split " ", $data; - - $op = lc $op; - - if (!$op) { - Irssi::print ("No operation given (save/set/clear/list/preview)"); - } elsif ($op eq "save") { - save_colors; - } elsif ($op eq "set") { - if (!$nick) { - Irssi::print ("Nick not given"); - } elsif (!$color) { - Irssi::print ("Color not given"); - } elsif ($color < 2 || $color > 14) { - Irssi::print ("Color must be between 2 and 14 inclusive"); - } else { - $saved_colors{$nick} = $color; - } - } elsif ($op eq "clear") { - if (!$nick) { - Irssi::print ("Nick not given"); - } else { - delete ($saved_colors{$nick}); - } - } elsif ($op eq "list") { - Irssi::print ("\nSaved Colors:"); - foreach my $nick (keys %saved_colors) { - Irssi::print (chr (3) . sprintf("%02d", $saved_colors{$nick}) . "$nick" . - chr (3) . "1 ($saved_colors{$nick})"); - } - } elsif ($op eq "preview") { - Irssi::print ("\nAvailable colors:"); - foreach my $i (2..14) { - Irssi::print (chr (3) . "$i" . "Color #$i"); - } - } -} - -load_colors; - -Irssi::settings_add_str('misc', 'nickcolor_colors', '2 3 4 5 6 7 9 10 11 12 13'); -Irssi::settings_add_bool('misc', 'nickcolor_enable_prefix', 0); -Irssi::settings_add_bool('misc', 'nickcolor_enable_truncate', 0); -Irssi::settings_add_str('misc', 'nickcolor_prefix_text' => '- '); -Irssi::settings_add_int('misc', 'nickcolor_truncate_value' => 0); -Irssi::command_bind('color', 'cmd_color'); - -Irssi::signal_add('message public', 'sig_public'); -Irssi::signal_add('message own_public', 'sig_me'); -Irssi::signal_add('message irc action', 'sig_action_public'); -Irssi::signal_add('message irc own_action', 'sig_action_me'); -Irssi::signal_add('event nick', 'sig_nick'); diff --git a/.irssi/scripts/old/nickcolor.pl.old b/.irssi/scripts/old/nickcolor.pl.old deleted file mode 100644 index ff9915d..0000000 --- a/.irssi/scripts/old/nickcolor.pl.old +++ /dev/null @@ -1,145 +0,0 @@ -use strict; -use Irssi 20020101.0250 (); -use vars qw($VERSION %IRSSI); -$VERSION = "2"; -%IRSSI = ( - authors => "Timo Sirainen, Ian Peters, David Leadbeater", - contact => "tss\@iki.fi", - name => "Nick Color", - description => "assign a different color for each nick", - license => "Public Domain", - url => "http://irssi.org/", - changed => "Sun 15 Jun 19:10:44 BST 2014", -); - -# Settings: -# nickcolor_colors: List of color codes to use. -# e.g. /set nickcolor_colors 2 3 4 5 6 7 9 10 11 12 13 -# (avoid 8, as used for hilights in the default theme). - -my %saved_colors; -my %session_colors = {}; - -sub load_colors { - open my $color_fh, "<", "$ENV{HOME}/.irssi/saved_colors"; - while (<$color_fh>) { - chomp; - my($nick, $color) = split ":"; - $saved_colors{$nick} = $color; - } -} - -sub save_colors { - open COLORS, ">", "$ENV{HOME}/.irssi/saved_colors"; - - foreach my $nick (keys %saved_colors) { - print COLORS "$nick:$saved_colors{$nick}\n"; - } - - close COLORS; -} - -# If someone we've colored (either through the saved colors, or the hash -# function) changes their nick, we'd like to keep the same color associated -# with them (but only in the session_colors, ie a temporary mapping). - -sub sig_nick { - my ($server, $newnick, $nick, $address) = @_; - my $color; - - $newnick = substr ($newnick, 1) if ($newnick =~ /^:/); - - if ($color = $saved_colors{$nick}) { - $session_colors{$newnick} = $color; - } elsif ($color = $session_colors{$nick}) { - $session_colors{$newnick} = $color; - } -} - -# This gave reasonable distribution values when run across -# /usr/share/dict/words - -sub simple_hash { - my ($string) = @_; - chomp $string; - my @chars = split //, $string; - my $counter; - - foreach my $char (@chars) { - $counter += ord $char; - } - - my @colors = split / /, Irssi::settings_get_str('nickcolor_colors'); - $counter = $colors[$counter % @colors]; - - return $counter; -} - -sub sig_public { - my ($server, $msg, $nick, $address, $target) = @_; - - # Has the user assigned this nick a color? - my $color = $saved_colors{$nick}; - - # Have -we- already assigned this nick a color? - if (!$color) { - $color = $session_colors{$nick}; - } - - # Let's assign this nick a color - if (!$color) { - $color = simple_hash $nick; - $session_colors{$nick} = $color; - } - - $color = sprintf "\003%02d", $color; - $server->command('/^format pubmsg {pubmsgnick $2 {pubnick ' . $color . '$0}}$1'); -} - -sub cmd_color { - my ($data, $server, $witem) = @_; - my ($op, $nick, $color) = split " ", $data; - - $op = lc $op; - - if (!$op) { - Irssi::print ("No operation given (save/set/clear/list/preview)"); - } elsif ($op eq "save") { - save_colors; - } elsif ($op eq "set") { - if (!$nick) { - Irssi::print ("Nick not given"); - } elsif (!$color) { - Irssi::print ("Color not given"); - } elsif ($color < 2 || $color > 14) { - Irssi::print ("Color must be between 2 and 14 inclusive"); - } else { - $saved_colors{$nick} = $color; - } - } elsif ($op eq "clear") { - if (!$nick) { - Irssi::print ("Nick not given"); - } else { - delete ($saved_colors{$nick}); - } - } elsif ($op eq "list") { - Irssi::print ("\nSaved Colors:"); - foreach my $nick (keys %saved_colors) { - Irssi::print (chr (3) . "$saved_colors{$nick}$nick" . - chr (3) . "1 ($saved_colors{$nick})"); - } - } elsif ($op eq "preview") { - Irssi::print ("\nAvailable colors:"); - foreach my $i (2..14) { - Irssi::print (chr (3) . "$i" . "Color #$i"); - } - } -} - -load_colors; - -Irssi::settings_add_str('misc', 'nickcolor_colors', '2 3 4 5 6 7 9 10 11 12 13'); -Irssi::command_bind('color', 'cmd_color'); - -Irssi::signal_add('message public', 'sig_public'); -Irssi::signal_add('event nick', 'sig_nick'); diff --git a/.irssi/scripts/old/trackbar22.pl.old b/.irssi/scripts/old/trackbar22.pl.old deleted file mode 100644 index 0d10882..0000000 --- a/.irssi/scripts/old/trackbar22.pl.old +++ /dev/null @@ -1,508 +0,0 @@ -# trackbar.pl -# -# This little script will do just one thing: it will draw a line each time you -# switch away from a window. This way, you always know just upto where you've -# been reading that window :) It also removes the previous drawn line, so you -# don't see double lines. -# -# redraw trackbar only works on irssi 0.8.17 or higher. -# -# -# Usage: -# -# The script works right out of the box, but if you want you can change -# the working by /set'ing the following variables: -# -# Setting: trackbar_style -# Description: This setting will be the color of your trackbar line. -# By default the value will be '%K', only Irssi color -# formats are allowed. If you don't know the color formats -# by heart, you can take a look at the formats documentation. -# You will find the proper docs on http://www.irssi.org/docs. -# -# Setting: trackbar_string -# Description: This is the string that your line will display. This can -# be multiple characters or just one. For example: '~-~-' -# The default setting is '-'. -# -# Setting: trackbar_use_status_window -# Description: If this setting is set to OFF, Irssi won't print a trackbar -# in the statuswindow -# -# Setting: trackbar_ignore_windows -# Description: A list of windows where no trackbar should be printed -# -# Setting: trackbar_print_timestamp -# Description: If this setting is set to ON, Irssi will print the formatted -# timestamp in front of the trackbar. -# -# Setting: trackbar_require_seen -# Description: Only clear the trackbar if it has been scrolled to. -# -# /mark is a command that will redraw the line at the bottom. -# -# Command: /trackbar, /trackbar goto -# Description: Jump to where the trackbar is, to pick up reading -# -# Command: /trackbar keep -# Description: Keep this window's trackbar where it is the next time -# you switch windows (then this flag is cleared again) -# -# Command: /mark, /trackbar mark -# Description: Remove the old trackbar and mark the bottom of this -# window with a new trackbar -# -# Command: /trackbar markvisible -# Description: Like mark for all visible windows -# -# Command: /trackbar markall -# Description: Like mark for all windows -# -# Command: /trackbar remove -# Description: Remove this window's trackbar -# -# Command: /trackbar removeall -# Description: Remove all windows' trackbars -# -# Command: /trackbar redraw -# Description: Force redraw of trackbars -# - - -# For bugreports and other improvements contact one of the authors. -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this script; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -# -## - -use strict; -use warnings; -use Irssi; -use Irssi::TextUI; -use Encode; - -use POSIX qw(strftime); -use vars qw($VERSION %IRSSI); - -$VERSION = "2.4"; # 1ca8fa9f28b9586 - -%IRSSI = ( - authors => 'Peter Leurs and Geert Hauwaerts', - contact => 'peter@pfoe.be', - patchers => 'Johan Kiviniemi (UTF-8), Uwe Dudenhoeffer (on-upgrade-remove-line)', - name => 'trackbar', - description => 'Shows a bar where you have last read a window.', - license => 'GNU General Public License', - url => 'http://www.pfoe.be/~peter/trackbar/', - commands => 'trackbar', -); - -## Comments and remarks. -# -# This script uses settings. -# Use /SET to change the value or /TOGGLE to switch it on or off. -# -# -# Tip: The command 'trackbar' is very usefull if you bind that to a key, -# so you can easily jump to the trackbar. Please see 'help bind' for -# more information about keybindings in Irssi. -# -# Command: /BIND meta2-P key F1 -# /BIND F1 command trackbar -# -## - -## Bugfixes and new items in this rewrite. -# -# * Remove all the trackbars before upgrading. -# * New setting trackbar_use_status_window to control the statuswindow trackbar. -# * New setting trackbar_print_timestamp to print a timestamp or not. -# * New command 'trackbar' to scroll up to the trackbar. -# * When resizing your terminal, Irssi will update all the trackbars to the new size. -# * When changing trackbar settings, change all the trackbars to the new settings. -# * New command 'trackbar mark' to draw a new trackbar (The old '/mark'). -# * New command 'trackbar markall' to draw a new trackbar in each window. -# * New command 'trackbar remove' to remove the trackbar from the current window. -# * New command 'trackbar removeall' to remove all the trackbars. -# * Don't draw a trackbar in empty windows. -# * Added a version check to prevent Irssi redraw errors. -# * Fixed a bookmark NULL versus 0 bug. -# * Fixed a remove-line bug in Uwe Dudenhoeffer his patch. -# * New command 'help trackbar' to display the trackbar commands. -# * Fixed an Irssi startup bug, now processing each auto-created window. -# -## - -## Known bugs and the todolist. -# -# Todo: * Instead of drawing a line, invert the line. -# -## - -sub cmd_help { - my ($args) = @_; - if ($args =~ /^trackbar *$/i) { - print CLIENTCRAP <<HELP -%9Syntax:%9 - -TRACKBAR -TRACKBAR GOTO -TRACKBAR KEEP -TRACKBAR MARK -TRACKBAR MARKVISIBLE -TRACKBAR MARKALL -TRACKBAR REMOVE -TRACKBAR REMOVEALL -TRACKBAR REDRAW - -%9Parameters:%9 - - GOTO: Jump to where the trackbar is, to pick up reading - KEEP: Keep this window's trackbar where it is the next time - you switch windows (then this flag is cleared again) - MARK: Remove the old trackbar and mark the bottom of this - window with a new trackbar - MARKVISIBLE: Like mark for all visible windows - MARKALL: Like mark for all windows - REMOVE: Remove this window's trackbar - REMOVEALL: Remove all windows' trackbars - REDRAW: Force redraw of trackbars - -%9Description:%9 - - Manage a trackbar. Without arguments, it will scroll up to the trackbar. - -%9Examples:%9 - - /TRACKBAR MARK - /TRACKBAR REMOVE -HELP - } -} - -Irssi::theme_register([ - 'trackbar_loaded', '%R>>%n %_Scriptinfo:%_ Loaded $0 version $1 by $2.', - 'trackbar_wrong_version', '%R>>%n %_Trackbar:%_ Please upgrade your client to 0.8.17 or above if you would like to use this feature of trackbar.', - 'trackbar_all_removed', '%R>>%n %_Trackbar:%_ All the trackbars have been removed.', - 'trackbar_not_found', '%R>>%n %_Trackbar:%_ No trackbar found in this window.', -]); - -my $old_irssi = Irssi::version < 20140701; -sub check_version { - if ($old_irssi) { - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_wrong_version'); - return; - } else { - return 1; - } -} - -sub is_utf8 { - lc Irssi::settings_get_str('term_charset') eq 'utf-8' -} - -my (%config, %keep_trackbar, %unseen_trackbar); - -sub remove_one_trackbar { - my $win = shift; - my $view = shift || $win->view; - my $line = $view->get_bookmark('trackbar'); - if (defined $line) { - my $bottom = $view->{bottom}; - $view->remove_line($line); - $win->command('^scrollback end') if $bottom && !$win->view->{bottom}; - $view->redraw; - } -} - -sub add_one_trackbar { - my $win = shift; - my $view = shift || $win->view; - $win->print(line($win->{width}), MSGLEVEL_NEVER); - $view->set_bookmark_bottom('trackbar'); - $unseen_trackbar{ $win->{_irssi} } = 1; - Irssi::signal_emit("window trackbar added", $win); - $view->redraw; -} - -sub update_one_trackbar { - my $win = shift; - my $view = shift || $win->view; - my $force = shift; - my $ignored = win_ignored($win, $view); - remove_one_trackbar($win, $view) - if $force || !defined $force || !$ignored; - add_one_trackbar($win, $view) - if $force || !$ignored; -} - -sub win_ignored { - my $win = shift; - my $view = shift || $win->view; - return 1 unless $view->{buffer}{lines_count}; - return 1 if $win->{name} eq '(status)' && !$config{use_status_window}; - no warnings 'uninitialized'; - return 1 if grep { $win->{name} eq $_ || $win->{refnum} eq $_ - || $win->get_active_name eq $_ } @{ $config{ignore_windows} }; - return 0; -} - -sub sig_window_changed { - my ($newwindow, $oldwindow) = @_; - return unless $oldwindow; - redraw_trackbars($newwindow); - trackbar_update_seen($newwindow); - return if delete $keep_trackbar{ $oldwindow->{_irssi} }; - trackbar_update_seen($oldwindow); - return if $config{require_seen} && $unseen_trackbar{ $oldwindow->{_irssi } }; - update_one_trackbar($oldwindow, undef, 0); -} - -sub trackbar_update_seen { - my $win = shift; - return unless $win; - return unless $unseen_trackbar{ $win->{_irssi} }; - - my $view = $win->view; - my $line = $view->get_bookmark('trackbar'); - unless ($line) { - delete $unseen_trackbar{ $win->{_irssi} }; - Irssi::signal_emit("window trackbar seen", $win); - return; - } - my $startline = $view->{startline}; - return unless $startline; - - if ($startline->{info}{time} < $line->{info}{time} - || $startline->{_irssi} == $line->{_irssi}) { - delete $unseen_trackbar{ $win->{_irssi} }; - Irssi::signal_emit("window trackbar seen", $win); - } -} - -sub screen_length; -{ local $@; - eval { require Text::CharWidth; }; - unless ($@) { - *screen_length = sub { Text::CharWidth::mbswidth($_[0]) }; - } - else { - *screen_length = sub { - my $temp = shift; - if (is_utf8()) { - Encode::_utf8_on($temp); - } - length($temp) - }; - } -} - -{ my %strip_table = ( - (map { $_ => '' } (split //, '04261537' . 'kbgcrmyw' . 'KBGCRMYW' . 'U9_8I:|FnN>#[' . 'pP')), - (map { $_ => $_ } (split //, '{}%')), - ); - sub c_length { - my $o = Irssi::strip_codes($_[0]); - $o =~ s/(%(%|Z.{6}|z.{6}|X..|x..|.))/exists $strip_table{$2} ? $strip_table{$2} : - $2 =~ m{x(?:0[a-f]|[1-6][0-9a-z]|7[a-x])|z[0-9a-f]{6}}i ? '' : $1/gex; - screen_length($o) - } -} - -sub line { - my ($width, $time) = @_; - my $string = $config{string}; - $string = ' ' unless length $string; - $time ||= time; - - Encode::_utf8_on($string); - my $length = c_length($string); - - my $format = ''; - if ($config{print_timestamp}) { - $format = $config{timestamp_str}; - $format =~ y/%/\01/; - $format =~ s/\01\01/%/g; - $format = strftime($format, localtime $time); - $format =~ y/\01/%/; - } - - my $times = $width / $length; - $times += 1 if $times != int $times; - $format .= $config{style}; - $width -= c_length($format); - $string x= $times; - chop $string while length $string && c_length($string) > $width; - return $format . $string; -} - -sub remove_all_trackbars { - for my $window (Irssi::windows) { - next unless ref $window; - remove_one_trackbar($window); - } -} - -sub UNLOAD { - remove_all_trackbars(); -} - -sub redraw_trackbars { - return unless check_version(); - for my $win (@_ ? @_ : Irssi::windows) { - next unless ref $win; - my $view = $win->view; - my $line = $view->get_bookmark('trackbar'); - next unless $line; - my $bottom = $view->{bottom}; - $win->print_after($line, MSGLEVEL_NEVER, line($win->{width}, $line->{info}{time}), - $line->{info}{time}); - $view->set_bookmark('trackbar', $win->last_line_insert); - $view->redraw; - $view->remove_line($line); - $win->command('^scrollback end') if $bottom && !$win->view->{bottom}; - $view->redraw; - } -} - -sub goto_trackbar { - my $win = Irssi::active_win; - my $line = $win->view->get_bookmark('trackbar'); - - if ($line) { - $win->command("scrollback goto ". strftime("%d %H:%M:%S", localtime($line->{info}{time}))); - } else { - $win->printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_not_found'); - } -} - -sub cmd_mark { - update_one_trackbar(Irssi::active_win, undef, 1); -} - -sub cmd_markall { - for my $window (Irssi::windows) { - next unless ref $window; - update_one_trackbar($window); - } -} - -sub signal_stop { - Irssi::signal_stop; -} - -sub cmd_markvisible { - my @wins = Irssi::windows; - my $awin = - my $bwin = Irssi::active_win; - my $awin_counter = 0; - Irssi::signal_add_priority('window changed' => 'signal_stop', -99); - do { - Irssi::active_win->command('window up'); - $awin = Irssi::active_win; - update_one_trackbar($awin); - ++$awin_counter; - } until ($awin->{refnum} == $bwin->{refnum} || $awin_counter >= @wins); - Irssi::signal_remove('window changed' => 'signal_stop'); -} - -sub cmd_trackbar_remove_one { - remove_one_trackbar(Irssi::active_win); -} - -sub cmd_remove_all_trackbars { - remove_all_trackbars(); - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_all_removed'); -} - -sub cmd_keep_once { - $keep_trackbar{ Irssi::active_win->{_irssi} } = 1; -} - -sub trackbar_runsub { - my ($data, $server, $item) = @_; - $data =~ s/\s+$//g; - - if ($data) { - Irssi::command_runsub('trackbar', $data, $server, $item); - } else { - goto_trackbar(); - } -} - -sub update_config { - my $was_status_window = $config{use_status_window}; - $config{style} = Irssi::settings_get_str('trackbar_style'); - $config{string} = Irssi::settings_get_str('trackbar_string'); - $config{require_seen} = Irssi::settings_get_bool('trackbar_require_seen'); - $config{ignore_windows} = [ split /[,\s]+/, Irssi::settings_get_str('trackbar_ignore_windows') ]; - $config{use_status_window} = Irssi::settings_get_bool('trackbar_use_status_window'); - $config{print_timestamp} = Irssi::settings_get_bool('trackbar_print_timestamp'); - if (defined $was_status_window && $was_status_window != $config{use_status_window}) { - if (my $swin = Irssi::window_find_name('(status)')) { - if ($config{use_status_window}) { - update_one_trackbar($swin); - } - else { - remove_one_trackbar($swin); - } - } - } - if ($config{print_timestamp}) { - my $ts_format = Irssi::settings_get_str('timestamp_format'); - my $ts_theme = Irssi::current_theme->get_format('fe-common/core', 'timestamp'); - my $render_str = Irssi::current_theme->format_expand($ts_theme); - (my $ts_escaped = $ts_format) =~ s/([%\$])/$1$1/g; - $render_str =~ s/(?|\$(.)(?!\w)|\$\{(\w+)\})/$1 eq 'Z' ? $ts_escaped : $1/ge; - $config{timestamp_str} = $render_str; - } - redraw_trackbars() unless $old_irssi; -} - -Irssi::settings_add_str('trackbar', 'trackbar_string', is_utf8() ? "\x{2500}" : '-'); -Irssi::settings_add_str('trackbar', 'trackbar_style', '%K'); -Irssi::settings_add_str('trackbar', 'trackbar_ignore_windows', ''); -Irssi::settings_add_bool('trackbar', 'trackbar_use_status_window', 1); -Irssi::settings_add_bool('trackbar', 'trackbar_print_timestamp', 0); -Irssi::settings_add_bool('trackbar', 'trackbar_require_seen', 0); - -update_config(); - -Irssi::signal_add_last( 'mainwindow resized' => 'redraw_trackbars') - unless $old_irssi; - -Irssi::signal_register({'window trackbar added' => [qw/Irssi::UI::Window/]}); -Irssi::signal_register({'window trackbar seen' => [qw/Irssi::UI::Window/]}); -Irssi::signal_register({'gui page scrolled' => [qw/Irssi::UI::Window/]}); -Irssi::signal_add_last('gui page scrolled' => 'trackbar_update_seen'); - -Irssi::signal_add('setup changed' => 'update_config'); -Irssi::signal_add_priority('session save' => 'remove_all_trackbars', Irssi::SIGNAL_PRIORITY_HIGH-1); - -Irssi::signal_add('window changed' => 'sig_window_changed'); - -Irssi::command_bind('trackbar goto' => 'goto_trackbar'); -Irssi::command_bind('trackbar keep' => 'cmd_keep_once'); -Irssi::command_bind('trackbar mark' => 'cmd_mark'); -Irssi::command_bind('trackbar markvisible' => 'cmd_markvisible'); -Irssi::command_bind('trackbar markall' => 'cmd_markall'); -Irssi::command_bind('trackbar remove' => 'cmd_trackbar_remove_one'); -Irssi::command_bind('trackbar removeall' => 'cmd_remove_all_trackbars'); -Irssi::command_bind('trackbar redraw' => 'redraw_trackbars'); -Irssi::command_bind('trackbar' => 'trackbar_runsub'); -Irssi::command_bind('mark' => 'cmd_mark'); -Irssi::command_bind_last('help' => 'cmd_help'); - -Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_loaded', $IRSSI{name}, $VERSION, $IRSSI{authors}); diff --git a/.irssi/scripts/recentdepart.pl b/.irssi/scripts/recentdepart.pl deleted file mode 100644 index efb8b95..0000000 --- a/.irssi/scripts/recentdepart.pl +++ /dev/null @@ -1,332 +0,0 @@ -#!/usr/bin/perl -w -# -# recentdepart.pl -# -# irssi script -# -# This script, when loaded into irssi, will filter quit and parted messages -# for channels listed in recdep_channels for any nick whos last message was -# more then a specified time ago. -# -# It also filters join messages showing only join messages for nicks who recently -# parted. -# -# [settings] -# recdep_channels -# - Should contain a list of chatnet and channel names that recentdepart -# should monitor. Its format is a spcae delimited list of chatnet/#channel -# pairs. Either chatnet or channel are optional but adding a / makes it -# explicitly recognized as a chatnet or a channel name. A special case is just a -# "*" which turns it on globally. -# -# "#irrsi #perl" - enables filtering on the #irssi and #perl -# channels on all chatnets. -# -# "freenode IRCNet/#irssi" - enables filtering for all channels on frenode -# and only the #irssi channel on IRCNet. -# -# "freenode/" - force "freenode" to be interpreted as the chatnet -# name by adding a / to the end. -# -# "/freenode" - forces "freenode" to be interpreted as the channel -# by prefixing it with the / delimiter. -# -# "*" - globally enables filtering. -# -# recdep_period -# - specifies the window of time, after a nick last spoke, for which quit/part -# notices will be let through the filter. -# -# recdep_rejoin -# - specifies a time period durring which a join notice for someone rejoining will -# be shown. Join messages are filtered if the nicks part/quit message was filtered -# or if the nick is gone longer then the rejoin period. -# Set to 0 to turn off filtering of join notices. -# -# recdep_nickperiod -# - specifies a window of time like recdep_period that is used to filter nick change -# notices. Set to 0 to turn off filtering of nick changes. -# -# recdep_use_hideshow -# - whether to use hideshow script instead of ignoring -# - -use strict; -use warnings; -use Irssi; -use Irssi::Irc; - -our $VERSION = "0.7"; -our %IRSSI = ( - authors => 'Matthew Sytsma', - contact => 'spiderpigy@yahoo.com', - name => 'Recently Departed', - description => 'Filters quit/part/join/nick notices based on time since last message. (Similar to weechat\'s smartfilter).', - license => 'GNU GPLv2 or later', - url => '', -); - -# store a hash of configure selected servers/channels -my %chanlist; -# Track recent times by server/nick/channel -# (it is more optimal to go nick/channel then channel/nick because some quit signals are by server not by channel. -# We will only have to loop through open channels that a nick has spoken in which should be less then looping -# through all the monitored channels looking for the nick. -my %nickhash=(); -# Track recent times for parted nicks by server/channel/nick -my %joinwatch=(); -my $use_hide; - -sub on_setup_changed { - my %old_chanlist = %chanlist; - %chanlist = (); - my @pairs = split(/ /, Irssi::settings_get_str("recdep_channels")); - - $use_hide = Irssi::settings_get_bool("recdep_use_hideshow"); - foreach (@pairs) - { - my ($net, $chan, $more) = split(/\//); - if ($more) - { - /\/(.+)/; - $chan = $1; - } -# Irssi::active_win()->print("Initial Net: $net Chan: $chan"); - if (!$net) - { - $net = '*'; - } - - if ($net =~ /^[#!@&]/ && !$chan) - { - $chan = $net; - $net = "*"; - } - - if (!$chan) - { - $chan = "*"; - } - - $chanlist{$net}{$chan} = 1; - } - - # empty the storage in case theres a channel or server we are no longer filtering - %nickhash=(); - %joinwatch=(); -} - -sub check_channel -{ - my ($server, $channel) = @_; - - # quits dont have a channel so we need to see if this server possibly contains this channel - if (!$channel || $channel eq '*') - { - # see if any non chatnet channel listings are open on this server - if (keys %{ $chanlist{'*'} }) - { - foreach my $chan (keys %{ $chanlist{'*'} }) - { - if ($chan eq '*' || $server->channel_find($chan)) - { - return 1; - } - } - } - - # see if there were any channels listed for this chatnet - if (keys %{ $chanlist{$server->{'chatnet'}} }) - { return 1; } - else - { return 0; } - } - - # check for global channel matches and pair matches - return (($chanlist{'*'}{'*'}) || - ($chanlist{'*'}{$channel}) || - ($chanlist{$server->{'chatnet'}}{'*'}) || - ($chanlist{$server->{'chatnet'}}{$channel})); -} - -# Hook for quitting -sub on_quit -{ - my ($server, $nick, $address, $reason) = @_; - - if ($server->{'nick'} eq $nick) - { return; } - - if (check_channel($server, '*')) - { - my $recent = 0; - foreach my $chan (keys %{ $nickhash{$server->{'tag'}}{lc($nick)} }) - { - if (time() - $nickhash{$server->{'tag'}}{lc($nick)}{$chan} < Irssi::settings_get_int("recdep_period")) - { - $recent = 1; - - if (Irssi::settings_get_int("recdep_rejoin") > 0) - { - $joinwatch{$server->{'tag'}}{$chan}{lc($nick)} = time(); - } - } - } - - delete $nickhash{$server->{'tag'}}{lc($nick)}; - - if (!$recent) - { - $use_hide ? $Irssi::scripts::hideshow::hide_next = 1 - : Irssi::signal_stop(); - } - } -} - -# Hook for parting -sub on_part -{ - my ($server, $channel, $nick, $address, $reason) = @_; - - # cleanup if its you who left a channel - if ($server->{'nick'} eq $nick) - { - # slightly painfull cleanup but we shouldn't hit this as often - foreach my $nickd (keys %{ $nickhash{$server->{'tag'}} }) - { - delete $nickhash{$server->{'tag'}}{$nickd}{$channel}; - if (!keys(%{ $nickhash{$server->{'tag'}}{$nickd} })) - { - delete $nickhash{$server->{'tag'}}{$nickd}; - } - } - delete $joinwatch{$server->{'tag'}}{$channel}; - } - elsif (check_channel($server, $channel)) - { - if (!defined $nickhash{$server->{'tag'}}{lc($nick)}{$channel} || time() - $nickhash{$server->{'tag'}}{lc($nick)}{$channel} > Irssi::settings_get_int("recdep_period")) - { - $use_hide ? $Irssi::scripts::hideshow::hide_next = 1 - : Irssi::signal_stop(); - } - elsif (Irssi::settings_get_int("recdep_rejoin") > 0) - { - $joinwatch{$server->{'tag'}}{$channel}{lc($nick)} = time(); - } - - delete $nickhash{$server->{'tag'}}{lc($nick)}{$channel}; - if (!keys(%{ $nickhash{$server->{'tag'}}{lc($nick)} })) - { - delete $nickhash{$server->{'tag'}}{lc($nick)}; - } - } -} - -# Hook for public messages. -sub on_public -{ - my ($server, $msg, $nick, $addr, $target) = @_; - - if (!$target) { return; } - if ($nick =~ /^#/) { return; } - - if ($server->{'nick'} eq $nick) { return; } - - if (check_channel($server, $target)) - { - $nickhash{$server->{'tag'}}{lc($nick)}{$target} = time(); - } -} - -# Hook for people joining -sub on_join -{ - my ($server, $channel, $nick, $address) = @_; - - if ($server->{'nick'} eq $nick) - { return; } - - if (Irssi::settings_get_int("recdep_rejoin") == 0) - { return; } - - if (check_channel($server, $channel)) - { - if (!defined $joinwatch{$server->{'tag'}}{$channel}{lc($nick)} || time() - $joinwatch{$server->{'tag'}}{$channel}{lc($nick)} > Irssi::settings_get_int("recdep_rejoin")) - { - $use_hide ? $Irssi::scripts::hideshow::hide_next = 1 - : Irssi::signal_stop(); - } - } - - # loop through and delete all old nicks from the rejoin hash - # this should be a small loop because it will only inlude nicks who recently left channel and who - # passed the part message filter - foreach my $nickd (keys %{ $joinwatch{$server->{'tag'}}{$channel} }) - { - if (time() - $joinwatch{$server->{'tag'}}{$channel}{lc($nickd)} < Irssi::settings_get_int("recdep_rejoin")) - { next; } - - delete $joinwatch{$server->{'tag'}}{$channel}{lc($nickd)}; - } - if (!keys(%{ $joinwatch{$server->{'tag'}}{$channel} })) - { - delete $joinwatch{$server->{'tag'}}{$channel}; - } -} - -# Hook for nick changes -sub on_nick -{ - my ($server, $new, $old, $address) = @_; - - if ($server->{'nick'} eq $old || $server->{'nick'} eq $new) - { return; } - - if (check_channel($server, '*')) - { - my $recent = 0; - foreach my $chan (keys %{ $nickhash{$server->{'tag'}}{lc($old)} }) - { - if (time() - $nickhash{$server->{'tag'}}{lc($old)}{$chan} < Irssi::settings_get_int("recdep_nickperiod")) - { - $recent = 1; - } - } - - if (!$recent && Irssi::settings_get_int("recdep_nickperiod") > 0) - { - $use_hide ? $Irssi::scripts::hideshow::hide_next = 1 - : Irssi::signal_stop(); - } - - delete $nickhash{$server->{'tag'}}{lc($old)}; - } -} - - -# Hook for cleanup on server quit -sub on_serverquit -{ - my ($server, $msg) = @_; - - delete $nickhash{$server->{'tag'}}; - delete $joinwatch{$server->{'tag'}}; -} - -# Setup hooks on events -Irssi::signal_add_last("message public", "on_public"); -Irssi::signal_add_last("message part", "on_part"); -Irssi::signal_add_last("message quit", "on_quit"); -Irssi::signal_add_last("message nick", "on_nick"); -Irssi::signal_add_last("message join", "on_join"); -Irssi::signal_add_last("server disconnected", "on_serverquit"); -Irssi::signal_add_last("server quit", "on_serverquit"); -Irssi::signal_add('setup changed', "on_setup_changed"); - -# Add settings -Irssi::settings_add_str("recdentpepart", "recdep_channels", '*'); -Irssi::settings_add_int("recdentpepart", "recdep_period", 600); -Irssi::settings_add_int("recdentpepart", "recdep_rejoin", 120); -Irssi::settings_add_int("recdentpepart", "recdep_nickperiod", 600); -Irssi::settings_add_bool("recdentpepart", "recdep_use_hideshow", 0); -on_setup_changed(); diff --git a/.irssi/scripts/scriptassist.pl b/.irssi/scripts/scriptassist.pl deleted file mode 100644 index 6870894..0000000 --- a/.irssi/scripts/scriptassist.pl +++ /dev/null @@ -1,1229 +0,0 @@ -# by Stefan "tommie" Tomanek -# -# scriptassist.pl - - -use strict; - -our $VERSION = '2003020806'; -our %IRSSI = ( - authors => 'Stefan \'tommie\' Tomanek', - contact => 'stefan@pico.ruhr.de', - name => 'scriptassist', - description => 'keeps your scripts on the cutting edge', - license => 'GPLv2', - url => 'http://irssi.org/scripts/', - modules => 'Data::Dumper LWP::UserAgent (GnuPG)', - commands => "scriptassist" -); - -our ($forked, %remote_db, $have_gpg, @complist); - -use Irssi 20020324; -use Data::Dumper; -use LWP::UserAgent; -use POSIX; - -# GnuPG is not always needed -$have_gpg = 0; -eval "use GnuPG qw(:algo :trust);"; -$have_gpg = 1 if not ($@); - -sub show_help { - my $help = "scriptassist $VERSION -/scriptassist check - Check all loaded scripts for new available versions -/scriptassist update <script|all> - Update the selected or all script to the newest version -/scriptassist search <query> - Search the script database -/scriptassist info <scripts> - Display information about <scripts> -".#/scriptassist ratings <scripts> -# Retrieve the average ratings of the the scripts -#/scriptassist top <num> -# Retrieve the first <num> top rated scripts -"/scriptassist new <num> - Display the newest <num> scripts -".#/scriptassist rate <script> <stars> -# Rate the script with a number of stars ranging from 0-5 -"/scriptassist contact <script> - Write an email to the author of the script - (Requires OpenURL) -/scriptassist cpan <module> - Visit CPAN to look for missing Perl modules - (Requires OpenURL) -/scriptassist install <script> - Retrieve and load the script -/scriptassist autorun <script> - Toggles automatic loading of <script> -"; - my $text=''; - foreach (split(/\n/, $help)) { - $_ =~ s/^\/(.*)$/%9\/$1%9/; - $text .= $_."\n"; - } - print CLIENTCRAP &draw_box("ScriptAssist", $text, "scriptassist help", 1); - #theme_box("ScriptAssist", $text, "scriptassist help", 1); -} - -sub theme_box { - my ($title, $text, $footer, $colour) = @_; - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'box_header', $title); - foreach (split(/\n/, $text)) { - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'box_inside', $_); - } - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'box_footer', $footer); -} - -sub draw_box { - my ($title, $text, $footer, $colour) = @_; - my $box = ''; - $box .= '%R,--[%n%9%U'.$title.'%U%9%R]%n'."\n"; - foreach (split(/\n/, $text)) { - $box .= '%R|%n '.$_."\n"; - } - $box .= '%R`--<%n'.$footer.'%R>->%n'; - $box =~ s/%.//g unless $colour; - return $box; -} - -sub call_openurl { - my ($url) = @_; - # check for a loaded openurl - if (my $code = Irssi::Script::openurl::->can('launch_url')) { - $code->($url); - } else { - print CLIENTCRAP "%R>>%n Please install openurl.pl"; - } -} - -sub bg_do { - my ($func) = @_; - my ($rh, $wh); - pipe($rh, $wh); - if ($forked) { - print CLIENTCRAP "%R>>%n Please wait until your earlier request has been finished."; - return; - } - my $pid = fork(); - $forked = 1; - if ($pid > 0) { - print CLIENTCRAP "%R>>%n Please wait..."; - close $wh; - Irssi::pidwait_add($pid); - my $pipetag; - my @args = ($rh, \$pipetag, $func); - $pipetag = Irssi::input_add(fileno($rh), INPUT_READ, \&pipe_input, \@args); - } else { - eval { - my @items = split(/ /, $func); - my %result; - my $ts1 = $remote_db{timestamp}; - my $xml = get_scripts(); - my $ts2 = $remote_db{timestamp}; - if (not($ts1 eq $ts2) && Irssi::settings_get_bool('scriptassist_cache_sources')) { - $result{db} = $remote_db{db}; - $result{timestamp} = $remote_db{timestamp}; - } - if ($items[0] eq 'check') { - $result{data}{check} = check_scripts($xml); - } elsif ($items[0] eq 'update') { - shift(@items); - $result{data}{update} = update_scripts(\@items, $xml); - } elsif ($items[0] eq 'search') { - shift(@items); - foreach (@items) { - $result{data}{search}{$_} = search_scripts($_, $xml); - } - } elsif ($items[0] eq 'install') { - shift(@items); - $result{data}{install} = install_scripts(\@items, $xml); - } elsif ($items[0] eq 'debug') { - shift(@items); - $result{data}{debug} = debug_scripts(\@items); - } elsif ($items[0] eq 'ratings') { - shift(@items); - @items = @{ loaded_scripts() } if $items[0] eq "all"; - my %ratings = %{ get_ratings(\@items, '') }; - foreach (keys %ratings) { - $result{data}{rating}{$_}{rating} = $ratings{$_}->[0]; - $result{data}{rating}{$_}{votes} = $ratings{$_}->[1]; - } - } elsif ($items[0] eq 'rate') { - $result{data}{rate}{$items[1]} = rate_script($items[1], $items[2]); - } elsif ($items[0] eq 'info') { - shift(@items); - $result{data}{info} = script_info(\@items); - } elsif ($items[0] eq 'echo') { - $result{data}{echo} = 1; - } elsif ($items[0] eq 'top') { - my %ratings = %{ get_ratings([], $items[1]) }; - foreach (keys %ratings) { - $result{data}{rating}{$_}{rating} = $ratings{$_}->[0]; - $result{data}{rating}{$_}{votes} = $ratings{$_}->[1]; - } - } elsif ($items[0] eq 'new') { - my $new = get_new($items[1]); - $result{data}{new} = $new; - } elsif ($items[0] eq 'unknown') { - my $cmd = $items[1]; - $result{data}{unknown}{$cmd} = get_unknown($cmd, $xml); - } - my $dumper = Data::Dumper->new([\%result]); - $dumper->Purity(1)->Deepcopy(1)->Indent(0); - my $data = $dumper->Dump; - print($wh $data); - }; - if ($@) { - print($wh Data::Dumper->new([+{data=>+{error=>$@}}]) - ->Purity(1)->Deepcopy(1)->Indent(0)->Dump); - } - close($wh); - POSIX::_exit(1); - } -} - -sub get_unknown { - my ($cmd, $db) = @_; - foreach (keys %$db) { - next unless defined $db->{$_}{commands}; - foreach my $item (split / /, $db->{$_}{commands}) { - return { $_ => $db->{$_} } if ($item =~ /^$cmd$/i); - } - } - return undef; -} - -sub get_names { - my ($sname, $db) = shift; - $sname =~ s/\s+$//; - $sname =~ s/\.pl$//; - my $plname = "$sname.pl"; - $sname =~ s/^.*\///; - my $xname = $sname; - $xname =~ s/\W/_/g; - my $pname = "${xname}::"; - if ($xname ne $sname || $sname =~ /_/) { - my $dir = Irssi::get_irssi_dir()."/scripts/"; - if ($db && exists $db->{"$sname.pl"}) { - # $found = 1; - } elsif (-e $dir.$plname || -e $dir."$sname.pl" || -e $dir."autorun/$sname.pl") { - # $found = 1; - } else { - # not found - my $pat = $xname; $pat =~ y/_/?/; - my $re = "\Q$xname"; $re =~ s/\Q_/./g; - if ($db) { - my ($cand) = grep /^$re\.pl$/, sort keys %$db; - if ($cand) { - return get_names($cand, $db); - } - } - my ($cand) = glob "'$dir$pat.pl' '${dir}autorun/$pat.pl'"; - if ($cand) { - $cand =~ s/^.*\///; - return get_names($cand, $db); - } - } - } - ($sname, $plname, $pname, $xname) -} - -sub script_info { - my ($scripts) = @_; - my %result; - my $xml = get_scripts(); - foreach (@{$scripts}) { - my ($sname, $plname, $pname) = get_names($_, $xml); - next unless (defined $xml->{$plname} || ( exists $Irssi::Script::{$pname} && exists $Irssi::Script::{$pname}{IRSSI} )); - $result{$sname}{version} = get_remote_version($sname, $xml); - my @headers = ('authors', 'contact', 'description', 'license', 'source'); - foreach my $entry (@headers) { - $result{$sname}{$entry} = $Irssi::Script::{$pname}{IRSSI}{$entry}; - if (defined $xml->{$plname}{$entry}) { - $result{$sname}{$entry} = $xml->{$plname}{$entry}; - } - } - if ($xml->{$plname}{signature_available}) { - $result{$sname}{signature_available} = 1; - } - if (defined $xml->{$plname}{modules}) { - my $modules = $xml->{$plname}{modules}; - foreach my $mod (split(/ /, $modules)) { - my $opt = ($mod =~ /\((.*)\)/)? 1 : 0; - $mod = $1 if $1; - $result{$sname}{modules}{$mod}{optional} = $opt; - $result{$sname}{modules}{$mod}{installed} = module_exist($mod); - } - } elsif (defined $Irssi::Script::{$pname}{IRSSI}{modules}) { - my $modules = $Irssi::Script::{$pname}{IRSSI}{modules}; - foreach my $mod (split(/ /, $modules)) { - my $opt = ($mod =~ /\((.*)\)/)? 1 : 0; - $mod = $1 if $1; - $result{$sname}{modules}{$mod}{optional} = $opt; - $result{$sname}{modules}{$mod}{installed} = module_exist($mod); - } - } - if (defined $xml->{$plname}{depends}) { - my $depends = $xml->{$plname}{depends}; - foreach my $dep (split(/ /, $depends)) { - $result{$sname}{depends}{$dep}{installed} = 1; - } - } - } - return \%result; -} - -sub rate_script { - my ($script, $stars) = @_; - my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30); - $ua->agent('ScriptAssist/'.2003020803); - my $request = HTTP::Request->new('GET', 'http://ratings.irssi.de/irssirate.pl?&stars='.$stars.'&mode=rate&script='.$script); - my $response = $ua->request($request); - unless ($response->is_success() && $response->content() =~ /You already rated this script/) { - return 1; - } else { - return 0; - } -} - -sub get_ratings { - my ($scripts, $limit) = @_; - my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30); - $ua->agent('ScriptAssist/'.2003020803); - my $script = join(',', @{$scripts}); - my $request = HTTP::Request->new('GET', 'http://ratings.irssi.de/irssirate.pl?script='.$script.'&sort=rating&limit='.$limit); - my $response = $ua->request($request); - my %result; - if ($response->is_success()) { - foreach (split /\n/, $response->content()) { - if (/<tr><td><a href=".*?">(.*?)<\/a>/) { - my $entry = $1; - if (/"><\/td><td>([0-9.]+)<\/td><td>(.*?)<\/td><td>/) { - $result{$entry} = [$1, $2]; - } - } - } - } - return \%result; -} - -sub get_new { - my ($num) = @_; - my $result; - my $xml = get_scripts(); - foreach (sort {$xml->{$b}{last_modified} cmp $xml->{$a}{last_modified}} keys %$xml) { - my %entry = %{ $xml->{$_} }; - next if $entry{HIDDEN}; - $result->{$_} = \%entry; - $num--; - last unless $num; - } - return $result; -} -sub module_exist { - my ($module) = @_; - $module =~ s/::/\//g; - foreach (@INC) { - return 1 if (-e $_."/".$module.".pm"); - } - return 0; -} - -sub debug_scripts { - my ($scripts) = @_; - my %result; - my $xml = get_scripts(); - foreach (@{$scripts}) { - my ($sname, $plname) = get_names($_, $xml); - if (defined $xml->{$plname}{modules}) { - my $modules = $xml->{$plname}{modules}; - foreach my $mod (split(/ /, $modules)) { - my $opt = ($mod =~ /\((.*)\)/)? 1 : 0; - $mod = $1 if $1; - $result{$sname}{$mod}{optional} = $opt; - $result{$sname}{$mod}{installed} = module_exist($mod); - } - } - } - return(\%result); -} - -sub install_scripts { - my ($scripts, $xml) = @_; - my %success; - my $dir = Irssi::get_irssi_dir()."/scripts/"; - foreach (@{$scripts}) { - my ($sname, $plname, $pname) = get_names($_, $xml); - if (get_local_version($sname) && (-e $dir.$plname)) { - $success{$sname}{installed} = -2; - } else { - $success{$sname} = download_script($sname, $xml); - } - } - return \%success; -} - -sub update_scripts { - my ($list, $database) = @_; - $list = loaded_scripts() if ($list->[0] eq "all" || scalar(@$list) == 0); - my %status; - foreach (@{$list}) { - my ($sname) = get_names($_, $database); - my $local = get_local_version($sname); - my $remote = get_remote_version($sname, $database); - next if $local eq '' || $remote eq ''; - if (compare_versions($local, $remote) eq "older") { - $status{$sname} = download_script($sname, $database); - } else { - $status{$sname}{installed} = -2; - } - $status{$sname}{remote} = $remote; - $status{$sname}{local} = $local; - } - return \%status; -} - -sub search_scripts { - my ($query, $database) = @_; - $query =~ s/\.pl\Z//; - my %result; - foreach (sort keys %{$database}) { - my %entry = %{$database->{$_}}; - next if $entry{HIDDEN}; - my $string = $_." "; - $string .= $entry{description} if defined $entry{description}; - if ($string =~ /$query/i) { - my $name = $_; - $name =~ s/\.pl$//; - if (defined $entry{description}) { - $result{$name}{desc} = $entry{description}; - } else { - $result{$name}{desc} = ""; - } - if (defined $entry{authors}) { - $result{$name}{authors} = $entry{authors}; - } else { - $result{$name}{authors} = ""; - } - if (get_local_version($name)) { - $result{$name}{installed} = 1; - } else { - $result{$name}{installed} = 0; - } - } - } - return \%result; -} - -sub pipe_input { - my ($rh, $pipetag) = @{$_[0]}; - my $text = do { local $/; <$rh>; }; - close($rh); - Irssi::input_remove($$pipetag); - $forked = 0; - unless ($text) { - print CLIENTCRAP "%R<<%n Something weird happend (no text)"; - return(); - } - local our $VAR1; - my $incoming = eval($text); - if ($incoming->{db} && $incoming->{timestamp}) { - $remote_db{db} = $incoming->{db}; - $remote_db{timestamp} = $incoming->{timestamp}; - } - unless (defined $incoming->{data}) { - print CLIENTCRAP "%R<<%n Something weird happend (no data)"; - return; - } - my %result = %{ $incoming->{data} }; - @complist = (); - if (defined $result{new}) { - print_new($result{new}); - push @complist, $_ foreach keys %{ $result{new} }; - } - if (defined $result{check}) { - print_check(%{$result{check}}); - push @complist, $_ foreach keys %{ $result{check} }; - } - if (defined $result{update}) { - print_update(%{ $result{update} }); - push @complist, $_ foreach keys %{ $result{update} }; - } - if (defined $result{search}) { - foreach (keys %{$result{search}}) { - print_search($_, %{$result{search}{$_}}); - push @complist, keys(%{$result{search}{$_}}); - } - } - if (defined $result{install}) { - print_install(%{ $result{install} }); - push @complist, $_ foreach keys %{ $result{install} }; - } - if (defined $result{debug}) { - print_debug(%{ $result{debug} }); - } - if (defined $result{rating}) { - print_ratings(%{ $result{rating} }); - push @complist, $_ foreach keys %{ $result{rating} }; - } - if (defined $result{rate}) { - print_rate(%{ $result{rate} }); - } - if (defined $result{info}) { - print_info(%{ $result{info} }); - } - if (defined $result{echo}) { - Irssi::print "ECHO"; - } - if ($result{unknown}) { - print_unknown($result{unknown}); - } - if (defined $result{error}) { - print CLIENTCRAP "%R<<%n There was an error in background processing:"; chomp($result{error}); - print CLIENTERROR $result{error}; - } - -} - -sub print_unknown { - my ($data) = @_; - foreach my $cmd (keys %$data) { - print CLIENTCRAP "%R<<%n No script provides '/$cmd'" unless $data->{$cmd}; - foreach (keys %{ $data->{$cmd} }) { - my $text .= "The command '/".$cmd."' is provided by the script '".$data->{$cmd}{$_}{name}."'.\n"; - $text .= "This script is currently not installed on your system.\n"; - $text .= "If you want to install the script, enter\n"; - my ($name) = get_names($_); - $text .= " %U/script install ".$name."%U "; - my $output = draw_box("ScriptAssist", $text, "'".$_."' missing", 1); - print CLIENTCRAP $output; - } - } -} - -sub check_autorun { - my ($script) = @_; - my (undef, $plname) = get_names($script); - my $dir = Irssi::get_irssi_dir()."/scripts/"; - if (-e $dir."/autorun/".$plname) { - if (readlink($dir."/autorun/".$plname) eq "../".$plname) { - return 1; - } - } - return 0; -} - -sub array2table { - my (@array) = @_; - my @width; - foreach my $line (@array) { - for (0..scalar(@$line)-1) { - my $l = $line->[$_]; - $l =~ s/%[^%]//g; - $l =~ s/%%/%/g; - $width[$_] = length($l) if $width[$_]<length($l); - } - } - my $text; - foreach my $line (@array) { - for (0..scalar(@$line)-1) { - my $l = $line->[$_]; - $text .= $line->[$_]; - $l =~ s/%[^%]//g; - $l =~ s/%%/%/g; - $text .= " "x($width[$_]-length($l)+1) unless ($_ == scalar(@$line)-1); - } - $text .= "\n"; - } - return $text; -} - - -sub print_info { - my (%data) = @_; - my $line; - foreach my $script (sort keys(%data)) { - my ($local, $autorun); - if (get_local_version($script)) { - $line .= "%go%n "; - $local = get_local_version($script); - } else { - $line .= "%ro%n "; - $local = undef; - } - if (defined $local || check_autorun($script)) { - $autorun = "no"; - $autorun = "yes" if check_autorun($script); - } else { - $autorun = undef; - } - $line .= "%9".$script."%9\n"; - $line .= " Version : ".$data{$script}{version}."\n"; - $line .= " Source : ".$data{$script}{source}."\n"; - $line .= " Installed : ".$local."\n" if defined $local; - $line .= " Autorun : ".$autorun."\n" if defined $autorun; - $line .= " Authors : ".$data{$script}{authors}; - $line .= " %Go-m signed%n" if $data{$script}{signature_available}; - $line .= "\n"; - $line .= " Contact : ".$data{$script}{contact}."\n"; - $line .= " Description: ".$data{$script}{description}."\n"; - $line .= "\n" if $data{$script}{modules}; - $line .= " Needed Perl modules:\n" if $data{$script}{modules}; - - foreach (sort keys %{$data{$script}{modules}}) { - if ( $data{$script}{modules}{$_}{installed} == 1 ) { - $line .= " %g->%n ".$_." (found)"; - } else { - $line .= " %r->%n ".$_." (not found)"; - } - $line .= " <optional>" if $data{$script}{modules}{$_}{optional}; - $line .= "\n"; - } - $line .= " Needed Irssi Scripts:\n" if $data{$script}{depends}; - foreach (sort keys %{$data{$script}{depends}}) { - if ( $data{$script}{depends}{$_}{installed} == 1 ) { - $line .= " %g->%n ".$_." (loaded)"; - } else { - $line .= " %r->%n ".$_." (not loaded)"; - } - $line .= "\n"; - } - } - print CLIENTCRAP draw_box('ScriptAssist', $line, 'info', 1) ; -} - -sub print_rate { - my (%data) = @_; - my $line; - foreach my $script (sort keys(%data)) { - if ($data{$script}) { - $line .= "%go%n %9".$script."%9 has been rated"; - } else { - $line .= "%ro%n %9".$script."%9 : Already rated this script"; - } - } - print CLIENTCRAP draw_box('ScriptAssist', $line, 'rating', 1) ; -} - -sub print_ratings { - my (%data) = @_; - my @table; - foreach my $script (sort {$data{$b}{rating}<=>$data{$a}{rating}} keys(%data)) { - my @line; - if (get_local_version($script)) { - push @line, "%go%n"; - } else { - push @line, "%yo%n"; - } - push @line, "%9".$script."%9"; - push @line, $data{$script}{rating}; - push @line, "[".$data{$script}{votes}." votes]"; - push @table, \@line; - } - print CLIENTCRAP draw_box('ScriptAssist', array2table(@table), 'ratings', 1) ; -} - -sub print_new { - my ($list) = @_; - my @table; - foreach (sort {$list->{$b}{last_modified} cmp $list->{$a}{last_modified}} keys %$list) { - my @line; - my ($name) = get_names($_); - if (get_local_version($name)) { - push @line, "%go%n"; - } else { - push @line, "%yo%n"; - } - push @line, "%9".$name."%9"; - push @line, $list->{$_}{last_modified}; - push @table, \@line; - } - print CLIENTCRAP draw_box('ScriptAssist', array2table(@table), 'new scripts', 1) ; -} - -sub print_debug { - my (%data) = @_; - my $line; - foreach my $script (sort keys %data) { - $line .= "%ro%n %9".$script."%9 failed to load\n"; - $line .= " Make sure you have the following perl modules installed:\n"; - foreach (sort keys %{$data{$script}}) { - if ( $data{$script}{$_}{installed} == 1 ) { - $line .= " %g->%n ".$_." (found)"; - } else { - $line .= " %r->%n ".$_." (not found)\n"; - $line .= " [This module is optional]\n" if $data{$script}{$_}{optional}; - $line .= " [Try /scriptassist cpan ".$_."]"; - } - $line .= "\n"; - } - print CLIENTCRAP draw_box('ScriptAssist', $line, 'debug', 1) ; - } -} - -sub load_script { - my ($script) = @_; - Irssi::command('script load '.$script); -} - -sub print_install { - my (%data) = @_; - my $text; - my ($crashed, @installed); - foreach my $script (sort keys %data) { - my $line; - if ($data{$script}{installed} == 1) { - my $hacked; - if ($have_gpg && Irssi::settings_get_bool('scriptassist_use_gpg')) { - if ($data{$script}{signed} >= 0) { - load_script($script) unless (lc($script) eq lc($IRSSI{name})); - } else { - $hacked = 1; - } - } else { - load_script($script) unless (lc($script) eq lc($IRSSI{name})); - } - if (get_local_version($script) && not lc($script) eq lc($IRSSI{name})) { - $line .= "%go%n %9".$script."%9 installed\n"; - push @installed, $script; - } elsif (lc($script) eq lc($IRSSI{name})) { - $line .= "%yo%n %9".$script."%9 installed, please reload manually\n"; - } else { - $line .= "%Ro%n %9".$script."%9 fetched, but unable to load\n"; - $crashed .= $script." " unless $hacked; - } - if ($have_gpg && Irssi::settings_get_bool('scriptassist_use_gpg')) { - foreach (split /\n/, check_sig($data{$script})) { - $line .= " ".$_."\n"; - } - } - } elsif ($data{$script}{installed} == -2) { - $line .= "%ro%n %9".$script."%9 already loaded, please try \"update\"\n"; - } elsif ($data{$script}{installed} <= 0) { - $line .= "%ro%n %9".$script."%9 not installed\n"; - foreach (split /\n/, check_sig($data{$script})) { - $line .= " ".$_."\n"; - } - } else { - $line .= "%Ro%n %9".$script."%9 not found on server\n"; - } - $text .= $line; - } - # Inspect crashed scripts - bg_do("debug ".$crashed) if $crashed; - print CLIENTCRAP draw_box('ScriptAssist', $text, 'install', 1); - list_sbitems(\@installed); -} - -sub list_sbitems { - my ($scripts) = @_; - my $text; - foreach (@$scripts) { - next unless exists $Irssi::Script::{"${_}::"}; - next unless exists $Irssi::Script::{"${_}::"}{IRSSI}; - my $header = $Irssi::Script::{"${_}::"}{IRSSI}; - next unless $header->{sbitems}; - $text .= '%9"'.$_.'"%9 provides the following statusbar item(s):'."\n"; - $text .= ' ->'.$_."\n" foreach (split / /, $header->{sbitems}); - } - return unless $text; - $text .= "\n"; - $text .= "Enter '/statusbar window add <item>' to add an item."; - print CLIENTCRAP draw_box('ScriptAssist', $text, 'sbitems', 1); -} - -sub check_sig { - my ($sig) = @_; - my $line; - my %trust = ( -1 => 'undefined', - 0 => 'never', - 1 => 'marginal', - 2 => 'fully', - 3 => 'ultimate' - ); - if ($sig->{signed} == 1) { - $line .= "Signature found from ".$sig->{sig}{user}."\n"; - $line .= "Timestamp : ".$sig->{sig}{date}."\n"; - $line .= "Fingerprint: ".$sig->{sig}{fingerprint}."\n"; - $line .= "KeyID : ".$sig->{sig}{keyid}."\n"; - $line .= "Trust : ".$trust{$sig->{sig}{trust}}."\n"; - } elsif ($sig->{signed} == -1) { - $line .= "%1Warning, unable to verify signature%n\n"; - } elsif ($sig->{signed} == 0) { - $line .= "%1No signature found%n\n" unless Irssi::settings_get_bool('scriptassist_install_unsigned_scripts'); - } - return $line; -} - -sub print_search { - my ($query, %data) = @_; - my $text; - foreach (sort keys %data) { - my $line; - $line .= "%go%n" if $data{$_}{installed}; - $line .= "%yo%n" if not $data{$_}{installed}; - $line .= " %9".$_."%9 "; - $line .= $data{$_}{desc}; - $line =~ s/($query)/%U$1%U/gi; - $line .= ' ('.$data{$_}{authors}.')'; - $text .= $line." \n"; - } - print CLIENTCRAP draw_box('ScriptAssist', $text, 'search: '.$query, 1) ; -} - -sub print_update { - my (%data) = @_; - my $text; - my @table; - my $verbose = Irssi::settings_get_bool('scriptassist_update_verbose'); - foreach (sort keys %data) { - my $signed = 0; - if ($data{$_}{installed} == 1) { - my $local = $data{$_}{local}; - my $remote = $data{$_}{remote}; - push @table, ['%yo%n', '%9'.$_.'%9', 'upgraded ('.$local.'->'.$remote.')']; - foreach (split /\n/, check_sig($data{$_})) { - push @table, ['', '', $_]; - } - if (lc($_) eq lc($IRSSI{name})) { - push @table, ['', '', "%R%9Please reload manually%9%n"]; - } else { - load_script($_); - } - } elsif ($data{$_}{installed} == 0 || $data{$_}{installed} == -1) { - push @table, ['%yo%n', '%9'.$_.'%9', 'not upgraded']; - foreach (split /\n/, check_sig($data{$_})) { - push @table, ['', '', $_]; - } - } elsif ($data{$_}{installed} == -2 && $verbose) { - my $local = $data{$_}{local}; - push @table, ['%go%n', '%9'.$_.'%9', 'already at the latest version ('.$local.')']; - } - } - $text = array2table(@table); - print CLIENTCRAP draw_box('ScriptAssist', $text, 'update', 1) ; -} - -sub contact_author { - my ($script) = @_; - my ($sname, $plname, $pname) = get_names($script); - return unless exists $Irssi::Script::{$pname}; - my $header = $Irssi::Script::{$pname}{IRSSI}; - if ($header && defined $header->{contact}) { - my @ads = split(/ |,/, $header->{contact}); - my $address = $ads[0]; - $address .= '?subject='.$script; - $address .= '_'.get_local_version($script) if defined get_local_version($script); - call_openurl($address) if $address =~ /[\@:]/; - } -} - -sub get_scripts { - my $ua = LWP::UserAgent->new(env_proxy=>1, keep_alive=>1, timeout=>30); - $ua->agent('ScriptAssist/'.2003020803); - $ua->env_proxy(); - my @mirrors = split(/ /, Irssi::settings_get_str('scriptassist_script_sources')); - my %sites_db; - my $not_modified = 0; - my $fetched = 0; - my @sources; - my $error; - foreach my $site (@mirrors) { - my $request = HTTP::Request->new('GET', $site); - if ($remote_db{timestamp}) { - $request->if_modified_since($remote_db{timestamp}); - } - my $response = $ua->request($request); - if ($response->code == 304) { # HTTP_NOT_MODIFIED - $not_modified = 1; - next; - } - unless ($response->is_success) { - $error = join "\n", $response->status_line(), (grep / at .* line \d+/, split "\n", $response->content()), ''; - next; - } - $fetched = 1; - my $data = $response->content(); - my ($src, $type); - if ($site =~ /(.*\/).+\.(.+)/) { - $src = $1; - $type = $2; - } - push @sources, $src; - #my @header = ('name', 'contact', 'authors', 'description', 'version', 'modules', 'last_modified'); - if ($type eq 'dmp') { - no strict 'vars'; - my $new_db = eval "$data"; - foreach (keys %$new_db) { - if (defined $sites_db{script}{$_}) { - my $old = $sites_db{$_}{version}; - my $new = $new_db->{$_}{version}; - next if (compare_versions($old, $new) eq 'newer'); - } - #foreach my $key (@header) { - foreach my $key (keys %{ $new_db->{$_} }) { - next unless defined $new_db->{$_}{$key}; - $sites_db{$_}{$key} = $new_db->{$_}{$key}; - } - $sites_db{$_}{source} = $src; - } - } else { - die("Unknown script database type ($type).\n"); - } - } - if ($fetched) { - # Clean database - foreach (keys %{$remote_db{db}}) { - foreach my $site (@sources) { - if ($remote_db{db}{$_}{source} eq $site) { - delete $remote_db{db}{$_}; - last; - } - } - } - $remote_db{db}{$_} = $sites_db{$_} foreach (keys %sites_db); - $remote_db{timestamp} = time(); - } elsif ($not_modified) { - # nothing to do - } else { - die("No script database sources defined in /set scriptassist_script_sources\n") unless @mirrors; - die("Fetching script database failed: $error") if $error; - die("Unknown error while fetching script database\n"); - } - return $remote_db{db}; -} - -sub get_remote_version { - my ($script, $database) = @_; - my $plname = (get_names($script, $database))[1]; - return $database->{$plname}{version}; -} - -sub get_local_version { - my ($script) = @_; - my $pname = (get_names($script))[2]; - return unless exists $Irssi::Script::{$pname}; - my $vref = $Irssi::Script::{$pname}{VERSION}; - return $vref ? $$vref : undef; -} - -sub compare_versions { - my ($ver1, $ver2) = @_; - for ($ver1, $ver2) { - $_ = "0:$_" unless /:/; - } - my @ver1 = split /[.:]/, $ver1; - my @ver2 = split /[.:]/, $ver2; - my $cmp = 0; - ### Special thanks to Clemens Heidinger - no warnings 'uninitialized'; - $cmp ||= $ver1[$_] <=> $ver2[$_] || $ver1[$_] cmp $ver2[$_] for 0..scalar(@ver2); - return 'newer' if $cmp == 1; - return 'older' if $cmp == -1; - return 'equal'; -} - -sub loaded_scripts { - my @modules; - foreach (sort grep(s/::$//, keys %Irssi::Script::)) { - push @modules, $_; - } - return \@modules; -} - -sub check_scripts { - my ($data) = @_; - my %versions; - foreach (@{loaded_scripts()}) { - my ($sname) = get_names($_, $data); - my $remote = get_remote_version($sname, $data); - my $local = get_local_version($sname); - my $state; - if ($local && $remote) { - $state = compare_versions($local, $remote); - } elsif ($local) { - $state = 'noversion'; - $remote = '/'; - } else { - $state = 'noheader'; - $local = '/'; - $remote = '/'; - } - if ($state) { - $versions{$sname}{state} = $state; - $versions{$sname}{remote} = $remote; - $versions{$sname}{local} = $local; - } - } - return \%versions; -} - -sub download_script { - my ($script, $xml) = @_; - my ($sname, $plname) = get_names($script, $xml); - my %result; - my $site = $xml->{$plname}{source}; - $result{installed} = 0; - $result{signed} = 0; - my $dir = Irssi::get_irssi_dir(); - my $ua = LWP::UserAgent->new(env_proxy => 1,keep_alive => 1,timeout => 30); - $ua->agent('ScriptAssist/'.2003020803); - my $request = HTTP::Request->new('GET', $site.'/scripts/'.$script.'.pl'); - my $response = $ua->request($request); - if ($response->is_success()) { - my $file = $response->content(); - mkdir $dir.'/scripts/' unless (-e $dir.'/scripts/'); - open(my $F, '>', $dir.'/scripts/'.$plname.'.new'); - print $F $file; - close($F); - if ($have_gpg && Irssi::settings_get_bool('scriptassist_use_gpg')) { - my $ua2 = LWP::UserAgent->new(env_proxy => 1,keep_alive => 1,timeout => 30); - $ua->agent('ScriptAssist/'.2003020803); - my $request2 = HTTP::Request->new('GET', $site.'/signatures/'.$plname.'.asc'); - my $response2 = $ua->request($request2); - if ($response2->is_success()) { - my $sig_dir = $dir.'/scripts/signatures/'; - mkdir $sig_dir unless (-e $sig_dir); - open(my $S, '>', $sig_dir.$plname.'.asc'); - my $file2 = $response2->content(); - print $S $file2; - close($S); - my $sig; - foreach (1..2) { - # FIXME gpg needs two rounds to load the key - my $gpg = new GnuPG(); - eval { - $sig = $gpg->verify( file => $dir.'/scripts/'.$plname.'.new', signature => $sig_dir.$plname.'.asc' ); - }; - } - if (defined $sig->{user}) { - $result{installed} = 1; - $result{signed} = 1; - $result{sig}{$_} = $sig->{$_} foreach (keys %{$sig}); - } else { - # Signature broken? - $result{installed} = 0; - $result{signed} = -1; - } - } else { - $result{signed} = 0; - $result{installed} = -1; - $result{installed} = 1 if Irssi::settings_get_bool('scriptassist_install_unsigned_scripts'); - } - } else { - $result{signed} = 0; - $result{installed} = -1; - $result{installed} = 1 if Irssi::settings_get_bool('scriptassist_install_unsigned_scripts'); - } - } - if ($result{installed}) { - my $old_dir = "$dir/scripts/old/"; - mkdir $old_dir unless (-e $old_dir); - rename "$dir/scripts/$plname", "$old_dir/$plname.old" if -e "$dir/scripts/$plname"; - rename "$dir/scripts/$plname.new", "$dir/scripts/$plname"; - } - return \%result; -} - -sub print_check { - my (%data) = @_; - my $text; - my @table; - foreach (sort keys %data) { - my $state = $data{$_}{state}; - my $remote = $data{$_}{remote}; - my $local = $data{$_}{local}; - if (Irssi::settings_get_bool('scriptassist_check_verbose')) { - push @table, ['%go%n', '%9'.$_.'%9', 'Up to date. ('.$local.')'] if $state eq 'equal'; - } - push @table, ['%mo%n', '%9'.$_.'%9', "No version information available on network."] if $state eq "noversion"; - push @table, ['%mo%n', '%9'.$_.'%9', 'No header in script.'] if $state eq "noheader"; - push @table, ['%bo%n', '%9'.$_.'%9', "Your version is newer (".$local."->".$remote.")"] if $state eq "newer"; - push @table, ['%ro%n', '%9'.$_.'%9', "A new version is available (".$local."->".$remote.")"] if $state eq "older";; - } - $text = array2table(@table); - print CLIENTCRAP draw_box('ScriptAssist', $text, 'check', 1) ; -} - -sub toggle_autorun { - my ($script) = @_; - my ($sname, $plname) = get_names($script); - my $dir = Irssi::get_irssi_dir()."/scripts/"; - mkdir $dir."autorun/" unless (-e $dir."autorun/"); - return unless (-e $dir.$plname); - if (-e $dir."/autorun/".$plname) { - if (readlink($dir."/autorun/".$plname) eq "../".$plname) { - if (unlink($dir."/autorun/".$plname)) { - print CLIENTCRAP "%R>>%n Autorun of ".$sname." disabled"; - } else { - print CLIENTCRAP "%R>>%n Unable to delete link"; - } - } else { - print CLIENTCRAP "%R>>%n ".$dir."/autorun/".$plname." is not a correct link"; - } - } else { - if (symlink("../".$plname, $dir."/autorun/".$plname)) { - print CLIENTCRAP "%R>>%n Autorun of ".$sname." enabled"; - } else { - print CLIENTCRAP "%R>>%n Unable to create autorun link"; - } - } -} - -sub sig_script_error { - my ($script, $msg) = @_; - return unless Irssi::settings_get_bool('scriptassist_catch_script_errors'); - if ($msg =~ /Can't locate (.*?)\.pm in \@INC \(\@INC contains:(.*?) at/) { - my $module = $1; - $module =~ s/\//::/g; - missing_module($module); - } -} - -sub missing_module { - my ($module) = @_; - my $text; - $text .= "The perl module %9".$module."%9 is missing on your system.\n"; - $text .= "Please ask your administrator about it.\n"; - $text .= "You can also check CPAN via '/scriptassist cpan ".$module."'.\n"; - print CLIENTCRAP &draw_box('ScriptAssist', $text, $module, 1); -} - -sub cmd_scripassist { - my ($arg, $server, $witem) = @_; - my @args = split(/ /, $arg); - if ($args[0] eq 'help' || $args[0] eq '-h') { - show_help(); - } elsif ($args[0] eq 'check') { - bg_do("check"); - } elsif ($args[0] eq 'update') { - shift @args; - bg_do("update ".join(' ', @args)); - } elsif ($args[0] eq 'search' && defined $args[1]) { - shift @args; - bg_do("search ".join(" ", @args)); - } elsif ($args[0] eq 'install' && defined $args[1]) { - shift @args; - bg_do("install ".join(' ', @args)); - } elsif ($args[0] eq 'contact' && defined $args[1]) { - contact_author($args[1]); - } elsif ($args[0] eq 'ratings' && defined $args[1]) { - shift @args; - bg_do("ratings ".join(' ', @args)); - } elsif ($args[0] eq 'rate' && defined $args[1] && defined $args[2]) { - shift @args; - bg_do("rate ".join(' ', @args)) if ($args[2] >= 0 && $args[2] < 6); - } elsif ($args[0] eq 'info' && defined $args[1]) { - shift @args; - bg_do("info ".join(' ', @args)); - } elsif ($args[0] eq 'echo') { - bg_do("echo"); - } elsif ($args[0] eq 'top') { - my $number = defined $args[1] ? $args[1] : 10; - bg_do("top ".$number); - } elsif ($args[0] eq 'cpan' && defined $args[1]) { - call_openurl('http://search.cpan.org/search?mode=module&query='.$args[1]); - } elsif ($args[0] eq 'autorun' && defined $args[1]) { - toggle_autorun($args[1]); - } elsif ($args[0] eq 'new') { - my $number = defined $args[1] ? $args[1] : 5; - bg_do("new ".$number); - } -} - -sub cmd_help { - my ($arg, $server, $witem) = @_; - $arg =~ s/\s+$//; - if ($arg =~ /^scriptassist/i) { - show_help(); - } -} - -sub sig_command_script_load { - my ($script, $server, $witem) = @_; - my ($sname, $plname, $pname, $xname) = get_names($script); - if ( exists $Irssi::Script::{$pname} ) { - if (my $code = "Irssi::Script::${pname}"->can('pre_unload')) { - print CLIENTCRAP "%R>>%n Triggering pre_unload function of $script..."; - $code->(); - } - } -} - -sub sig_default_command { - my ($cmd, $server) = @_; - return unless Irssi::settings_get_bool("scriptassist_check_unknown_commands"); - bg_do('unknown '.$cmd); -} - -sub sig_complete { - my ($list, $window, $word, $linestart, $want_space) = @_; - return unless $linestart =~ /^.script(assist)? (install|rate|ratings|update|check|contact|info|autorun)/i; - my @newlist; - my $str = $word; - foreach (@complist) { - if ($_ =~ /^(\Q$str\E.*)?$/) { - push @newlist, $_; - } - } - foreach (@{loaded_scripts()}) { - push @newlist, $_ if /^(\Q$str\E.*)?$/; - } - push @$list, $_ foreach @newlist; - Irssi::signal_stop(); -} - - -Irssi::settings_add_str($IRSSI{name}, 'scriptassist_script_sources', 'https://scripts.irssi.org/scripts.dmp'); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_cache_sources', 1); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_update_verbose', 1); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_check_verbose', 1); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_catch_script_errors', 1); - -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_install_unsigned_scripts', 1); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_use_gpg', 1); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_integrate', 1); -Irssi::settings_add_bool($IRSSI{name}, 'scriptassist_check_unknown_commands', 1); - -Irssi::signal_add_first("default command", 'sig_default_command'); -Irssi::signal_add_first('complete word', 'sig_complete'); -Irssi::signal_add_first('command script load', 'sig_command_script_load'); -Irssi::signal_add_first('command script unload', 'sig_command_script_load'); - -Irssi::signal_register({ 'script error' => [ 'Irssi::Script', 'string' ] }); -Irssi::signal_add_last('script error', 'sig_script_error'); - -Irssi::command_bind('scriptassist', 'cmd_scripassist'); -Irssi::command_bind('help', 'cmd_help'); - -Irssi::theme_register(['box_header', '%R,--[%n$*%R]%n', -'box_inside', '%R|%n $*', -'box_footer', '%R`--<%n$*%R>->%n', -]); - -foreach my $cmd ( ( 'check', - 'install', - 'update', - 'contact', - 'search', -# '-h', - 'help', -# 'ratings', -# 'rate', - 'info', -# 'echo', -# 'top', - 'cpan', - 'autorun', - 'new' ) ) { - Irssi::command_bind('scriptassist '.$cmd => sub { - cmd_scripassist("$cmd ".$_[0], $_[1], $_[2]); }); - if (Irssi::settings_get_bool('scriptassist_integrate')) { - Irssi::command_bind('script '.$cmd => sub { - cmd_scripassist("$cmd ".$_[0], $_[1], $_[2]); }); - } -} - -print CLIENTCRAP '%B>>%n '.$IRSSI{name}.' '.$VERSION.' loaded: /scriptassist help for help'; diff --git a/.irssi/scripts/splitlong.pl b/.irssi/scripts/splitlong.pl deleted file mode 100644 index 3c8a355..0000000 --- a/.irssi/scripts/splitlong.pl +++ /dev/null @@ -1,60 +0,0 @@ -# /set splitlong_max_length -# specifies the maximum length of a msg, automatically chosen when set to "0" -# default: 0 -# -# /set splitlong_line_start -# /set splitlong_line_end -# self-explanatory -# defaults: "... ", " ..." -### -use strict; -use vars qw($VERSION %IRSSI); - -use Irssi 20011001; - -$VERSION = "0.20"; -%IRSSI = ( - authors => "Bjoern \'fuchs\' Krombholz", - contact => "bjkro\@gmx.de", - name => "splitlong", - license => "Public Domain", - description => "Split overlong PRIVMSGs to msgs with length allowed by ircd", - changed => "Wed Jun 25 00:17:00 CET 2003", - changes => "Actually the real 0.19 (now 0.20), but upload didn't work some month ago, target problem fixed..." -); - -sub sig_command_msg { - my ($cmd, $server, $winitem) = @_; - my ( $param, $target,$data) = $cmd =~ /^(-\S*\s)?(\S*)\s(.*)/; - - my $maxlength = Irssi::settings_get_int('splitlong_max_length'); - my $lstart = Irssi::settings_get_str('splitlong_line_start'); - my $lend = Irssi::settings_get_str('splitlong_line_end'); - - if ($maxlength == 0) { - # 497 = 510 - length(":" . "!" . " PRIVMSG " . " :"); - $maxlength = 497 - length($server->{nick} . $server->{userhost} . $target); - } - my $maxlength2 = $maxlength - length($lend); - - if (length($data) > ($maxlength)) { - my @spltarr; - - while (length($data) > ($maxlength2)) { - my $pos = rindex($data, " ", $maxlength2); - push @spltarr, substr($data, 0, ($pos < ($maxlength/10 + 4)) ? $maxlength2 : $pos) . $lend; - $data = $lstart . substr($data, ($pos < ($maxlength/10 + 4)) ? $maxlength2 : $pos+1); - } - - push @spltarr, $data; - foreach (@spltarr) { - Irssi::signal_emit("command msg", "$target $_", $server, $winitem); - } - Irssi::signal_stop(); - } -} - -Irssi::settings_add_int('misc', 'splitlong_max_length', 0); -Irssi::settings_add_str('misc', 'splitlong_line_start', "... "); -Irssi::settings_add_str('misc', 'splitlong_line_end', " ..."); -Irssi::command_bind('msg', 'sig_command_msg'); diff --git a/.irssi/scripts/tmux_away.pl b/.irssi/scripts/tmux_away.pl deleted file mode 100644 index 36fb160..0000000 --- a/.irssi/scripts/tmux_away.pl +++ /dev/null @@ -1,202 +0,0 @@ -use Irssi; -use strict; -use FileHandle; - -use vars qw($VERSION %IRSSI); - -$VERSION = "2.1"; # e8934ed1ce04461 -%IRSSI = ( - authors => 'cdidier', - name => 'tmux_away', - description => 'set (un)away if tmux session is attached/detached', - license => 'GPL v2', - url => 'http://cybione.org', -); - -# tmux_away irssi module -# -# Written by Colin Didier <cdidier@cybione.org> and heavily based on -# screen_away irssi module version 0.9.7.1 written by Andreas 'ads' Scherbaum -# <ads@ufp.de>. -# -# Updated by John C. Vernaleo <john@netpurgatory.com> to handle tmux with -# named sessions and other code cleanup and forked as version 2.0. -# -# usage: -# -# put this script into your autorun directory and/or load it with -# /SCRIPT LOAD <name> -# -# there are 5 settings available: -# -# /set tmux_away_active ON/OFF/TOGGLE -# /set tmux_away_repeat <integer> -# /set tmux_away_grace <integer> -# /set tmux_away_message <string> -# /set tmux_away_window <string> -# /set tmux_away_nick <string> -# -# active means that you will be only set away/unaway, if this -# flag is set, default is ON -# repeat is the number of seconds, after the script will check the -# tmux session status again, default is 5 seconds -# grace is the number of seconds, to wait additionally, before -# setting you away, default is disabled (0) -# message is the away message sent to the server, default: not here ... -# window is a window number or name, if set, the script will switch -# to this window, if it sets you away, default is '1' -# nick is the new nick, if the script goes away -# will only be used it not empty - - -# variables -my $timer_name = undef; -my $away_status = 0; -my %old_nicks = (); -my %away = (); - -# Register formats -Irssi::theme_register( -[ - 'tmux_away_crap', - '{line_start}{hilight ' . $IRSSI{'name'} . ':} $0' -]); - -# try to find out if we are running in a tmux session -# (see if $ENV{TMUX} is set) -if (!defined($ENV{TMUX})) { - # just return, we will never be called again - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', - "no tmux session!"); - return; -} - -my @args_env = split(',', $ENV{TMUX}); -my $tmux_socket = $args_env[0]; - -# register config variables -Irssi::settings_add_bool('misc', $IRSSI{'name'} . '_active', 1); -Irssi::settings_add_int('misc', $IRSSI{'name'} . '_repeat', 5); -Irssi::settings_add_int('misc', $IRSSI{'name'} . '_grace', 0); -Irssi::settings_add_str('misc', $IRSSI{'name'} . '_message', "not here..."); -Irssi::settings_add_str('misc', $IRSSI{'name'} . '_window', "1"); -Irssi::settings_add_str('misc', $IRSSI{'name'} . '_nick', ""); - - -# check, set or reset the away status -sub tmux_away { - my ($immediate) = @_; - my ($status, @res); - - # only run, if activated - if (Irssi::settings_get_bool($IRSSI{'name'} . '_active') != 1) { - $away_status = 0; - } else { - if ($away_status == 0) { - # display init message at first time - my $grace = Irssi::settings_get_int($IRSSI{'name'} . '_grace'); - $grace = ", $grace seconds grace" if $grace; - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', - "activating $IRSSI{'name'} (interval: " . Irssi::settings_get_int($IRSSI{'name'} . '_repeat') . " seconds$grace)"); - $away_status = 2; - } - - # get actual tmux session status - chomp(@res = `tmux -S '$tmux_socket' lsc 2>&1`); - chomp(my $tmux_session = `tmux -S '$tmux_socket' display -p '#S' 2>/dev/null`); - if ($res[0] =~ /^server not found/ || $? >> 8) { - die "error getting tmux session status."; - } - $status = 1; # away, assumes the session is detached - foreach (@res) { - my @args_st = split(' '); - if ($args_st[1] eq $tmux_session) { - $status = 2; # unaway - } - } - - # unaway -> away - if ($status == 1 and $away_status != 1) { - if (my $grace = Irssi::settings_get_int($IRSSI{'name'} . '_grace')) { - if (!$immediate) { - Irssi::timeout_add_once($grace * 1000, 'tmux_away', '1'); - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', - "(in grace for away: $grace seconds)"); - return 1; - } - } - if (length(Irssi::settings_get_str($IRSSI{'name'} . '_window')) > 0) { - # if length of window is greater then 0, make this window active - Irssi::command('window goto ' . Irssi::settings_get_str($IRSSI{'name'} . '_window')); - } - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', "Set away"); - my $message = Irssi::settings_get_str($IRSSI{'name'} . '_message'); - if (length($message) == 0) { - # we have to set a message or we wouldnt go away - $message = "not here ..."; - } - foreach (Irssi::servers()) { - if (!$_->{usermode_away}) { - # user isn't yet away - $away{$_->{'tag'}} = 0; - $_->command("^AWAY " . ($_->{chat_type} ne 'SILC' ? "-one " : "") . "$message"); - if ($_->{chat_type} ne 'XMPP' and length(Irssi::settings_get_str($IRSSI{'name'} . '_nick')) > 0) { - # only change if actual nick isn't already the away nick - if (Irssi::settings_get_str($IRSSI{'name'} . '_nick') ne $_->{nick}) { - # keep old nick - $old_nicks{$_->{'tag'}} = $_->{nick}; - # set new nick - $_->command("NICK " . Irssi::settings_get_str($IRSSI{'name'} . '_nick')); - } - } - } else { - # user is already away, remember this - $away{$_->{'tag'}} = 1; - } - } - $away_status = $status; - - # away -> unaway - } elsif ($status == 2 and $away_status != 2) { - if (my $grace = Irssi::settings_get_int($IRSSI{'name'} . '_grace')) { - if (!$immediate) { - Irssi::timeout_add_once($grace * 1000, 'tmux_away', '1'); - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', - "(in grace for unaway: $grace seconds)"); - return 1; - } - } - # unset away - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', "Reset away"); - foreach (Irssi::servers()) { - if ($away{$_->{'tag'}} == 1) { - # user was already away, don't reset away - $away{$_->{'tag'}} = 0; - next; - } - $_->command("^AWAY" . (($_->{chat_type} ne 'SILC') ? " -one" : "")) if ($_->{usermode_away}); - if ($_->{chat_type} ne 'XMPP' and defined($old_nicks{$_->{'tag'}}) and length($old_nicks{$_->{'tag'}}) > 0) { - # set old nick - $_->command("NICK " . $old_nicks{$_->{'tag'}}); - $old_nicks{$_->{'tag'}} = ""; - } - } - $away_status = $status; - } elsif ($immediate) { - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'tmux_away_crap', - "in grace aborted"); - } - } - # but everytimes install a new timer - register_tmux_away_timer(); - return 0; -} - -# remove old timer and install a new one -sub register_tmux_away_timer { - # add new timer with new timeout (maybe the timeout has been changed) - Irssi::timeout_add_once(Irssi::settings_get_int($IRSSI{'name'} . '_repeat') * 1000, 'tmux_away', ''); -} - -# init process -tmux_away(); diff --git a/.irssi/scripts/trackbar.pl b/.irssi/scripts/trackbar.pl deleted file mode 100644 index 7ac9965..0000000 --- a/.irssi/scripts/trackbar.pl +++ /dev/null @@ -1,579 +0,0 @@ -## trackbar.pl -# -# This little script will do just one thing: it will draw a line each time you -# switch away from a window. This way, you always know just upto where you've -# been reading that window :) It also removes the previous drawn line, so you -# don't see double lines. -# -# redraw trackbar only works on irssi 0.8.17 or higher. -# -## - -## Usage: -# -# The script works right out of the box, but if you want you can change -# the working by /set'ing the following variables: -# -# Setting: trackbar_style -# Description: This setting will be the color of your trackbar line. -# By default the value will be '%K', only Irssi color -# formats are allowed. If you don't know the color formats -# by heart, you can take a look at the formats documentation. -# You will find the proper docs on http://www.irssi.org/docs. -# -# Setting: trackbar_string -# Description: This is the string that your line will display. This can -# be multiple characters or just one. For example: '~-~-' -# The default setting is '-'. -# Here are some unicode characters you can try: -# "───" => U+2500 => a line -# "═══" => U+2550 => a double line -# "━━━" => U+2501 => a wide line -# "▭ " => U+25ad => a white rectangle -# -# Setting: trackbar_use_status_window -# Description: If this setting is set to OFF, Irssi won't print a trackbar -# in the statuswindow -# -# Setting: trackbar_ignore_windows -# Description: A list of windows where no trackbar should be printed -# -# Setting: trackbar_print_timestamp -# Description: If this setting is set to ON, Irssi will print the formatted -# timestamp in front of the trackbar. -# -# Setting: trackbar_require_seen -# Description: Only clear the trackbar if it has been scrolled to. -# -# /mark is a command that will redraw the line at the bottom. -# -# Command: /trackbar, /trackbar goto -# Description: Jump to where the trackbar is, to pick up reading -# -# Command: /trackbar keep -# Description: Keep this window's trackbar where it is the next time -# you switch windows (then this flag is cleared again) -# -# Command: /mark, /trackbar mark -# Description: Remove the old trackbar and mark the bottom of this -# window with a new trackbar -# -# Command: /trackbar markvisible -# Description: Like mark for all visible windows -# -# Command: /trackbar markall -# Description: Like mark for all windows -# -# Command: /trackbar remove -# Description: Remove this window's trackbar -# -# Command: /trackbar removeall -# Description: Remove all windows' trackbars -# -# Command: /trackbar redraw -# Description: Force redraw of trackbars -# -## - -## -# -# For bugreports and other improvements contact one of the authors. -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this script; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -# -## - -use strict; -use warnings; -use vars qw($VERSION %IRSSI); - -$VERSION = "2.5"; # 56e983314dc1b85 - -%IRSSI = ( - authors => "Peter 'kinlo' Leurs, Uwe Dudenhoeffer, " . - "Michiel Holtkamp, Nico R. Wohlgemuth, " . - "Geert Hauwaerts", - contact => 'peter@pfoe.be', - patchers => 'Johan Kiviniemi (UTF-8), Uwe Dudenhoeffer (on-upgrade-remove-line)', - name => 'trackbar', - description => 'Shows a bar where you have last read a window.', - license => 'GNU General Public License', - url => 'http://www.pfoe.be/~peter/trackbar/', - commands => 'trackbar', -); - -## Comments and remarks. -# -# This script uses settings. -# Use /SET to change the value or /TOGGLE to switch it on or off. -# -# -# Tip: The command 'trackbar' is very usefull if you bind that to a key, -# so you can easily jump to the trackbar. Please see 'help bind' for -# more information about keybindings in Irssi. -# -# Command: /BIND meta2-P key F1 -# /BIND F1 command trackbar -# -## - -## Bugfixes and new items in this rewrite. -# -# * Remove all the trackbars before upgrading. -# * New setting trackbar_use_status_window to control the statuswindow trackbar. -# * New setting trackbar_print_timestamp to print a timestamp or not. -# * New command 'trackbar' to scroll up to the trackbar. -# * When resizing your terminal, Irssi will update all the trackbars to the new size. -# * When changing trackbar settings, change all the trackbars to the new settings. -# * New command 'trackbar mark' to draw a new trackbar (The old '/mark'). -# * New command 'trackbar markall' to draw a new trackbar in each window. -# * New command 'trackbar remove' to remove the trackbar from the current window. -# * New command 'trackbar removeall' to remove all the trackbars. -# * Don't draw a trackbar in empty windows. -# * Added a version check to prevent Irssi redraw errors. -# * Fixed a bookmark NULL versus 0 bug. -# * Fixed a remove-line bug in Uwe Dudenhoeffer his patch. -# * New command 'help trackbar' to display the trackbar commands. -# * Fixed an Irssi startup bug, now processing each auto-created window. -# -## - -## Known bugs and the todolist. -# -# Todo: * Instead of drawing a line, invert the line. -# -## - -## Authors: -# -# - Main maintainer & author: Peter 'kinlo' Leurs -# - Many thanks to Timo 'cras' Sirainen for placing me on my way -# - on-upgrade-remove-line patch by Uwe Dudenhoeffer -# - trackbar resizing by Michiel Holtkamp (02 Jul 2012) -# - scroll to trackbar, window excludes, and timestamp options by Nico R. -# Wohlgemuth (22 Sep 2012) -# -## - -## Version history: -# -# 2.5: - merge back on scripts.irssi.org -# - fix /trackbar redraw broken in 2.4 -# - fix legacy encodings -# - add workaround for irssi issue #271 -# 2.4: - add support for horizontal splits -# 2.3: - add some features for seen tracking using other scripts -# 2.0: - big rewrite based on 1.4 -# * removed /tb, you can have it with /alias tb trackbar if you want -# * subcommand and settings changes: -# /trackbar vmark => /trackbar markvisible -# /trackbar scroll => /trackbar goto (or just /trackbar) -# /trackbar help => /help trackbar -# /set trackbar_hide_windows => /set trackbar_ignore_windows -# /set trackbar_timestamp => /set trackbar_print_timestamp -# * magic line strings were removed, just paste the unicode you want! -# * trackbar_timestamp_styled is not currently supported -# 1.9: - add version guard -# 1.8: - sub draw_bar -# 1.7: - Added /tb scroll, trackbar_hide_windows, trackbar_timestamp_timestamp -# and trackbar_timestamp_styled -# 1.6: - Work around Irssi resize bug, please do /upgrade! (see below) -# 1.5: - Resize trackbars in all windows when terminal is resized -# 1.4: - Changed our's by my's so the irssi script header is valid -# - Removed utf-8 support. In theory, the script should work w/o any -# problems for utf-8, just set trackbar_string to a valid utf-8 character -# and everything *should* work. However, this script is being plagued by -# irssi internal bugs. The function Irssi::settings_get_str does NOT handle -# unicode strings properly, hence you will notice problems when setting the bar -# to a unicode char. For changing your bar to utf-8 symbols, read the line sub. -# 1.3: - Upgrade now removes the trackbars. -# - Some code cleanups, other defaults -# - /mark sets the line to the bottom -# 1.2: - Support for utf-8 -# - How the bar looks can now be configured with trackbar_string -# and trackbar_style -# 1.1: - Fixed bug when closing window -# 1.0: - Initial release -# -## - -use Irssi; -use Irssi::TextUI; -use Encode; - -use POSIX qw(strftime); - -sub cmd_help { - my ($args) = @_; - if ($args =~ /^trackbar *$/i) { - print CLIENTCRAP <<HELP -%9Syntax:%9 - -TRACKBAR -TRACKBAR GOTO -TRACKBAR KEEP -TRACKBAR MARK -TRACKBAR MARKVISIBLE -TRACKBAR MARKALL -TRACKBAR REMOVE -TRACKBAR REMOVEALL -TRACKBAR REDRAW - -%9Parameters:%9 - - GOTO: Jump to where the trackbar is, to pick up reading - KEEP: Keep this window's trackbar where it is the next time - you switch windows (then this flag is cleared again) - MARK: Remove the old trackbar and mark the bottom of this - window with a new trackbar - MARKVISIBLE: Like mark for all visible windows - MARKALL: Like mark for all windows - REMOVE: Remove this window's trackbar - REMOVEALL: Remove all windows' trackbars - REDRAW: Force redraw of trackbars - -%9Description:%9 - - Manage a trackbar. Without arguments, it will scroll up to the trackbar. - -%9Examples:%9 - - /TRACKBAR MARK - /TRACKBAR REMOVE -HELP - } -} - -Irssi::theme_register([ - 'trackbar_loaded', '%R>>%n %_Scriptinfo:%_ Loaded $0 version $1 by $2.', - 'trackbar_wrong_version', '%R>>%n %_Trackbar:%_ Please upgrade your client to 0.8.17 or above if you would like to use this feature of trackbar.', - 'trackbar_all_removed', '%R>>%n %_Trackbar:%_ All the trackbars have been removed.', - 'trackbar_not_found', '%R>>%n %_Trackbar:%_ No trackbar found in this window.', -]); - -my $old_irssi = Irssi::version < 20140701; -sub check_version { - if ($old_irssi) { - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_wrong_version'); - return; - } else { - return 1; - } -} - -sub is_utf8 { - lc Irssi::settings_get_str('term_charset') eq 'utf-8' -} - -my (%config, %keep_trackbar, %unseen_trackbar); - -sub remove_one_trackbar { - my $win = shift; - my $view = shift || $win->view; - my $line = $view->get_bookmark('trackbar'); - if (defined $line) { - my $bottom = $view->{bottom}; - $view->remove_line($line); - $win->command('^scrollback end') if $bottom && !$win->view->{bottom}; - $view->redraw; - } -} - -sub add_one_trackbar { - my $win = shift; - my $view = shift || $win->view; - $win->print(line($win->{width}), MSGLEVEL_NEVER); - $view->set_bookmark_bottom('trackbar'); - $unseen_trackbar{ $win->{_irssi} } = 1; - Irssi::signal_emit("window trackbar added", $win); - $view->redraw; -} - -sub update_one_trackbar { - my $win = shift; - my $view = shift || $win->view; - my $force = shift; - my $ignored = win_ignored($win, $view); - remove_one_trackbar($win, $view) - if $force || !defined $force || !$ignored; - add_one_trackbar($win, $view) - if $force || !$ignored; -} - -sub win_ignored { - my $win = shift; - my $view = shift || $win->view; - return 1 unless $view->{buffer}{lines_count}; - return 1 if $win->{name} eq '(status)' && !$config{use_status_window}; - no warnings 'uninitialized'; - return 1 if grep { $win->{name} eq $_ || $win->{refnum} eq $_ - || $win->get_active_name eq $_ } @{ $config{ignore_windows} }; - return 0; -} - -sub sig_window_changed { - my ($newwindow, $oldwindow) = @_; - return unless $oldwindow; - redraw_one_trackbar($newwindow) unless $old_irssi; - trackbar_update_seen($newwindow); - return if delete $keep_trackbar{ $oldwindow->{_irssi} }; - trackbar_update_seen($oldwindow); - return if $config{require_seen} && $unseen_trackbar{ $oldwindow->{_irssi } }; - update_one_trackbar($oldwindow, undef, 0); -} - -sub trackbar_update_seen { - my $win = shift; - return unless $win; - return unless $unseen_trackbar{ $win->{_irssi} }; - - my $view = $win->view; - my $line = $view->get_bookmark('trackbar'); - unless ($line) { - delete $unseen_trackbar{ $win->{_irssi} }; - Irssi::signal_emit("window trackbar seen", $win); - return; - } - my $startline = $view->{startline}; - return unless $startline; - - if ($startline->{info}{time} < $line->{info}{time} - || $startline->{_irssi} == $line->{_irssi}) { - delete $unseen_trackbar{ $win->{_irssi} }; - Irssi::signal_emit("window trackbar seen", $win); - } -} - -sub screen_length; -{ local $@; - eval { require Text::CharWidth; }; - unless ($@) { - *screen_length = sub { Text::CharWidth::mbswidth($_[0]) }; - } - else { - *screen_length = sub { - my $temp = shift; - Encode::_utf8_on($temp) if is_utf8(); - length($temp) - }; - } -} - -{ my %strip_table = ( - (map { $_ => '' } (split //, '04261537' . 'kbgcrmyw' . 'KBGCRMYW' . 'U9_8I:|FnN>#[' . 'pP')), - (map { $_ => $_ } (split //, '{}%')), - ); - sub c_length { - my $o = Irssi::strip_codes($_[0]); - $o =~ s/(%(%|Z.{6}|z.{6}|X..|x..|.))/exists $strip_table{$2} ? $strip_table{$2} : - $2 =~ m{x(?:0[a-f]|[1-6][0-9a-z]|7[a-x])|z[0-9a-f]{6}}i ? '' : $1/gex; - screen_length($o) - } -} - -sub line { - my ($width, $time) = @_; - my $string = $config{string}; - $string = ' ' unless length $string; - $time ||= time; - - Encode::_utf8_on($string) if is_utf8(); - my $length = c_length($string); - - my $format = ''; - if ($config{print_timestamp}) { - $format = $config{timestamp_str}; - $format =~ y/%/\01/; - $format =~ s/\01\01/%/g; - $format = strftime($format, localtime $time); - $format =~ y/\01/%/; - } - - my $times = $width / $length; - $times += 1 if $times != int $times; - my $style = "$config{style}"; - Encode::_utf8_on($style) if is_utf8(); - $format .= $style; - $width -= c_length($format); - $string x= $times; - chop $string while length $string && c_length($string) > $width; - return $format . $string; -} - -sub remove_all_trackbars { - for my $window (Irssi::windows) { - next unless ref $window; - remove_one_trackbar($window); - } -} - -sub UNLOAD { - remove_all_trackbars(); -} - -sub redraw_one_trackbar { - my $win = shift; - my $view = $win->view; - my $line = $view->get_bookmark('trackbar'); - return unless $line; - my $bottom = $view->{bottom}; - $win->print_after($line, MSGLEVEL_NEVER, line($win->{width}, $line->{info}{time}), - $line->{info}{time}); - $view->set_bookmark('trackbar', $win->last_line_insert); - $view->remove_line($line); - $win->command('^scrollback end') if $bottom && !$win->view->{bottom}; - $view->redraw; -} - -sub redraw_trackbars { - return unless check_version(); - for my $win (Irssi::windows) { - next unless ref $win; - redraw_one_trackbar($win); - } -} - -sub goto_trackbar { - my $win = Irssi::active_win; - my $line = $win->view->get_bookmark('trackbar'); - - if ($line) { - $win->command("scrollback goto ". strftime("%d %H:%M:%S", localtime($line->{info}{time}))); - } else { - $win->printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_not_found'); - } -} - -sub cmd_mark { - update_one_trackbar(Irssi::active_win, undef, 1); -} - -sub cmd_markall { - for my $window (Irssi::windows) { - next unless ref $window; - update_one_trackbar($window); - } -} - -sub signal_stop { - Irssi::signal_stop; -} - -sub cmd_markvisible { - my @wins = Irssi::windows; - my $awin = - my $bwin = Irssi::active_win; - my $awin_counter = 0; - Irssi::signal_add_priority('window changed' => 'signal_stop', -99); - do { - Irssi::active_win->command('window up'); - $awin = Irssi::active_win; - update_one_trackbar($awin); - ++$awin_counter; - } until ($awin->{refnum} == $bwin->{refnum} || $awin_counter >= @wins); - Irssi::signal_remove('window changed' => 'signal_stop'); -} - -sub cmd_trackbar_remove_one { - remove_one_trackbar(Irssi::active_win); -} - -sub cmd_remove_all_trackbars { - remove_all_trackbars(); - Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_all_removed'); -} - -sub cmd_keep_once { - $keep_trackbar{ Irssi::active_win->{_irssi} } = 1; -} - -sub trackbar_runsub { - my ($data, $server, $item) = @_; - $data =~ s/\s+$//g; - - if ($data) { - Irssi::command_runsub('trackbar', $data, $server, $item); - } else { - goto_trackbar(); - } -} - -sub update_config { - my $was_status_window = $config{use_status_window}; - $config{style} = Irssi::settings_get_str('trackbar_style'); - $config{string} = Irssi::settings_get_str('trackbar_string'); - $config{require_seen} = Irssi::settings_get_bool('trackbar_require_seen'); - $config{ignore_windows} = [ split /[,\s]+/, Irssi::settings_get_str('trackbar_ignore_windows') ]; - $config{use_status_window} = Irssi::settings_get_bool('trackbar_use_status_window'); - $config{print_timestamp} = Irssi::settings_get_bool('trackbar_print_timestamp'); - if (defined $was_status_window && $was_status_window != $config{use_status_window}) { - if (my $swin = Irssi::window_find_name('(status)')) { - if ($config{use_status_window}) { - update_one_trackbar($swin); - } - else { - remove_one_trackbar($swin); - } - } - } - if ($config{print_timestamp}) { - my $ts_format = Irssi::settings_get_str('timestamp_format'); - my $ts_theme = Irssi::current_theme->get_format('fe-common/core', 'timestamp'); - my $render_str = Irssi::current_theme->format_expand($ts_theme); - (my $ts_escaped = $ts_format) =~ s/([%\$])/$1$1/g; - $render_str =~ s/(?|\$(.)(?!\w)|\$\{(\w+)\})/$1 eq 'Z' ? $ts_escaped : $1/ge; - $config{timestamp_str} = $render_str; - } - redraw_trackbars() unless $old_irssi; -} - -Irssi::settings_add_str('trackbar', 'trackbar_string', is_utf8() ? "\x{2500}" : '-'); -Irssi::settings_add_str('trackbar', 'trackbar_style', '%K'); -Irssi::settings_add_str('trackbar', 'trackbar_ignore_windows', ''); -Irssi::settings_add_bool('trackbar', 'trackbar_use_status_window', 1); -Irssi::settings_add_bool('trackbar', 'trackbar_print_timestamp', 0); -Irssi::settings_add_bool('trackbar', 'trackbar_require_seen', 0); - -update_config(); - -Irssi::signal_add_last( 'mainwindow resized' => 'redraw_trackbars') - unless $old_irssi; - -Irssi::signal_register({'window trackbar added' => [qw/Irssi::UI::Window/]}); -Irssi::signal_register({'window trackbar seen' => [qw/Irssi::UI::Window/]}); -Irssi::signal_register({'gui page scrolled' => [qw/Irssi::UI::Window/]}); -Irssi::signal_add_last('gui page scrolled' => 'trackbar_update_seen'); - -Irssi::signal_add('setup changed' => 'update_config'); -Irssi::signal_add_priority('session save' => 'remove_all_trackbars', Irssi::SIGNAL_PRIORITY_HIGH-1); - -Irssi::signal_add('window changed' => 'sig_window_changed'); - -Irssi::command_bind('trackbar goto' => 'goto_trackbar'); -Irssi::command_bind('trackbar keep' => 'cmd_keep_once'); -Irssi::command_bind('trackbar mark' => 'cmd_mark'); -Irssi::command_bind('trackbar markvisible' => 'cmd_markvisible'); -Irssi::command_bind('trackbar markall' => 'cmd_markall'); -Irssi::command_bind('trackbar remove' => 'cmd_trackbar_remove_one'); -Irssi::command_bind('trackbar removeall' => 'cmd_remove_all_trackbars'); -Irssi::command_bind('trackbar redraw' => 'redraw_trackbars'); -Irssi::command_bind('trackbar' => 'trackbar_runsub'); -Irssi::command_bind('mark' => 'cmd_mark'); -Irssi::command_bind_last('help' => 'cmd_help'); - -Irssi::printformat(MSGLEVEL_CLIENTCRAP, 'trackbar_loaded', $IRSSI{name}, $VERSION, $IRSSI{authors}); - -# workaround for issue #271 -{ package Irssi::Nick } diff --git a/.irssi/scripts/twtopic.pl b/.irssi/scripts/twtopic.pl deleted file mode 100644 index a32e3f2..0000000 --- a/.irssi/scripts/twtopic.pl +++ /dev/null @@ -1,193 +0,0 @@ -# John Engelbrecht's original versions (<= 1.0.2) were released under the public -# domain. Ryan Kavanagh's changes are distributed under the ISC license: -# -# Copyright (C) 2017 Ryan Kavanagh <rak@ryanak.ca> -# -# Permission to use, copy, modify, and/or distribute this software for any -# purpose with or without fee is hereby granted, provided that the above -# copyright notice and this permission notice appear in all copies. -# -# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH -# REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY -# AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, -# INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM -# LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR -# OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR -# PERFORMANCE OF THIS SOFTWARE. - -use strict; -use vars qw($VERSION %IRSSI); -use Irssi; -use Irssi::Irc; -use Irssi::TextUI; - -$VERSION = '2.0'; -%IRSSI = ( - authors => 'John Engelbrecht, Ryan Kavanagh', - contact => 'jengelbr@yahoo.com, rak@ryanak.ca', - name => 'twtopic.pl', - description => 'Animated Topic bar.', - sbitems => 'twtopic', - license => 'Public Domain, ISC', - changed => 'Wed Jan 03 16:20:17 EST 2017', - url => 'http://irssi.darktalker.net' . "\n", -); - -my $instrut = - ".--------------------------------------------------.\n" - . "| 1.) shell> mkdir ~/.irssi/scripts |\n" - . "| 2.) shell> cp twtopic.pl ~/.irssi/scripts/ |\n" - . "| 3.) shell> mkdir ~/.irssi/scripts/autorun |\n" - . "| 4.) shell> ln -s ~/.irssi/scripts/twtopic.pl \\ |\n" - . "| ~/.irssi/scripts/autorun/twtopic.pl |\n" - . "| 5.) /sbar topic remove topic |\n" - . "| 6.) /sbar topic remove topic_empty |\n" - . "| 7.) /sbar topic add -after topicbarstart |\n" - . "| -priority 100 -alignment left twtopic |\n" - . "| 9.) /toggle twtopic_instruct and last /save |\n" - . "|--------------------------------------------------|\n" - . "| Options: Default: |\n" - . "| /set twtopic_refresh <speed> 150 |\n" - . "| /set twtopic_size <size> 20 |\n" - . "| /set twtopic_padding <size> 20 |\n" - . "| /set twtopic_auto_resize <ON|OFF> OFF |\n" - . "| /set twtopic_ar_padding <size> 0 |\n" - . "| /set twtopic_min_scroll <ON|OFF> OFF |\n" - . "| /set twtopic_init_pause <length> 10 |\n" - . "| /toggle twtopic_instruct |Startup instructions |\n" - . "\`--------------------------------------------------'"; - -my $timeout; -my $start_pos = 0; -my $size; -my $min_scroll; -my $padding; -my $topic = ""; -my @mirc_color_arr = ( - "\0031", "\0035", "\0033", "\0037", "\0032", "\0036", - "\00310", "\0030", "\00314", "\0034", "\0039", "\0038", - "\00312", "\00313", "\00311", "\00315", "\017" -); - -sub setup { - my $window = Irssi::active_win; - if ( Irssi::settings_get_bool('twtopic_auto_resize') ) { - $size = - $window->{'width'} - Irssi::settings_get_int('twtopic_ar_padding'); - } - else { - $size = Irssi::settings_get_int('twtopic_size'); - } - # Subtract 4 because we wrap the topic in '[ ' / ' ]'. - $size = $size - 4; - $min_scroll = Irssi::settings_get_bool('twtopic_min_scroll'); - $padding = Irssi::settings_get_int('twtopic_padding'); - update_topic(); -} - -sub regular_timer { - my $time = Irssi::settings_get_int('twtopic_refresh'); - Irssi::timeout_remove($timeout); - $timeout = Irssi::timeout_add( $time, 'reload', undef ); -} - -sub init_timer { - my $time = Irssi::settings_get_int('twtopic_init_pause'); - Irssi::timeout_remove($timeout); - $timeout = Irssi::timeout_add( $time, 'regular_timer', undef ); -} - -sub show { - my ( $item, $get_size_only ) = @_; - my $text = get(); - $text = "[ " . $text . " ]"; - $item->default_handler( $get_size_only, $text, undef, 1 ); -} - -sub update_topic { - $topic = ""; - my $name = Irssi::active_win()->{active}->{name}; - my $type = Irssi::active_win()->{active}->{type}; - if ( $name eq "" ) { - # We're in the status window - $topic = - "Irssi website: http://www.irssi.org, " - . "Irssi IRC channel: #irssi @ irc://irc.freenode:6667, " - . "twtopic has been written by Tech Wizard and ryanakca"; - } - elsif ( $type eq "QUERY" ) { - $topic = "You are now talking to...... " . $name; - } - else { - my $channel = Irssi::Irc::Server->channel_find($name); - $topic = $channel->{topic}; - foreach (@mirc_color_arr) { $topic =~ s/$_//g; } - } - if ( $topic eq "" ) { - $topic = "=-=-=-=-= No Topic =-=-=-=-=-=-=-"; - } - $topic =~ s/(\00313)+//; - $topic =~ s/(\002)+//; - $topic =~ s/(\001)+//; - # Reset the topic and pause - init_timer(); - # The length of the topic may have changed. We should reset our $start_pos - # to avoid going off the end in case the topic got shorter. - $start_pos = -1; - reload (); -} - -sub get { - my $topiclen = length($topic); - if ( $topiclen <= $size && $min_scroll ) { - return $topic . ( ' ' x ( $size - $topiclen ) ); - } - my $padded = $topic . ( ' ' x $padding ); - my $str = ""; - my $needed = $size - length($str); - while ( $needed > 0 ) { - if ( $needed < length($padded) - $start_pos ) { - $str = $str . substr( $padded, $start_pos, $needed ); - } - elsif ( $needed < length($padded) ) { - $str = - $str - . substr( $padded, $start_pos ) - . substr( $padded, 0, $needed - length($padded) ); - } - else { - $str = - $str - . substr( $padded, $start_pos ) - . substr( $padded, 0, $start_pos ); - } - $needed = $size - length($str); - } - $start_pos = $start_pos + 1 < length($padded) ? $start_pos + 1 : 0; - return $str; -} - - -Irssi::signal_add( 'channel topic changed', 'update_topic' ); -Irssi::signal_add( 'setup changed', 'setup' ); -Irssi::signal_add( 'terminal resized', 'setup' ); -Irssi::signal_add( 'window changed', 'update_topic' ); - -Irssi::settings_add_bool( 'tech_addon', 'twtopic_auto_resize', 0 ); -Irssi::settings_add_bool( 'tech_addon', 'twtopic_instruct', 1 ); -Irssi::settings_add_bool( 'tech_addon', 'twtopic_min_scroll', 0 ); -Irssi::settings_add_int( 'tech_addon', 'twtopic_ar_padding', 10 ); -Irssi::settings_add_int( 'tech_addon', 'twtopic_init_pause', 10 ); -Irssi::settings_add_int( 'tech_addon', 'twtopic_padding', 20 ); -Irssi::settings_add_int( 'tech_addon', 'twtopic_refresh', 150 ); -Irssi::settings_add_int( 'tech_addon', 'twtopic_size', 20 ); - -sub reload { Irssi::statusbar_items_redraw('twtopic'); } - -if ( Irssi::settings_get_bool('twtopic_instruct') ) { - print $instrut; -} - -setup(); - -Irssi::statusbar_item_register( 'twtopic', '$0', 'show' ); diff --git a/.irssi/scripts/usercount.pl b/.irssi/scripts/usercount.pl deleted file mode 100644 index 650f9f3..0000000 --- a/.irssi/scripts/usercount.pl +++ /dev/null @@ -1,184 +0,0 @@ -use strict; -use Irssi 20040119.2359 (); -use vars qw($VERSION %IRSSI); -$VERSION = "1.19"; -%IRSSI = ( - authors => 'David Leadbeater, Timo Sirainen, Georg Lukas', - contact => 'dgl@dgl.cx, tss@iki.fi, georg@boerde.de', - name => 'usercount', - description => 'Adds a usercount for a channel as a statusbar item', - sbitems => 'usercount', - license => 'GNU GPLv2 or later', - url => 'http://irssi.dgl.cx/', - changes => 'Only show halfops if server supports them', -); - -# Once you have loaded this script run the following command: -# /statusbar window add usercount -# You can also add -alignment left|right option - -# Settings: -# /toggle usercount_show_zero to show item even when there are no users -# /toggle usercount_show_ircops (default off) -# /toggle usercount_show_halfops (default on) - -# you can customize the look of this item from theme file: -# sb_usercount = "{sb %_$0%_ nicks ($1-)}"; -# sb_uc_ircops = "%_*%_$*"; -# sb_uc_ops = "%_@%_$*"; -# sb_uc_halfops = "%_%%%_$*"; -# sb_uc_voices = "%_+%_$*"; -# sb_uc_normal = "$*"; -# sb_uc_space = " "; - - -use Irssi::TextUI; - -my ($ircops, $ops, $halfops, $voices, $normal, $total); -my ($timeout_tag, $recalc); - -# Called to make the status bar item -sub usercount { - my ($item, $get_size_only) = @_; - my $wi = !Irssi::active_win() ? undef : Irssi::active_win()->{active}; - - if(!ref $wi || $wi->{type} ne "CHANNEL") { # only works on channels - return unless ref $item; - $item->{min_size} = $item->{max_size} = 0; - return; - } - - if ($recalc) { - $recalc = 0; - calc_users($wi); - } - - my $theme = Irssi::current_theme(); - my $format = $theme->format_expand("{sb_usercount}"); - if ($format) { - # use theme-specific look - my $ircopstr = $theme->format_expand("{sb_uc_ircops $ircops}", - Irssi::EXPAND_FLAG_IGNORE_EMPTY); - my $opstr = $theme->format_expand("{sb_uc_ops $ops}", - Irssi::EXPAND_FLAG_IGNORE_EMPTY); - my $halfopstr = $theme->format_expand("{sb_uc_halfops $halfops}", - Irssi::EXPAND_FLAG_IGNORE_EMPTY); - my $voicestr = $theme->format_expand("{sb_uc_voices $voices}", - Irssi::EXPAND_FLAG_IGNORE_EMPTY); - my $normalstr = $theme->format_expand("{sb_uc_normal $normal}", - Irssi::EXPAND_FLAG_IGNORE_EMPTY); - my $space = $theme->format_expand('{sb_uc_space}', - Irssi::EXPAND_FLAG_IGNORE_EMPTY); - $space = " " unless $space; - - my $str = ""; - $str .= $ircopstr.$space if defined $ircops; - $str .= $opstr.$space if defined $ops; - $str .= $halfopstr.$space if defined $halfops; - $str .= $voicestr.$space if defined $voices; - $str .= $normalstr.$space if defined $normal; - $str =~ s/\Q$space\E$//; - - $format = $theme->format_expand("{sb_usercount $total $str}", - Irssi::EXPAND_FLAG_IGNORE_REPLACES); - } else { - # use the default look - $format = "{sb \%_$total\%_ nicks \%c(\%n"; - $format .= '*'.$ircops.' ' if (defined $ircops); - $format .= '@'.$ops.' ' if (defined $ops); - $format .= '%%'.$halfops.' ' if (defined $halfops); - $format .= "+$voices " if (defined $voices); - $format .= "$normal " if (defined $normal); - $format =~ s/ $//; - $format .= "\%c)}"; - } - - $item->default_handler($get_size_only, $format, undef, 1); -} - -sub calc_users() { - my $channel = shift; - my $server = $channel->{server}; - - $ircops = $ops = $halfops = $voices = $normal = 0; - for ($channel->nicks()) { - if ($_->{serverop}) { - $ircops++; - } - - if ($_->{op}) { - $ops++; - } elsif ($_->{halfop}) { - $halfops++; - } elsif ($_->{voice}) { - $voices++; - } else { - $normal++; - } - } - - $total = $ops+$halfops+$voices+$normal; - - if (!Irssi::settings_get_bool('usercount_show_zero')) { - $ircops = undef if ($ircops == 0); - $ops = undef if ($ops == 0); - $halfops = undef if ($halfops == 0); - $voices = undef if ($voices == 0); - $normal = undef if ($normal == 0); - } - - # Server doesn't support halfops? - if($server->isupport("PREFIX") !~ /\%/) { - $halfops = undef; - } else { - $halfops = undef unless Irssi::settings_get_bool('usercount_show_halfops'); - } - - $ircops = undef unless Irssi::settings_get_bool('usercount_show_ircops'); -} - -sub refresh { - if ($timeout_tag > 0) { - Irssi::timeout_remove($timeout_tag); - $timeout_tag = 0; - } - Irssi::statusbar_items_redraw('usercount'); -} - -sub refresh_check { - my $channel = shift; - my $wi = ref Irssi::active_win() ? Irssi::active_win()->{active} : 0; - - return unless ref $wi && ref $channel; - return if $wi->{name} ne $channel->{name}; - return if $wi->{server}->{tag} ne $channel->{server}->{tag}; - - # don't refresh immediately, or we'll end up refreshing - # a lot around netsplits - $recalc = 1; - Irssi::timeout_remove($timeout_tag) if ($timeout_tag > 0); - $timeout_tag = Irssi::timeout_add(500, 'refresh', undef); -} - -sub refresh_recalc { - $recalc = 1; - refresh(); -} - -$recalc = 1; -$timeout_tag = 0; - -Irssi::settings_add_bool('usercount', 'usercount_show_zero', 1); -Irssi::settings_add_bool('usercount', 'usercount_show_ircops', 0); -Irssi::settings_add_bool('usercount', 'usercount_show_halfops', 1); - -Irssi::statusbar_item_register('usercount', undef, 'usercount'); -Irssi::statusbars_recreate_items(); - -Irssi::signal_add_last('nicklist new', 'refresh_check'); -Irssi::signal_add_last('nicklist remove', 'refresh_check'); -Irssi::signal_add_last('nick mode changed', 'refresh_check'); -Irssi::signal_add_last('setup changed', 'refresh_recalc'); -Irssi::signal_add_last('window changed', 'refresh_recalc'); -Irssi::signal_add_last('window item changed', 'refresh_recalc'); - diff --git a/.jackdrc b/.jackdrc deleted file mode 100644 index aa08d97..0000000 --- a/.jackdrc +++ /dev/null @@ -1 +0,0 @@ -/usr/bin/jackd -r -dalsa -dhw:0 -r48000 -p1024 -n4 diff --git a/.local/share/applications/sp.desktop b/.local/share/applications/sp.desktop deleted file mode 100644 index 022c6bd..0000000 --- a/.local/share/applications/sp.desktop +++ /dev/null @@ -1,11 +0,0 @@ -[Desktop Entry] -Type=Application -Name=Spotify CLI -GenericName=Music Player -Icon=spotify-client -TryExec=sp -Exec=sp open %U -Terminal=false -MimeType=x-scheme-handler/spotify; -Categories=Audio;Music;Player;AudioVideo; -StartupWMClass=spotify diff --git a/.mailcheckrc b/.mailcheckrc deleted file mode 100644 index ba2eade..0000000 --- a/.mailcheckrc +++ /dev/null @@ -1,45 +0,0 @@ -# mailcheckrc Default configuration for Mailcheck program -# -# This is a sample mailcheckrc file. It provies a good starting point, -# but it probably isn't exactly what you want. See mailcheck(1) for -# more information. - -# If you edit /etc/login.defs to turn off mailbox checking, you'll -# probably want to enable this next line: -#/var/spool/mail/$(USER) - -# If you're using qmail's Maildir feature, you'll probably want to -# enable this line: -#$(HOME)/Maildir/ - -# For qmail's mbox file in user's home directory: -#$(HOME)/Mailbox - -# Mailcheck also supports remote POP3 and IMAP mailboxes. Most users -# will want to set these up in a .mailcheckrc file in their home -# directory, not here. - -# If you have a remote POP3 mailbox, use a line like the following -# if your username is the same there as here. -#pop3://servername -# -# If your POP3 username is different there than here: -#pop3://username@servernameint -# -# In either case, you need to put an entry in $HOME/.netrc for the password. -# .netrc is in the form: -# -# machine mail.example.com login rmf1 password MyPasWrd -# -# where mail.example.com, rmf1, and MyPasWrd are the values for your account, -# and machine, login, and password are literal text in the file. - -# An IMAP account is similar to a POP account, but you can specify a -# mailbox path: -#imap://servername/inbox - -# For both POP3 and IMAP, you can specify a nonstandard port: -#pop3://servername:1110 -#imap://servername:1143/inbox -imap://ryan@localhost/ -imap://ryan@localhost/QueensU.INBOX diff --git a/.notmuch-config b/.notmuch-config deleted file mode 100644 index 5697b61..0000000 --- a/.notmuch-config +++ /dev/null @@ -1,68 +0,0 @@ -# .notmuch-config - Configuration file for the notmuch mail system -# -# For more information about notmuch, see http://notmuchmail.org - -# Database configuration -# -# The only value supported here is 'path' which should be the top-level -# directory where your mail currently exists and to where mail will be -# delivered in the future. Files should be individual email messages. -# Notmuch will store its database within a sub-directory of the path -# configured here named ".notmuch". -# -[database] -path=/home/ryan/.maildb/GMAIL/ - -# User configuration -# -# Here is where you can let notmuch know how you would like to be -# addressed. Valid settings are -# -# name Your full name. -# primary_email Your primary email address. -# other_email A list (separated by ';') of other email addresses -# at which you receive email. -# -# Notmuch will use the various email addresses configured here when -# formatting replies. It will avoid including your own addresses in the -# recipient list of replies, and will set the From address based on the -# address to which the original email was addressed. -# -[user] -name=Ryan Kavanagh -primary_email=rak@debian.org -other_email=ryanakca@gmail.com;9rak@queensu.ca;ryan.kavanagh@queensu.ca;ryan@ryanak.ca;ryanakca-guest@users.alioth.debian.org;ryanakca@ubuntu.com;ryan@cs.queensu.ca;rak@debian.org;ryank@cs.mcgill.ca;ryan.kavanagh@mail.mcgill.ca; - -# Configuration for "notmuch new" -# -# The following options are supported here: -# -# tags A list (separated by ';') of the tags that will be -# added to all messages incorporated by "notmuch new". -# -[new] -tags=unread; - -# Maildir compatibility configuration -# -# The following option is supported here: -# -# synchronize_flags Valid values are true and false. -# -# If true, then the following maildir flags (in message filenames) -# will be syncrhonized with the corresponding notmuch tags: -# -# Flag Tag -# ---- ------- -# D draft -# F flagged -# P passed -# R replied -# S unread (added when 'S' flag is not present) -# -# The "notmuch new" command will notice flag changes in filenames -# and update tags, while the "notmuch tag" and "notmuch restore" -# commands will notice tag changes and update flags in filenames -# -[maildir] -synchronize_flags=true diff --git a/.pythonrc.py b/.pythonrc.py deleted file mode 100644 index 29373d4..0000000 --- a/.pythonrc.py +++ /dev/null @@ -1,8 +0,0 @@ -# ~/.pythonrc -# enable syntax completion -try: - import rlcompleter - rlcompleter.readline.parse_and_bind("tab: complete") -except: - import readline - readline.parse_and_bind("tab: complete") diff --git a/.screenlayout/epsilon-McGill.sh b/.screenlayout/epsilon-McGill.sh deleted file mode 100755 index 58812f1..0000000 --- a/.screenlayout/epsilon-McGill.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output LVDS1 --mode 1024x600 --pos 264x1050 --rotate normal --output VGA1 --mode 1680x1050 --pos 0x0 --rotate normal diff --git a/.screenlayout/epsilon-SAIL.sh b/.screenlayout/epsilon-SAIL.sh deleted file mode 100755 index 85426bc..0000000 --- a/.screenlayout/epsilon-SAIL.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output LVDS1 --mode 1024x600 --pos 0x1200 --rotate normal --output VGA1 --mode 1920x1200 --pos 0x0 --rotate normal diff --git a/.screenlayout/epsilon-home.sh b/.screenlayout/epsilon-home.sh deleted file mode 100755 index 70bb12b..0000000 --- a/.screenlayout/epsilon-home.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output VGA1 --mode 1920x1080 --pos 0x0 --rotate normal --output LVDS1 --mode 1024x600 --pos 344x1080 --rotate normal diff --git a/.screenlayout/epsilon-solo.sh b/.screenlayout/epsilon-solo.sh deleted file mode 100755 index e23847b..0000000 --- a/.screenlayout/epsilon-solo.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output LVDS1 --mode 1024x600 --pos 0x0 --rotate normal --output VGA1 --off diff --git a/.screenlayout/lambda-home.sh b/.screenlayout/lambda-home.sh deleted file mode 100755 index 10e0ee0..0000000 --- a/.screenlayout/lambda-home.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output VGA-1 --mode 1920x1080 --pos 0x0 --rotate normal --output TV-1 --off --output DVI-I-1 --off diff --git a/.screenlayout/nu-home.sh b/.screenlayout/nu-home.sh deleted file mode 100755 index c5b1c36..0000000 --- a/.screenlayout/nu-home.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output HDMI1 --mode 1920x1080 --pos 1366x0 --rotate normal --output LVDS1 --mode 1366x768 --pos 0x0 --rotate normal --output DP1 --off --output VGA1 --off diff --git a/.screenlayout/nu-solo.sh b/.screenlayout/nu-solo.sh deleted file mode 100755 index c9c12a0..0000000 --- a/.screenlayout/nu-solo.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output HDMI1 --off --output LVDS1 --mode 1366x768 --pos 0x0 --rotate normal --output DP1 --off --output VGA1 --off diff --git a/.screenlayout/nu-work.sh b/.screenlayout/nu-work.sh deleted file mode 100755 index 7106df8..0000000 --- a/.screenlayout/nu-work.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/sh -xrandr --output HDMI1 --off --output LVDS1 --mode 1366x768 --pos 1080x576 --rotate normal --output DP1 --off --output VGA1 --mode 1920x1080 --pos 0x0 --rotate left @@ -1,227 +0,0 @@ -;; -*- Emacs-Lisp -*- - -(setq vm-imap-account-alist - '( - ("imap:localhost:143:*:login:ryan:*" "local") - ("imap-ssl:imap.google.com:993:*:login:ryanakca:*" "gmail") - ("imap-ssl:rakavan.mail.mit.edu:993:*:login:rakavan:*" "MIT") - ) - ) - -(setq vm-primary-inbox "imap:localhost:143:INBOX:login:ryan:*") - -(setq vm-imap-folder-cache-directory "~/.vm-cache") - -; Setup coloring -(require 'u-vm-color) -(add-hook 'vm-select-message-hook 'u-vm-color-fontify-buffer) -(add-hook 'vm-summary-mode-hook 'u-vm-color-summary-mode) -(defadvice vm-fill-paragraphs-containing-long-lines - (after u-vm-color activate) - (u-vm-color-fontify-buffer)) -(defadvice vm-show-current-message (after u-vm-color activate) - (u-vm-color-fontify-buffer-even-more)) -(defadvice vm-decode-mime-message (after u-vm-color activate) - (u-vm-color-fontify-buffer-even-more)) - -;; fill paragraphs to 72 chars -(setq vm-fill-paragraphs-containing-long-lines-in-reply 72) -(setq vm-word-wrap-paragraphs-in-reply t) - -; Setup a shortcut to the whole visit-imap-folder nonsense -(defalias 'imap 'vm-visit-imap-folder) - -; Keep the -> line centered -(setq vm-auto-center-summary t) - -; Obey FCC -(add-hook 'mail-send-hook 'vm-imap-save-composition) - -;; Use a sendmail program -(setq send-mail-function 'sendmail-send-it) - -; Enable multiple sender profiles -(require 'vm-pcrisis) -(vmpc-my-identities "rak@debian.org" "ryanakca@gmail.com" - "ryan.kavanagh@queensu.ca" "9rak@queensu.ca" - "ryanakca@kubuntu.org" "ryanakca@ubuntu.com" - "ryan@cs.queensu.ca" "ryank@cs.mcgill.ca" - "ryan.kavanagh@mail.mcgill.ca") - -(setq vmpc-conditions - '( ("QueensU" - (vmpc-folder-match ".*QueensU.*") ) - ("To Debian" - (vmpc-header-match "To" ".*debian.org") ) - ("To Queensu" - (vmpc-header-match "To" ".*@queensu.ca") ) - ("To Queens CS" - (vmpc-header-match "To" "ryan@cs.queensu.ca") ) - ("To Ubuntu" - (vmpc-header-match "To" ".*@ubuntu.com") ) - ("To Kubuntu" - (vmpc-header-match "To" ".*@kubuntu.org") ) - ("default" - (vmpc-none-true-yet) ) - ) ) - -(setq vmpc-actions - '( ("From Queens" - (vmpc-composition-buffer - (setq user-mail-address "ryan.kavanagh@queensu.ca") ) - (vmpc-substitute-header "From" "Ryan Kavanagh <ryan.kavanagh@queensu.ca>") - (vmpc-substitute-header "IMAP-FCC" "local:QueensU.Sent Items") ) - ("From Queens CS" - (vmpc-composition-buffer - (setq user-mail-address "ryan@cs.queensu.ca") ) - (vmpc-substitute-header "From" "Ryan Kavanagh <ryan@cs.queensu.ca>") ) - ("From Debian" - (vmpc-composition-buffer - (setq user-mail-address "rak@debian.org") ) - (vmpc-substitute-header "From" "Ryan Kavanagh <rak@debian.org>") ) - ("From Ubuntu" - (vmpc-composition-buffer - (setq user-mail-address "ryanakca@ubuntu.com") ) - (vmpc-substitute-header "From" "Ryan Kavanagh <ryanakca@ubuntu.com") ) - ("From Kubuntu" - (vmpc-composition-buffer - (setq user-mail-address "ryanakca@kubuntu.org") ) - (vmpc-substitute-header "From" "Ryan Kavanagh <ryanakca@kubuntu.org") ) - ("prompt" - (vmpc-prompt-for-profile) ) - ) ) - -;; Fallback rules -(setq vmpc-default-rules - '( ("To Queensu" "From Queens") - ("To Queens CS" "From Queens CS") - ("To Debian" "From Debian") - ("default" "From Debian") - ) ) - -;; Rules for mail created with vm-mail -(setq vmpc-newmail-rules vmpc-default-rules) -;; Rules for mail created with vm-mail-from-folder -(setq vmpc-mail-rules vmpc-default-rules) -;; Rules for mail created with vm-reply -(setq vmpc-reply-rules - '( ("To Debian" "From Debian") - ("To Queensu" "From Queens") - ("To Queens CS" "From Queens CS") - ("To Ubuntu" "From Ubuntu") - ("To Kubuntu" "From Kubuntu") - ) ) - -;; Store login info in .authinfo.gpg -(require 'auth-source) - -;; Display whole message, require <SPC> to mark as read -(setq vm-preview-lines t) - -;; bind ! to flag a message -(define-key vm-mode-map "!" 'vm-toggle-flag-message) -;; We'll always be saving to an imap server -(define-key vm-mode-map "s" 'vm-save-message-to-imap-folder) -;; We'll always be switching to an imap server -(define-key vm-mode-map "v" 'vm-visit-imap-folder) - -;; assume we're saving to the same imap server -(setq vm-imap-save-to-server t) - -;; delete a message after saving it -(setq vm-delete-after-saving t) - -;; move to the next message after deleting -(setq vm-move-after-deleting t) - -;; move to the next message after reading -(setq vm-move-after-reading t) - -;; ask before creating a new folder to save to -(setq vm-confirm-new-folders t) - -;; Automatically verify mime signatures -(setq vm-mime-verify-signatures t) - -;; Ident threads -(setq-default vm-summary-show-threads t) - -;; Don't try to load entire messages into memory at startup. -(setq vm-enable-external-messages '(imap)) -(setq vm-imap-max-message-size 0) - -;; Set attribution format -(setq vm-included-text-attribution-format "On %w, %m %2d, %y at %h %z, %F wrote: -") - -;; Prefix included text by "> " -(setq vm-included-text-prefix "> ") - -;; include text in reply -(setq vm-include-text-basic t) - -;; summary format -(setq vm-summary-format "%n %*%a %-17.17F %2y %-3.3m %2d (%-4l) %4l/%-5c %I\"%s\" -") - -;;; BBDB -(require 'bbdb-autoloads) -(require 'bbdb) -(bbdb-initialize 'vm); 'mail 'message) -;; The following two lines have BBDB automatically add addresses -(bbdb-mua-auto-update-init 'vm); 'mail 'message) -(setq bbdb-update-records-p 'create) -(setq bbdb-mua-update-interactive-p '(create . create)) -;; Offer to save the database -(setq bbdb-offer-save t) -;; Use vm to send mail -(setq bbdb-send-mail-style 'vm) -;; Use a horizontal split -(setq bbdb-mua-pop-up 'horiz) -;; Maximum height of BBDB popup size for vertical split -(setq bbdb-mua-pop-up-window-size 10) -;; Maximum width of BBDB popup size for horizontal split -(setq bbdb-horiz-pop-up-window-size '(80 . 0.3)) -;; Don't add addresses matching the following regexp to our DB -(setq bbdb-ignore-some-messages-alist - '((("From" "CC" "Reply-To") . ".*@bugs.\\(debian.org\\|launchpad.net\\)\\|.*@.*.launchpad.net\\|noreply\\|.*facebook.com") - (("To" "Sender") . "noreply"))) -;; (setq bbdb/mail-auto-create-p 'bbdb-ignore-some-messages-hook) -;; Add all addresses in an email -(setq bbdb-message-all-addresses t) -;; ??? -(setq bbdb-offer-to-create t) -;; Add notes when updating a record -(add-hook 'bbdb-notice-mail-hook 'bbdb-auto-notes) -;; And track the following: -(setq bbdb-auto-notes-rules - (list - '("Organization" - (".*" organization "\\1" nil)) - '("User-Agent" - (".*" mailer identity nil)) - '("X-Mailer" - (".*" mailer identity nil)) - '("X-Newsreader" - (".*" mailer identity nil)))) -;; There is more than one John Smith in the world -(setq bbdb-allow-duplicates t) -;; Allow cycling and tab completion of emails when composing -;;(setq bbdb-complete-mail nil t) -(setq bbdb-complete-mail-allow-cycling t) - -;; signature -(setq mail-signature t) -(setq mail-signature-file "~/.signature") - -;; gpg? -(require 'vm-pgg) -; prompt for signing -(add-hook 'vm-mail-send-hook 'vm-pgg-ask-hook t) - -;; shortcut to read theads -(fset 'ryan-read-thread2 - (lambda (&optional arg) "Keyboard macro." (interactive "p") (kmacro-exec-ring-item (quote ("MTMn.Mu\356" 0 "%d")) arg))) -(global-set-key [3 18] 'ryan-read-thread2) - -;; vim: set filetype=lisp: diff --git a/.xmobarrc b/.xmobarrc deleted file mode 100644 index b537cc8..0000000 --- a/.xmobarrc +++ /dev/null @@ -1,19 +0,0 @@ -Config { font = "-misc-fixed-*-*-*-*-10-*-*-*-*-*-*-*" - , bgColor = "black" - , fgColor = "grey" - , position = Top - , lowerOnStart = True - , commands = [ Run Weather "CYGK" ["-t","<station>: <tempC>C, pressure: <pressure>hPa","-L","18","-H","25","--normal","green","--high","red","--low","lightblue"] 36000 - , Run Network "eth0" ["-L","0","-H","32","--normal","green","--high","red"] 10 - , Run Network "wlan0" ["-L","0","-H","32","--normal","green","--high","red"] 10 - , Run Cpu ["-L","3","-H","50","--normal","green","--high","red"] 10 - , Run Memory ["-t","Mem: <usedratio>%"] 10 - , Run Swap [] 10 - , Run Com "uname" ["-s","-r"] "" 36000 - , Run Thermal "THRM" ["-t","<temp>C","-L","40","-H","60","--high","red","--low","lightblue"] 5 - , Run Date "%a %b %_d %Y %H:%M:%S" "date" 10 - ] - , sepChar = "%" - , alignSep = "}{" - , template = "%cpu% @ %THRM% | %memory% * %swap% | %eth0% - %wlan0% }{ <fc=#ee9a00>%date%</fc>| %CYGK% | %uname%" - } diff --git a/bin/gpg-check b/bin/gpg-check deleted file mode 100755 index 79948c9..0000000 --- a/bin/gpg-check +++ /dev/null @@ -1,17 +0,0 @@ -#!/bin/sh - -MSG=$(cat) - -echo "${MSG}" | grep 'BEGIN PGP SIGNATURE' > /dev/null 2>&1; -SIGNED=$? - -if [ ${SIGNED} = 0 ]; then - echo "${MSG}" | \ - sed -e '/^-\+BEGIN PGP SIGNED MESSAGE-\+/,/^Hash:.*/d' \ - -e '/^-\+BEGIN PGP SIGNATURE-\+/,$d' | \ - mutt-autoalias - echo '\n' - echo "${MSG}" | gpg --verify - 2>&1; -else - echo "${MSG}" | mutt-autoalias -fi diff --git a/bin/mutt-autoalias b/bin/mutt-autoalias deleted file mode 100755 index a9725d5..0000000 --- a/bin/mutt-autoalias +++ /dev/null @@ -1,16 +0,0 @@ -#!/bin/sh - -MESSAGE=$(cat) - -EXCLUDE="\(.*@bugs.\(debian.org|launchpad.net\)|.*@.*.launchpad.net|noreply|.*facebook.*|.*gmail.com.*Behalf Of\)" -NEWALIAS=$(echo "${MESSAGE}" | grep ^"From: " | egrep -v "${EXCLUDE}" | sed s/[\,\"\']//g | awk '{$1=""; if (NF == 3) {print "alias" $0;} else if (NF == 2) {print "alias" $0 $0;} else if (NF > 3) {print "alias", tolower($(NF-1))"."tolower($2) $0;}}') - -if grep -Fxq "$NEWALIAS" $HOME/.mutt/alias.rc; then - : -elif [ "x${NEWALIAS}" = "x" ]; then - : -else - echo "$NEWALIAS" >> $HOME/.mutt/alias.rc -fi - -echo "${MESSAGE}" diff --git a/bin/mutt-notmuch b/bin/mutt-notmuch deleted file mode 100755 index a5b339a..0000000 --- a/bin/mutt-notmuch +++ /dev/null @@ -1,190 +0,0 @@ -#!/usr/bin/perl -w -# -# mutt-notmuch - notmuch (of a) helper for Mutt -# -# Copyright: © 2011 Stefano Zacchiroli <zack@upsilon.cc> -# License: GNU General Public License (GPL), version 3 or above -# -# See the bottom of this file for more documentation. -# A manpage can be obtained by running "pod2man mutt-notmuch > mutt-notmuch.1" - -use strict; -use warnings; - -use File::Path; -use Getopt::Long; -use Mail::Internet; -use Mail::Box::Maildir; -use Pod::Usage; - - -# create an empty maildir (if missing) or empty an existing maildir" -sub empty_maildir($) { - my ($maildir) = (@_); - rmtree($maildir) if (-d $maildir); - my $folder = new Mail::Box::Maildir(folder => $maildir, - create => 1); - $folder->close(); -} - -# search($maildir, $query) -# search mails according to $query with notmuch; store results in $maildir -sub search($$) { - my ($maildir, $query) = @_; - - empty_maildir($maildir); - system("notmuch search --output=files $query" - . " | sed -e 's: :\\\\ :g'" - . " | xargs --no-run-if-empty ln -s -t $maildir/cur/"); -} - -sub search_action($$@) { - my ($interactive, $results_dir, @params) = @_; - - if (! $interactive) { - search($results_dir, join(' ', @params)); - } else { - my $query = ""; - my $done = 0; - while (! $done) { - print "search ('?' for man): "; - chomp($query = <STDIN>); - if ($query eq "?") { - system("man notmuch"); - } elsif ($query eq "") { - $done = 1; # quit doing nothing - } else { - search($results_dir, $query); - $done = 1; - } - } - } -} - -sub thread_action(@) { - my ($results_dir, @params) = @_; - - my $mail = Mail::Internet->new(\*STDIN); - $mail->head->get('message-id') =~ /^<(.*)>$/; # get message-id - my $mid = $1; - my $tid = `notmuch search --output=threads id:$mid`;# get thread id - chomp($tid); - - search($results_dir, $tid); -} - -sub die_usage() { - my %podflags = ( "verbose" => 1, - "exitval" => 2 ); - pod2usage(%podflags); -} - -sub main() { - my $results_dir = "$ENV{HOME}/.cache/mutt_results"; - my $interactive = 0; - my $help_needed = 0; - - my $getopt = GetOptions( - "h|help" => \$help_needed, - "o|output-dir=s" => \$results_dir, - "p|prompt" => \$interactive); - if (! $getopt || $#ARGV < 0) { die_usage() }; - my ($action, @params) = ($ARGV[0], @ARGV[1..$#ARGV]); - - if ($help_needed) { - die_usage(); - } elsif ($action eq "search" && $#ARGV == 0 && ! $interactive) { - print STDERR "Error: no search term provided\n\n"; - die_usage(); - } elsif ($action eq "search") { - search_action($interactive, $results_dir, @params); - } elsif ($action eq "thread") { - thread_action($results_dir, @params); - } else { - die_usage(); - } -} - -main(); - -__END__ - -=head1 NAME - -mutt-notmuch - notmuch (of a) helper for Mutt - -=head1 SYNOPSIS - -=over - -=item B<mutt-notmuch> [I<OPTION>]... search [I<SEARCH-TERM>]... - -=item B<mutt-notmuch> [I<OPTION>]... thread < I<MAIL> - -=back - -=head1 DESCRIPTION - -mutt-notmuch is a frontend to the notmuch mail indexer capable of populating -maildir with search results. - -=head1 OPTIONS - -=over 4 - -=item -o DIR - -=item --output-dir DIR - -Store search results as (symlink) messages under maildir DIR. Beware: DIR will -be overwritten. (Default: F<~/.cache/mutt_results/>) - -=item -p - -=item --prompt - -Instead of using command line search terms, prompt the user for them (only for -"search"). - -=item -h - -=item --help - -Show usage information and exit. - -=back - -=head1 INTEGRATION WITH MUTT - -mutt-notmuch can be used to integrate notmuch with the Mutt mail user agent -(unsurprisingly, given the name). To that end, you should define the following -macros in your F<~/.muttrc> (replacing F<~/bin/mutt-notmuch> for the actual -location of mutt-notmuch on your system): - - macro index <F8> \ - "<enter-command>unset wait_key<enter><shell-escape>~/bin/mutt-notmuch --prompt search<enter><change-folder-readonly>~/.cache/mutt_results<enter>" \ - "search mail (using notmuch)" - macro index <F9> \ - "<enter-command>unset wait_key<enter><pipe-message>~/bin/mutt-notmuch thread<enter><change-folder-readonly>~/.cache/mutt_results<enter><enter-command>set wait_key<enter>" \ - "search and reconstruct owning thread (using notmuch)" - -The first macro (activated by <F8>) will prompt the user for notmuch search -terms and then jump to a temporary maildir showing search results. The second -macro (activated by <F9>) will reconstruct the thread corresponding to the -current mail and show it as search results. - -To keep notmuch index current you should then periodically run C<notmuch -new>. Depending on your local mail setup, you might want to do that via cron, -as a hook triggered by mail retrieval, etc. - -=head1 SEE ALSO - -mutt(1), notmuch(1) - -=head1 AUTHOR - -Copyright: (C) 2011 Stefano Zacchiroli <zack@upsilon.cc> - -License: GNU General Public License (GPL), version 3 or higher - -=cut diff --git a/bin/sdf b/bin/sdf deleted file mode 100755 index 824af51..0000000 --- a/bin/sdf +++ /dev/null @@ -1,8 +0,0 @@ -#!/bin/sh - -SDF=faeroes.sdf.org - -tmux new-session -A -s sdf -d -n com "ssh -t ${SDF} rcom" -tmux set-option -t sdf:^ default-command "ssh -t ${SDF}" -tmux set-option -t sdf:^ remain-on-exit on -tmux attach -t sdf @@ -1,272 +0,0 @@ -#!/usr/bin/env bash - -# -# This is sp, the command-line Spotify controller. It talks to a running -# instance of the Spotify Linux client over dbus, providing an interface not -# unlike mpc. -# -# Put differently, it allows you to control Spotify without leaving the comfort -# of your command line, and without a custom client or Premium subscription. -# -# As an added bonus, it also works with ssh, at and cron. -# -# Example: -# $ sp weather girls raining men -# $ sp current -# Album 100 Hits Of The '80s -# Artist The Weather Girls -# Title It's Raining Men -# $ sp pause -# -# Alarm clock example: -# $ at 7:45 <<< 'sp bangarang' -# -# Remote example: -# $ ssh vader@prod02.nomoon.ta 'sp imperial march' -# -# -# Copyright (C) 2013 Wander Nauta -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software, to deal in the Software without restriction, including -# without limitation the rights to use, copy, modify, merge, publish, -# distribute, sublicense, and/or sell copies of the Software, and to permit -# persons to whom the Software is furnished to do so, subject to the following -# conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# The software is provided "as is", without warranty of any kind, express or -# implied, including but not limited to the warranties of merchantability, -# fitness for a particular purpose and noninfringement. In no event shall the -# authors or copyright holders be liable for any claim, damages or other -# liability, whether in an action of contract, tort or otherwise, arising from, -# out of or in connection with the software or the use or other dealings in the -# software. -# - -# CONSTANTS - -SP_VERSION="0.1" -SP_DEST="org.mpris.MediaPlayer2.spotify" -SP_PATH="/org/mpris/MediaPlayer2" -SP_MEMB="org.mpris.MediaPlayer2.Player" - -# SHELL OPTIONS - -shopt -s expand_aliases - -# UTILITY FUNCTIONS - -function require { - hash $1 2>/dev/null || { - echo >&2 "Error: '$1' is required, but was not found."; exit 1; - } -} - -# COMMON REQUIRED BINARIES - -# We need dbus-send to talk to Spotify. -require dbus-send - -# Assert standard Unix utilities are available. -require grep -require sed -require cut -require tr - -# 'SPECIAL' (NON-DBUS-ALIAS) COMMANDS - -function sp-dbus { - # Sends the given method to Spotify over dbus. - dbus-send --print-reply --dest=$SP_DEST $SP_PATH $SP_MEMB.$1 ${*:2} > /dev/null -} - -function sp-open { - # Opens the given spotify: URI in Spotify. - sp-dbus OpenUri string:$1 -} - -function sp-metadata { - # Prints the currently playing track in a parseable format. - - dbus-send \ - --print-reply `# We need the reply.` \ - --dest=$SP_DEST \ - $SP_PATH \ - org.freedesktop.DBus.Properties.Get \ - string:"$SP_MEMB" string:'Metadata' \ - | grep -Ev "^method" `# Ignore the first line.` \ - | grep -Eo '("(.*)")|(\b[0-9][a-zA-Z0-9.]*\b)' `# Filter interesting fiels.`\ - | sed -E '2~2 a|' `# Mark odd fields.` \ - | tr -d '\n' `# Remove all newlines.` \ - | sed -E 's/\|/\n/g' `# Restore newlines.` \ - | sed -E 's/(xesam:)|(mpris:)//' `# Remove ns prefixes.` \ - | sed -E 's/^"//' `# Strip leading...` \ - | sed -E 's/"$//' `# ...and trailing quotes.` \ - | sed -E 's/"+/|/' `# Regard "" as seperator.` \ - | sed -E 's/ +/ /g' `# Merge consecutive spaces.` -} - -function sp-current { - # Prints the currently playing track in a friendly format. - require column - - sp-metadata \ - | grep --color=never -E "(title)|(album)|(artist)" \ - | sed 's/^\(.\)/\U\1/' \ - | column -t -s'|' -} - -function sp-eval { - # Prints the currently playing track as shell variables, ready to be eval'ed - require sort - - sp-metadata \ - | grep --color=never -E "(title)|(album)|(artist)|(trackid)|(trackNumber)" \ - | sort -r \ - | sed 's/^\([^|]*\)\|/\U\1/' \ - | sed -E 's/\|/="/' \ - | sed -E 's/$/"/' \ - | sed -E 's/^/SPOTIFY_/' -} - -function sp-art { - # Prints the artUrl. - - sp-metadata | grep "artUrl" | cut -d'|' -f2 -} - -function sp-display { - # Calls display on the artUrl. - - require display - display $(sp-art) -} - -function sp-feh { - # Calls feh on the artURl. - - require feh - feh $(sp-art) -} - -function sp-url { - # Prints the HTTP url. - - TRACK=$(sp-metadata | grep "url" | cut -d'|' -f2 | cut -d':' -f3) - echo "http://open.spotify.com/track/$TRACK" -} - -function sp-clip { - # Copies the HTTP url. - - require xclip - sp-url | xclip -} - -function sp-http { - # xdg-opens the HTTP url. - - require xdg-open - xdg-open $(sp-url) -} - -function sp-help { - # Prints usage information. - - echo "Usage: sp [command]" - echo "Control a running Spotify instance from the command line." - echo "" - echo " sp play - Play/pause Spotify" - echo " sp pause - Pause Spotify" - echo " sp next - Go to next track" - echo " sp prev - Go to previous track" - echo "" - echo " sp current - Format the currently playing track" - echo " sp metadata - Dump the current track's metadata" - echo " sp eval - Return the metadata as a shell script" - echo "" - echo " sp art - Print the URL to the current track's album artwork" - echo " sp display - Display the current album artwork with \`display\`" - echo " sp feh - Display the current album artwork with \`feh\`" - echo "" - echo " sp url - Print the HTTP URL for the currently playing track" - echo " sp clip - Copy the HTTP URL to the X clipboard" - echo " sp http - Open the HTTP URL in a web browser" - echo "" - echo " sp open <uri> - Open a spotify: uri" - echo " sp search <q> - Start playing the best search result for the given query" - echo "" - echo " sp version - Show version information" - echo " sp help - Show this information" - echo "" - echo "Any other argument will start a search (i.e. 'sp foo' will search for foo)." -} - -function sp-search { - # Searches for tracks, plays the first result. - - require curl - - Q="$@" - SPTFY_URI=$( \ - curl -s -G --data-urlencode "q=$Q" https://api.spotify.com/v1/search\?type=track \ - | grep -E -o "spotify:track:[a-zA-Z0-9]+" -m 1 \ - ) - - sp-open $SPTFY_URI -} - -function sp-version { - # Prints version information. - - echo "sp $SP_VERSION" - echo "Copyright (C) 2013 Wander Nauta" - echo "License MIT" -} - -# 'SIMPLE' (DBUS-ALIAS) COMMANDS - -alias sp-play=" sp-dbus PlayPause" -alias sp-pause=" sp-dbus Pause" -alias sp-next=" sp-dbus Next" -alias sp-prev=" sp-dbus Previous" - -# DISPATCHER - -# First, we connect to the dbus session spotify is on. This isn't really needed -# when running locally, but is crucial when we don't have an X display handy -# (for instance, when running sp over ssh.) - -SPOTIFY_PID="$(pidof -s spotify || pidof -s .spotify-wrapped)" - -if [[ -z "$SPOTIFY_PID" ]]; then - echo "Error: Spotify is not running." - exit 1 -fi - -QUERY_ENVIRON="$(cat /proc/${SPOTIFY_PID}/environ | tr '\0' '\n' | grep "DBUS_SESSION_BUS_ADDRESS" | cut -d "=" -f 2-)" -if [[ "${QUERY_ENVIRON}" != "" ]]; then - export DBUS_SESSION_BUS_ADDRESS="${QUERY_ENVIRON}" -fi - -# Then we dispatch the command. - -subcommand="$1" - -if [[ -z "$subcommand" ]]; then - # No arguments given, print help. - sp-help -else - # Arguments given, check if it's a command. - if $(type sp-$subcommand > /dev/null 2> /dev/null); then - # It is. Run it. - shift - eval "sp-$subcommand $@" - else - # It's not. Try a search. - eval "sp-search $@" - fi -fi diff --git a/bin/vpnc b/bin/vpnc deleted file mode 100755 index 3933feb..0000000 --- a/bin/vpnc +++ /dev/null @@ -1,4 +0,0 @@ -#!/bin/sh - -#sudo ipsec up $1 && sleep 1 && sudo xl2tpd-control connect $1 -sudo xl2tpd-control connect $1 |