… | |
… | |
18 | |
18 | |
19 | $self->grab_button (3, urxvt::ControlMask); |
19 | $self->grab_button (3, urxvt::ControlMask); |
20 | |
20 | |
21 | () |
21 | () |
22 | } |
22 | } |
|
|
23 | |
|
|
24 | our @hook; |
23 | |
25 | |
24 | sub on_button_press { |
26 | sub on_button_press { |
25 | my ($self, $event) = @_; |
27 | my ($self, $event) = @_; |
26 | |
28 | |
27 | if ($event->{button} == 3 && $event->{state} & urxvt::ControlMask) { |
29 | if ($event->{button} == 3 && $event->{state} & urxvt::ControlMask) { |
… | |
… | |
69 | and $add_button->("shell quote" => sub { $_ = "\Q$_" }); |
71 | and $add_button->("shell quote" => sub { $_ = "\Q$_" }); |
70 | |
72 | |
71 | /^(http|ftp|telnet|irc|news):\// |
73 | /^(http|ftp|telnet|irc|news):\// |
72 | and $add_button->("run $self->{browser}" => sub { urxvt::exec_async $self->{browser}, $_ }); |
74 | and $add_button->("run $self->{browser}" => sub { urxvt::exec_async $self->{browser}, $_ }); |
73 | |
75 | |
|
|
76 | for my $hook (@hook) { |
|
|
77 | if (my ($title, $cb) = $hook->($popup)) { |
|
|
78 | $add_button->($title, $cb); |
|
|
79 | } |
|
|
80 | } |
|
|
81 | |
74 | if (/^\s*((?:0x)?\d+)\s*$/) { |
82 | if (/^\s*((?:0x)?\d+)\s*$/) { |
75 | $popup->add_title (sprintf "%20s", eval $1); |
83 | $popup->add_title (sprintf "%20s", eval $1); |
76 | $popup->add_title (sprintf "%20s", sprintf "0x%x", eval $1); |
84 | $popup->add_title (sprintf "%20s", sprintf "0x%x", eval $1); |
77 | $popup->add_title (sprintf "%20s", sprintf "0%o", eval $1); |
85 | $popup->add_title (sprintf "%20s", sprintf "0%o", eval $1); |
78 | } |
86 | } |