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.15 by root, Sun Jan 8 01:30:32 2006 UTC vs.
Revision 1.31 by root, Thu Jan 19 09:47:15 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 $res = $self->locale_decode ($res);
18 utf8::encode $res;
19 push @{ $self->{patterns} }, qr/$res/;
20 }
21
22 ()
23}
24
25# "find interetsing things"-patterns
12my @mark_patterns = ( 26my @mark_patterns = (
27 # common types of "parentheses"
28 qr{ (?<![^[:space:]]) ‘ ([^‘’]+) ’ (?![^[:space]]) }x,
29 qr{ (?<![^[:space:]]) ` ([^`']+) ' (?![^[:space]]) }x,
30 qr{ (?<![^[:space:]]) (" [^[:space:]] [^"]* ") }x,
31 qr{ (" [^"]* [^[:space:]] ") (?![^[:space]]) }x,
32 qr{ \< ([^<>[:space:]]+) \> }x,
33 qr{ \{ ([^{}[:space:]]+) \} }x,
34 qr{ \[ ([^{}[:space:]]+) \] }x,
35 qr{ \( ([^()[:space:]]+) \) }x,
36
13 # urls, just a heuristic 37 # urls, just a heuristic
14 qr{( 38 qr{(
15 (?:https?|ftp|news|mailto|file)://[ab-zA-Z0-9\-\@;\/?:&=%\$_.+!*\x27(),~]+ 39 (?:https?|ftp|news|mailto|file)://[ab-zA-Z0-9\-\@;\/?:&=%\$_.+!*\x27(),~]+
16 [ab-zA-Z0-9\-\@;\/?:&=%\$_+!*\x27(),~] # do not include a trailing dot, its wrong too often 40 [ab-zA-Z0-9\-\@;\/?:&=%\$_+!*\x27()~] # exclude some trailing characters (heuristic)
17 )}x, 41 )}x,
18 42
19 # common forms of quoting 43 # shell-like argument quoting, basically always matches
20 qr{(?:^|\s) [‘`] ([^‘`’']+) [’'] (?:\s|$)}x,
21
22 # shell-like argument quoting
23 qr{\G [\ \t|&;<>()] *( 44 qr{\G [\ \t|&;<>()] *(
24 (?: 45 (?:
25 [^\\"'\ \t|&;<>()]+ 46 [^\\"'\ \t|&;<>()]+
26 | \\. 47 | \\.
27 | " (?: [^\\"]+ | \\. )* " 48 | " (?: [^\\"]+ | \\. )* "
28 | ' [^']* ' 49 | ' [^']* '
29 )+ 50 )+
30 )}x, 51 )}x,
31); 52);
32 53
54# "correct obvious? crap"-patterns
33my @simplify_patterns = ( 55my @simplify_patterns = (
34 qr{^"([^\\"'\ \t|&;<>()*?]+)"$}, # "simple" => simple 56 qr{^"([^\\"'\ \t|&;<>()*?]+)"$}, # "simple" => simple
35 qr{^(.*)[,\-]$}, 57 qr{^(.*)[,\-]$}, # strip off trailing , and -
36); 58);
37 59
38sub on_sel_extend { 60sub on_sel_extend {
39 my ($self) = @_; 61 my ($self, $time) = @_;
40 62
41 my ($row, $col) = $self->selection_mark; 63 my ($row, $col) = $self->selection_mark;
42 my $line = $self->line ($row); 64 my $line = $self->line ($row);
43 my $offset = $line->offset_of ($row, $col);
44 my $text = $line->t; 65 my $text = $line->t;
66 my $markofs = $line->offset_of ($row, $col);
67 my $curlen = $line->offset_of ($self->selection_end)
68 - $line->offset_of ($self->selection_beg);
45 69
46 for my $regex (@mark_patterns) { 70 my @matches;
71
72 # not doing matches in unicode mode helps speed
73 # enourmously here. working in utf-8 should be
74 # equivalent due to the magic of utf-8 encoding.
75 utf8::encode $text;
76 study $text; # _really_ helps, too :)
77
78 for my $regex (@mark_patterns, @{ $self->{patterns} }) {
47 while ($text =~ /$regex/g) { 79 while ($text =~ /$regex/g) {
48 if ($-[1] <= $offset and $offset <= $+[1]) { 80 if ($-[1] <= $markofs and $markofs <= $+[1]) {
81 my $ofs = $-[1];
49 my $match = $1; 82 my $match = $1;
50 my ($ofs1, $ofs2) = ($-[1], $+[1]);
51 83
52 for my $regex (@simplify_patterns) { 84 for my $regex (@simplify_patterns) {
53 if ($match =~ $regex) { 85 if ($match =~ $regex) {
54 $match = $1; 86 $match = $1;
55 $ofs1 += $-[1]; 87 $ofs += $-[1];
56 $ofs2 = $ofs1 + length $match;
57 } 88 }
58 } 89 }
59 90
60 $self->selection_beg ($line->coord_of ($ofs1)); 91 push @matches, [$ofs, length $match];
61 $self->selection_end ($line->coord_of ($ofs2));
62 return 1;
63 } 92 }
64 } 93 }
65 } 94 }
66 95
96 # whole line
97 push @matches, [0, ($line->end - $line->beg + 1) * $self->ncol];
98
99 for (sort { $a->[1] <=> $b->[1] or $b->[0] <=> $a->[0] } @matches) {
100 my ($ofs, $len) = @$_;
101
102 next if $len <= $curlen;
103
104 $self->selection_beg ($line->coord_of ($ofs));
105 $self->selection_end ($line->coord_of ($ofs + $len));
106 return 1;
107 }
108
67 () 109 ()
68} 110}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines