/[Frey]/trunk/lib/Frey/PPI.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/lib/Frey/PPI.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 331 by dpavlin, Sat Nov 8 16:12:39 2008 UTC revision 487 by dpavlin, Mon Nov 24 17:09:00 2008 UTC
# Line 13  has 'class' => ( Line 13  has 'class' => (
13          documentation => 'Name of class to parse',          documentation => 'Name of class to parse',
14  );  );
15    
16    has 'doc' => (
17            is => 'ro',
18            isa => 'PPI::Document',
19            lazy => 1,
20            default => sub {
21                    my ( $self ) = @_;
22                    my $path = $self->class;
23                    $path = $self->class_path( $path ) unless $path =~ m{/};
24                    warn "# doc from ", $self->class, " at ", $path if $self->debug;
25                    my $doc = PPI::Document->new( $path );
26                    $doc->prune('PPI::Token::Whitespace');
27                    return $doc;
28            },
29    );
30    
31    sub find {
32            my ( $self, $coderef ) = @_;
33    
34            my $doc = $self->doc;
35            $doc->find(sub {
36                    my ( $doc,$el ) = @_;
37                    eval { $coderef->( $doc, $el ) };
38                    warn "ERROR: $@" if $@;
39            });
40    }
41    
42  sub attribute_order {  sub attribute_order {
43          my ( $self ) = @_;          my ( $self ) = @_;
44    
45          my $doc = PPI::Document->new( $self->class_path( $self->class ) ) || die $!;          my @attribute_order;
46            $self->find(sub {
47                    my ($doc,$el) = @_;
48                    return unless
49                            $el->isa('PPI::Statement') &&
50                            $el->{children}->[0]->isa('PPI::Token::Word') &&
51                            $el->{children}->[0]->literal eq 'has';
52    
53                    warn "## has ",$el->{children}->[1]->literal if $self->debug;
54                    push @attribute_order, $el->{children}->[1]->literal;
55            });
56    
57          $doc->prune('PPI::Token::Whitespace');          warn "# ", $self->class, " attribute_order ", dump( @attribute_order ) if $self->debug;
58    
59          my @attribute_order;          return @attribute_order if wantarray;
60            return \@attribute_order;
61    }
62    
63          $doc->find(sub {  sub includes {
64            my $self = shift;
65    
66            my $include;
67            $self->find(sub {
68                  my ($doc,$el) = @_;                  my ($doc,$el) = @_;
69                  if ( $el->isa('PPI::Statement') && $el->{children}->[0]->{content} eq 'has' ) {                  return unless $el->isa('PPI::Statement::Include');
70                          warn "## has ",$el->{children}->[1]->string if $self->debug;  
71                          push @attribute_order, $el->{children}->[1]->string;                  warn "## include ",dump( $el->module, $el->type, $el->pragma ) if $self->debug;
72                  }                  push @{ $include->{ $el->type } }, $el->module
                 return 1;  
73          });          });
74            warn "# ", $self->class, " include ", dump( $include ) if $self->debug;
75            return $include;
76    }
77    
78          warn "# ", $self->class, " attribute_order ", dump( @attribute_order ) if $self->debug;  our $class_has_tests;
79    
80    sub parse_tests {
81            my ( $self ) = @_;
82    
83            map {
84                    warn "## ppi test $_" if $self->debug;
85    
86                    my $doc = Frey::PPI->new( class => $_ );
87                    my @tests;
88    
89    #               warn "## ",dump( $doc );
90    
91                    $doc->find(sub {
92                            my ($doc,$el) = @_;
93                            return unless
94                                    $el->isa('PPI::Statement') &&
95                                    $el->{children}->[0]->isa('PPI::Token::Word') &&
96                                    $el->{children}->[0]->literal eq 'use_ok';
97    
98    #                       warn "## ",dump( $el );
99                            my $class = $el->child(1)->child(0)->child(0)->literal;
100                            $class_has_tests->{$class}->{$_}++;
101                    });
102            } glob 't/*.t';
103            warn "# collected class tests ",dump( $class_has_tests ) if $self->debug;
104    
105            return $class_has_tests;
106    }
107    
108    =head2 has_tests
109    
110      my @tests = $self->has_tests;
111    
112    =cut
113    
114    sub has_tests {
115            my ($self) = shift;
116            
117            $self->parse_tests unless defined $class_has_tests;
118    
119          return @attribute_order;          my $class = $self->class;
120    
121            if ( my $tests = $class_has_tests->{ $class } ) {
122    #               warn "# has_tests $class ",dump( keys %$tests );
123                    return [ keys %$tests ];
124            }
125            return [];
126  }  }
127    
128  sub data {  =head2 as_data
129    
130    Debugging output
131    
132    =cut
133    
134    sub as_data {
135          my $self = shift;          my $self = shift;
136          [ $self->attribute_order ];          return {
137                    includes => $self->includes,
138                    attribute_order => [ $self->attribute_order ],
139                    doc => $self->doc,
140            };
141  }  }
142    
143  1;  1;

Legend:
Removed from v.331  
changed lines
  Added in v.487

  ViewVC Help
Powered by ViewVC 1.1.26