File: PathparamEntry.pm

package info (click to toggle)
horae 066-3
  • links: PTS
  • area: contrib
  • in suites: lenny
  • size: 17,272 kB
  • ctags: 1,656
  • sloc: perl: 64,718; lisp: 744; sh: 82; makefile: 67; ansic: 35
file content (61 lines) | stat: -rw-r--r-- 1,221 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61


=head1 NAME

Tk::PathparamEntry - perl/Tk Entry widget with redefined word boundaries

=for pm Tk/PathparamEntry.pm

=for category Derived Widgets

=head1 SYNOPSIS

    use Tk::PathparamEntry;
    ...
    $ppe = $mw->PathparamEntry(?options,...?);

=head1 DESCRIPTION

This "I<IS A>" entry widget with all bindings identical to the normal
entry widget, except that word boundaries have been redefined to be
appropriate to those of an Ifeffit math expression, i.e. whitespace
plus parens, commas, and binary math operators.

=head1 KEYS

widget, entry

=head1 SEE ALSO

L<Tk::Entry>

=cut


package Tk::PathparamEntry;

use Tk::Entry;
use base  qw(Tk::Entry);

Construct Tk::Widget 'PathparamEntry';

sub wordstart
{my ($w,$pos) = @_;
 my $string = $w->get;
 $pos = $w->index('insert')-1 unless(defined $pos);
 $string = substr($string,0,$pos);
 $string =~ s/[^- \t\n\r\f(),^+*\/]*$//;
 length $string;
}

sub wordend
{my ($w,$pos) = @_;
 my $string = $w->get;
 my $anc = length $string;
 $pos = $w->index('insert') unless(defined $pos);
 $string = substr($string,$pos);
 $string =~ s/^(?:((?=[- \t\n\r\f(),^+*\/])[- \t\n\r\f(),+*\/]*|(?=[^- \t\n\r\f(),^+*\/])[^- \t\n\r\f(),^+*\/]*))//x;
 $anc - length($string);
}

1;