--- rxvt-unicode/src/perl/selection-popup 2006/01/12 02:20:56 1.9 +++ rxvt-unicode/src/perl/selection-popup 2006/01/18 10:11:03 1.12 @@ -14,13 +14,15 @@ sub on_start { my ($self) = @_; - $self->{browser} = urxvt::untaint $self->x_resource ("urlLauncher") || "x-www-browser"; + $self->{browser} = $self->x_resource ("urlLauncher") || "x-www-browser"; $self->grab_button (3, urxvt::ControlMask); () } +our @hook; + sub on_button_press { my ($self, $event) = @_; @@ -57,9 +59,7 @@ for ($text) { $add_button->("rot13" => sub { y/A-Za-z/N-ZA-Mn-za-m/ }); - - urxvt::safe - and $add_button->("eval perl expression" => sub { no warnings; $_ = eval urxvt::untaint $_ }); + $add_button->("eval perl expression" => sub { no warnings; $_ = eval $_ }); /^(\S+):(\d+):?$/ and $add_button->("vi-commands to load '$1'" => sub { s/^(\S+):(\d+):?$/\x1b:e $1\x0d:$2\x0d/ }); @@ -72,6 +72,18 @@ /^(http|ftp|telnet|irc|news):\// and $add_button->("run $self->{browser}" => sub { urxvt::exec_async $self->{browser}, $_ }); + + for my $hook (@hook) { + if (my ($title, $cb) = $hook->($popup)) { + $add_button->($title, $cb); + } + } + + if (/^\s*((?:0x)?\d+)\s*$/) { + $popup->add_title (sprintf "%20s", eval $1); + $popup->add_title (sprintf "%20s", sprintf "0x%x", eval $1); + $popup->add_title (sprintf "%20s", sprintf "0%o", eval $1); + } } $popup->show;