summaryrefslogtreecommitdiffstats
path: root/debian/patches/go.pl-multiple-networks.diff
blob: 5db19c64354bf7bd40d46f776191e529a73054c1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
Description: show network name if there're channels with the same name on different networks
Forwarded: not-needed
Bug-Debian: http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=476518
Author: Ryan Niebur <ryanryan52@gmail.com>
Last-Update: 2017-07-12
--- a/scripts/go.pl
+++ b/scripts/go.pl
@@ -48,6 +48,48 @@
 	return $re;
 }
 
+sub generate_the_list {
+  my $foo = {};
+  foreach(Irssi::windows) {
+    $foo->{get_channel_name($_)} ||= 0;
+    $foo->{get_channel_name($_)} += 1;
+  }
+  return $foo;
+}
+
+sub get_server_tag {
+  my $w = shift;
+  if(defined($w->items()) && defined($w->items()->{server}) && defined($w->items()->{server}->{tag})) {
+    return $w->items()->{server}->{tag};
+  } else {
+    return "";
+  }
+}
+
+sub get_channel_name {
+  my $w = shift;
+  return $w->get_active_name();
+}
+
+sub get_channel_and_tag {
+  my $w = shift;
+  if(length(get_server_tag($w)) > 0) {
+    return get_channel_name($w) . '@' . get_server_tag($w);
+  } else {
+    return get_channel_name($w); # dunno how to handle this correctly...hopefully it will never come up.
+  }
+}
+
+sub name_of_this_window {
+  my $w = shift;
+  my $list = generate_the_list();
+  if($list->{get_channel_name($w)} > 1){
+    return get_channel_and_tag($w);
+  } else {
+    return get_channel_name($w);
+  }
+}
+
 sub signal_complete_go {
 	my ($complist, $window, $word, $linestart, $want_space) = @_;
 	my $channel = $window->get_active_name();
@@ -60,7 +102,7 @@
 		Irssi::settings_get_bool('go_complete_anchored'));
 	@$complist = ();
 	foreach my $w (Irssi::windows) {
-		my $name = $w->get_active_name();
+		my $name = name_of_this_window($w);
 		if ($word ne "") {
 			if ($name =~ $re) {
 				push(@$complist, $name)