… | |
… | |
15 | my ($self) = @_; |
15 | my ($self) = @_; |
16 | |
16 | |
17 | $self->{browser} = urxvt::untaint $self->x_resource ("urlLauncher") || "x-www-browser"; |
17 | $self->{browser} = urxvt::untaint $self->x_resource ("urlLauncher") || "x-www-browser"; |
18 | |
18 | |
19 | $self->grab_button (3, urxvt::ControlMask); |
19 | $self->grab_button (3, urxvt::ControlMask); |
|
|
20 | |
|
|
21 | () |
20 | } |
22 | } |
21 | |
23 | |
22 | sub on_button_press { |
24 | sub on_button_press { |
23 | my ($self, $event) = @_; |
25 | my ($self, $event) = @_; |
24 | |
26 | |
… | |
… | |
67 | |
69 | |
68 | /[\\"'\ \t|&;<>()]/ |
70 | /[\\"'\ \t|&;<>()]/ |
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 { system "$self->{browser} \Q$_\E &" }); |
74 | and $add_button->("run $self->{browser}" => sub { urxvt::exec_async $self->{browser}, $_ }); |
|
|
75 | |
|
|
76 | if (/^\s*((?:0x)?\d+)\s*$/) { |
|
|
77 | $popup->add_title (sprintf "%20s", eval $1); |
|
|
78 | $popup->add_title (sprintf "%20s", sprintf "0x%x", eval $1); |
|
|
79 | $popup->add_title (sprintf "%20s", sprintf "0%o", eval $1); |
|
|
80 | } |
73 | } |
81 | } |
74 | |
82 | |
75 | $popup->show; |
83 | $popup->show; |
76 | |
84 | |
77 | return 1; |
85 | return 1; |