=================================================================== RCS file: /cvs/todotxt/Text-Todo/lib/Text/Todo/Entry.pm,v retrieving revision 1.1 retrieving revision 1.6 diff -u -r1.1 -r1.6 --- todotxt/Text-Todo/lib/Text/Todo/Entry.pm 2009/07/10 23:26:14 1.1 +++ todotxt/Text-Todo/lib/Text/Todo/Entry.pm 2009/07/13 18:50:37 1.6 @@ -1,6 +1,6 @@ package Text::Todo::Entry; -# $RedRiver$ +# $RedRiver: Entry.pm,v 1.5 2009/07/11 16:02:18 andrew Exp $ use warnings; use strict; @@ -14,10 +14,30 @@ { my %text_of; - my %contexts_of; - my %projects_of; + my %tags_of; my %priority_of; + my %tags = ( + context => q{@}, + project => q{+}, + ); + + for my $tag ( keys %tags ) { + ## no critic strict + no strict 'refs'; # Violates use strict, but allows code generation + ## use critic + + *{ $tag . 's' } = sub { + my ($self) = @_; + return $self->_tags($tag); + }; + + *{ 'in_' . $tag } = sub { + my ( $self, $item ) = @_; + return $self->_is_in( $tag . 's', $item ); + }; + } + sub new { my ( $class, $text ) = @_; @@ -37,56 +57,41 @@ $text_of{$ident} = $text; - %{ $contexts_of{$ident} } = map { $_ => q{} } $text =~ /\@ (\S+)/gxms; - %{ $projects_of{$ident} } = map { $_ => q{} } $text =~ /\+ (\S+)/gxms; - ( $priority_of{$ident} ) = $text =~ /\( ([A-Z]) \)/ixms; + foreach my $tag ( keys %tags ) { + my $symbol = quotemeta $tags{$tag}; + $tags_of{$ident}{$tag} = { map { $_ => q{} } + $text =~ / (?:^|\s) $symbol (\S+)/gxms }; + } + ( $priority_of{$ident} ) = $text =~ /^ \s* \( ([A-Z]) \)/ixms; return 1; } - sub text { - my ($self) = @_; + sub _tags { + my ( $self, $tag ) = @_; my $ident = ident($self); - return $text_of{$ident}; + my @tags = sort keys %{ $tags_of{$ident}{$tag} }; + return wantarray ? @tags : \@tags; } - sub contexts { - my ($self) = @_; - my $ident = ident($self); - - return sort keys %{ $contexts_of{$ident} }; + sub _is_in { + my ( $self, $tags, $item ) = @_; + return defined first { $_ eq $item } $self->$tags; } - sub in_context { - my ( $self, $context ) = @_; - return $self->_is_in( $context, 'contexts' ); - } - - sub projects { + sub text { my ($self) = @_; my $ident = ident($self); - return sort keys %{ $projects_of{$ident} }; + return $text_of{$ident}; } - sub in_project { - my ( $self, $project ) = @_; - return $self->_is_in( $project, 'projects' ); - } - sub priority { my ($self) = @_; my $ident = ident($self); return $priority_of{$ident}; - } - - sub _is_in { - my ( $self, $item, $type ) = @_; - my $ident = ident($self); - - return defined first { $_ eq $item } $self->$type; } sub change {