… | |
… | |
12 | } |
12 | } |
13 | |
13 | |
14 | sub on_start { |
14 | sub on_start { |
15 | my ($self) = @_; |
15 | my ($self) = @_; |
16 | |
16 | |
17 | $self->{browser} = $self->x_resource ("urlLauncher") || "x-www-browser"; |
17 | $self->{browser} = $self->x_resource ("urlLauncher") || "sensible-browser"; |
18 | |
18 | |
19 | $self->grab_button (3, urxvt::ControlMask); |
19 | $self->grab_button (3, urxvt::ControlMask); |
20 | |
20 | |
21 | () |
21 | () |
22 | } |
22 | } |
… | |
… | |
60 | and $add_button->("rot13" => sub { y/A-Za-z/N-ZA-Mn-za-m/ }); |
60 | and $add_button->("rot13" => sub { y/A-Za-z/N-ZA-Mn-za-m/ }); |
61 | |
61 | |
62 | /./ |
62 | /./ |
63 | and $add_button->("eval perl expression" => sub { no warnings; $_ = eval $_ }); |
63 | and $add_button->("eval perl expression" => sub { no warnings; $_ = eval $_ }); |
64 | |
64 | |
|
|
65 | /./ |
|
|
66 | and $add_button->((sprintf "to unicode hex index (%x)", ord) => sub { $_ = sprintf "%x", ord }); |
|
|
67 | |
65 | /^(\S+):(\d+):?$/ |
68 | /^(\S+):(\d+):?$/ |
66 | and $add_button->("vi-commands to load '$1'" => sub { s/^(\S+):(\d+):?$/\x1b:e $1\x0d:$2\x0d/ }); |
69 | and $add_button->("vi-commands to load '$1'" => sub { s/^(\S+):(\d+):?$/\x1b:e $1\x0d:$2\x0d/ }); |
67 | |
70 | |
68 | /%[0-9a-fA-F]{2}/ && !/%[^0-9a-fA-F]/ && !/%.[^0-9a-fA-F]/ |
71 | /%[0-9a-fA-F]{2}/ && !/%[^0-9a-fA-F]/ && !/%.[^0-9a-fA-F]/ |
69 | and $add_button->("uri unescape" => sub { s/%([0-9a-fA-F]{2})/chr hex $1/ge }); |
72 | and $add_button->("uri unescape" => sub { s/%([0-9a-fA-F]{2})/chr hex $1/ge }); |
70 | |
73 | |
71 | /[\\"'\ \t|&;<>()]/ |
74 | /[\\"'\ \t|&;<>()]/ |
72 | and $add_button->("shell quote" => sub { $_ = "\Q$_" }); |
75 | and $add_button->("shell quote" => sub { $_ = "\Q$_" }); |
73 | |
76 | |
74 | /^(http|ftp|telnet|irc|news):\// |
77 | /^(https?|ftp|telnet|irc|news):\// |
75 | and $add_button->("run $self->{browser}" => sub { $self->exec_async ($self->{browser}, $_) }); |
78 | and $add_button->("run $self->{browser}" => sub { $self->exec_async ($self->{browser}, $_) }); |
76 | |
79 | |
77 | for my $hook (@{ $self->{term}{selection_popup_hook} || [] }) { |
80 | for my $hook (@{ $self->{term}{selection_popup_hook} || [] }) { |
78 | if (my ($title, $cb) = $hook->($popup)) { |
81 | if (my ($title, $cb) = $hook->($popup)) { |
79 | $add_button->($title, $cb); |
82 | $add_button->($title, $cb); |