ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/perl/selection-popup
(Generate patch)

Comparing rxvt-unicode/src/perl/selection-popup (file contents):
Revision 1.5 by root, Mon Jan 9 06:29:47 2006 UTC vs.
Revision 1.22 by root, Tue Jan 4 21:34:18 2011 UTC

1#! perl 1#! perl
2 2
3sub msg { 3sub msg {
4 my ($self, $msg1, $msg2) = @_; 4 my ($self, $msg) = @_;
5 5
6 my $overlay = $self->overlay (0, 0, 6 my $overlay = $self->overlay (0, 0, $self->strwidth ($msg), 1);
7 (List::Util::max map $self->strwidth ($_), $msg1, $msg2), 2);
8 $overlay->set (0, 0, $msg1); 7 $overlay->set (0, 0, $msg);
9 $overlay->set (0, 1, $msg2);
10 my $iow; $iow = urxvt::timer->new->start (urxvt::NOW + 1)->cb (sub { 8 my $iow; $iow = urxvt::timer->new->after (1)->cb (sub {
11 undef $overlay; 9 undef $overlay;
12 undef $iow; 10 undef $iow;
13 }); 11 });
14} 12}
15 13
16sub on_start { 14sub on_start {
17 my ($self) = @_; 15 my ($self) = @_;
18 16
17 $self->{browser} = $self->x_resource ("urlLauncher") || "sensible-browser";
18
19 $self->grab_button (3, urxvt::ControlMask); 19 $self->grab_button (3, urxvt::ControlMask);
20
21 ()
20} 22}
21 23
22sub on_button_press { 24sub on_button_press {
23 my ($self, $event) = @_; 25 my ($self, $event) = @_;
24 26
45 $cb->(); 47 $cb->();
46 48
47 if ($orig ne $_) { 49 if ($orig ne $_) {
48 $self->selection ($_); 50 $self->selection ($_);
49 s/[\x00-\x1f\x80-\x9f]/·/g; 51 s/[\x00-\x1f\x80-\x9f]/·/g;
50 $self->msg ("Selection replaced by", $_); 52 $self->msg ($self->special_encode ($_));
51 } 53 }
52 } 54 }
53 }); 55 });
54 }; 56 };
55 57
56 for ($text) { 58 for ($text) {
57 $add_button->("rot13" => sub { y/A-Za-z/N-ZA-Mn-za-m/ }); 59 /\n/
60 and $add_button->("newlines to spaces" => sub { y/\n/ / });
58 61
59 urxvt::safe 62 /./
63 and $add_button->("rot13" => sub { y/A-Za-z/N-ZA-Mn-za-m/ });
64
65 /./
60 and $add_button->("eval perl expression" => sub { $_ = eval urxvt::untaint $_ }); 66 and $add_button->("eval perl expression" => sub { no warnings; $_ = eval $_ });
67
68 /./
69 and $add_button->((sprintf "to unicode hex index (%x)", ord) => sub { $_ = sprintf "%x", ord });
61 70
62 /^(\S+):(\d+):?$/ 71 /^(\S+):(\d+):?$/
63 and $add_button->("vi-commands to load '$1'" => sub { s/^(\S+):(\d+):?$/\x1b:e $1\x0d:$2\x0d/ }); 72 and $add_button->("vi-commands to load '$1'" => sub { s/^(\S+):(\d+):?$/\x1b:e $1\x0d:$2\x0d/ });
64 73
65 /%[0-9a-fA-F]{2}/ && !/%[^0-9a-fA-F]/ && !/%.[^0-9a-fA-F]/ 74 /%[0-9a-fA-F]{2}/ && !/%[^0-9a-fA-F]/ && !/%.[^0-9a-fA-F]/
66 and $add_button->("uri unescape" => sub { s/%([0-9a-fA-F]{2})/chr hex $1/ge }); 75 and $add_button->("uri unescape" => sub { s/%([0-9a-fA-F]{2})/chr hex $1/ge });
67 76
68 /[\\"'\ \t|&;<>()]/ 77 /[\\"'\ \t|&;<>()]/
69 and $add_button->("shell quote" => sub { $_ = "\Q$_" }); 78 and $add_button->("shell quote" => sub { $_ = "\Q$_" });
70 79
71 /^(http|ftp|telnet|irc|news):\// 80 /^(https?|ftp|telnet|irc|news):\//
72 and $add_button->("run x-www-browser" => sub { system "x-www-browser \Q$_\E &" }); 81 and $add_button->("run $self->{browser}" => sub { $self->exec_async ($self->{browser}, $_) });
82
83 for my $hook (@{ $self->{term}{selection_popup_hook} || [] }) {
84 if (my ($title, $cb) = $hook->($popup)) {
85 $add_button->($title, $cb);
86 }
87 }
88
89 if (/^\s*((?:0x)?\d+)\s*$/) {
90 $popup->add_title (sprintf "%20s", eval $1);
91 $popup->add_title (sprintf "%20s", sprintf "0x%x", eval $1);
92 $popup->add_title (sprintf "%20s", sprintf "0%o", eval $1);
93 }
73 } 94 }
74 95
75 $popup->show; 96 $popup->show;
76 97
77 return 1; 98 return 1;

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines