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.22 by root, Thu Jan 12 10:21:50 2006 UTC vs.
Revision 1.25 by root, Thu Jan 12 23:30:51 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{([[:word:]]+)},
15
16 # common "parentheses" 25 # common types of "parentheses"
17 qr{(?:^|\s) ‘ ([^‘’]+?) ’ (?:\s|\)|$)}x, 26 qr{ (?<![^[:space:]]) ‘ ([^‘’]+) ’ (?![^[:space]]) }x,
18 qr{(?:^|\s) ` ([^`']+?) ' (?:\s|\)|$)}x, 27 qr{ (?<![^[:space:]]) ` ([^`']+) ' (?![^[:space]]) }x,
19 qr{ \{ ([^{}]+?) \} }x, 28 qr{ (?<![^[:space:]]) (" [^[:space:]] [^"]* ") }x,
20 qr{ \[ ([^{}]+?) \] }x, 29 qr{ (" [^"]* [^[:space:]] ") (?![^[:space]]) }x,
21 qr{ \( ([^()]+?) \) }x, 30 qr{ \< ([^<>[:space:]]+) \> }x,
31 qr{ \{ ([^{}[:space:]]+) \} }x,
32 qr{ \[ ([^{}[:space:]]+) \] }x,
33 qr{ \( ([^()[:space:]]+) \) }x,
22 34
23 # urls, just a heuristic 35 # urls, just a heuristic
24 qr{( 36 qr{(
25 (?:https?|ftp|news|mailto|file)://[ab-zA-Z0-9\-\@;\/?:&=%\$_.+!*\x27(),~]+ 37 (?:https?|ftp|news|mailto|file)://[ab-zA-Z0-9\-\@;\/?:&=%\$_.+!*\x27(),~]+
26 [ab-zA-Z0-9\-\@;\/?:&=%\$_+!*\x27()~] # exclude some trailing characters (heuristic) 38 [ab-zA-Z0-9\-\@;\/?:&=%\$_+!*\x27()~] # exclude some trailing characters (heuristic)
53 my $curlen = $line->offset_of ($self->selection_end) 65 my $curlen = $line->offset_of ($self->selection_end)
54 - $line->offset_of ($self->selection_beg); 66 - $line->offset_of ($self->selection_beg);
55 67
56 my @matches; 68 my @matches;
57 69
58 for my $regex (@mark_patterns) { 70 for my $regex (@mark_patterns, @{ $self->{patterns} }) {
59 while ($text =~ /$regex/g) { 71 while ($text =~ /$regex/g) {
60 if ($-[1] <= $markofs and $markofs <= $+[1]) { 72 if ($-[1] <= $markofs and $markofs <= $+[1]) {
61 my $ofs = $-[1]; 73 my $ofs = $-[1];
62 my $match = $1; 74 my $match = $1;
63
64 push @matches, [$ofs, length $match];
65 75
66 for my $regex (@simplify_patterns) { 76 for my $regex (@simplify_patterns) {
67 if ($match =~ $regex) { 77 if ($match =~ $regex) {
68 $match = $1; 78 $match = $1;
69 $ofs += $-[1]; 79 $ofs += $-[1];

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines