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

Comparing rxvt-unicode/src/perl/selection (file contents):
Revision 1.20 by root, Thu Jan 12 03:32:56 2006 UTC vs.
Revision 1.23 by root, Thu Jan 12 12:05:28 2006 UTC

7 and $self->selection (map { y/A-Za-z/N-ZA-Mn-za-m/; $_ } $self->selection); 7 and $self->selection (map { y/A-Za-z/N-ZA-Mn-za-m/; $_ } $self->selection);
8 8
9 () 9 ()
10} 10}
11 11
12sub on_init {
13 my ($self) = @_;
14
15 for (my $idx = 0; defined (my $res = $self->x_resource ("selection.pattern-$idx")); $idx++) {
16 no re 'eval'; # just to be sure
17 push @{ $self->{patterns} }, qr/$res/;
18 }
19
20 ()
21}
22
12# "find interetsing things"-patterns 23# "find interetsing things"-patterns
13my @mark_patterns = ( 24my @mark_patterns = (
14 qr{([[:alnum:]]+)}, 25 qr{([[:word:]]+)},
15 26
16 # common "parentheses" 27 # common "parentheses"
17 qr{(?:^|\s) ‘ ([^‘’]+?) ’ (?:\s|\)|$)}x, 28 qr{(?:^|\s) ‘ ([^‘’]+?) ’ (?:\s|\)|$)}x,
18 qr{(?:^|\s) ` ([^`']+?) ' (?:\s|\)|$)}x, 29 qr{(?:^|\s) ` ([^`']+?) ' (?:\s|\)|$)}x,
19 qr{ \{ ([^{}]+?) \} }x, 30 qr{ \{ ([^{}]+?) \} }x,
20 qr{ \[ ([^{}]+?) \] }x, 31 qr{ \[ ([^{}]+?) \] }x,
32 qr{ \( ([^()]+?) \) }x,
21 33
22 # urls, just a heuristic 34 # urls, just a heuristic
23 qr{( 35 qr{(
24 (?:https?|ftp|news|mailto|file)://[ab-zA-Z0-9\-\@;\/?:&=%\$_.+!*\x27(),~]+ 36 (?:https?|ftp|news|mailto|file)://[ab-zA-Z0-9\-\@;\/?:&=%\$_.+!*\x27(),~]+
25 [ab-zA-Z0-9\-\@;\/?:&=%\$_+!*\x27()~] # exclude some trailing characters (heuristic) 37 [ab-zA-Z0-9\-\@;\/?:&=%\$_+!*\x27()~] # exclude some trailing characters (heuristic)
41 qr{^"([^\\"'\ \t|&;<>()*?]+)"$}, # "simple" => simple 53 qr{^"([^\\"'\ \t|&;<>()*?]+)"$}, # "simple" => simple
42 qr{^(.*)[,\-]$}, # strip off trailing , and - 54 qr{^(.*)[,\-]$}, # strip off trailing , and -
43); 55);
44 56
45sub on_sel_extend { 57sub on_sel_extend {
46 my ($self) = @_; 58 my ($self, $time) = @_;
47 59
48 my ($row, $col) = $self->selection_mark; 60 my ($row, $col) = $self->selection_mark;
49 my $line = $self->line ($row); 61 my $line = $self->line ($row);
50 my $text = $line->t; 62 my $text = $line->t;
51 my $markofs = $line->offset_of ($row, $col); 63 my $markofs = $line->offset_of ($row, $col);
52 my $curlen = $line->offset_of ($self->selection_end) 64 my $curlen = $line->offset_of ($self->selection_end)
53 - $line->offset_of ($self->selection_beg); 65 - $line->offset_of ($self->selection_beg);
54 66
55 my @matches; 67 my @matches;
56 68
57 for my $regex (@mark_patterns) { 69 for my $regex (@mark_patterns, @{ $self->{patterns} }) {
58 while ($text =~ /$regex/g) { 70 while ($text =~ /$regex/g) {
59 if ($-[1] <= $markofs and $markofs <= $+[1]) { 71 if ($-[1] <= $markofs and $markofs <= $+[1]) {
60 my $ofs = $-[1]; 72 my $ofs = $-[1];
61 my $match = $1; 73 my $match = $1;
62 74
72 push @matches, [$ofs, length $match]; 84 push @matches, [$ofs, length $match];
73 } 85 }
74 } 86 }
75 } 87 }
76 88
89 # whole line
90 push @matches, [0, ($line->end - $line->beg + 1) * $self->ncol];
91
77 for (sort { $a->[1] <=> $b->[1] or $b->[0] <=> $a->[0] } @matches) { 92 for (sort { $a->[1] <=> $b->[1] or $b->[0] <=> $a->[0] } @matches) {
78 my ($ofs, $len) = @$_; 93 my ($ofs, $len) = @$_;
79 94
80 next if $len <= $curlen; 95 next if $len <= $curlen;
81 96
82 $self->selection_beg ($line->coord_of ($ofs)); 97 $self->selection_beg ($line->coord_of ($ofs));
83 $self->selection_end ($line->coord_of ($ofs + $len)); 98 $self->selection_end ($line->coord_of ($ofs + $len));
84 return 1; 99 return 1;
85 } 100 }
86 101
87 # whole line 102 ()
88 $self->selection_beg ($line->beg, 0);
89 $self->selection_end ($line->end, $self->ncol);
90
91 return 1;
92} 103}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines