/[Frey]/trunk/lib/Frey/ClassLoader.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/ClassLoader.pm

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

revision 431 by dpavlin, Wed Nov 19 00:40:03 2008 UTC revision 590 by dpavlin, Fri Nov 28 16:35:59 2008 UTC
# Line 8  Load L<Frey> classes Line 8  Load L<Frey> classes
8  =cut  =cut
9    
10  extends 'Frey';  extends 'Frey';
11    with 'Frey::Session';
12    
13  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
14  use File::Find;  use File::Find;
# Line 29  sub classes { Line 30  sub classes {
30    
31          # FIXME there must be better way to do this in Moose style          # FIXME there must be better way to do this in Moose style
32          finddepth({ no_chdir => 1, wanted => sub {          finddepth({ no_chdir => 1, wanted => sub {
33                  return unless s/\.pm$//;                  return unless m{\.pm$};
34                  my @a = split(m!/!,$_);                  my $class = $_;
35                  my $class = join('::', @a[ 1 .. $#a ]);                  $class =~ s{^lib/}{};
36                  warn ">> $_ ",dump( @a ), " >> $class\n" if $self->debug;                  $class =~ s{\.pm$}{};
37                  $class_path->{ $class } = "$_.pm";                  $class =~ s{/}{::}g;
38                    if ( $class =~ m{Mojo} ) {
39                            $self->TODO( "Mojo support" );
40                            return;
41                    }
42                    $class_path->{ $class } = $_;
43          } }, 'lib');          } }, 'lib');
44          warn "## class_path = ",dump( $class_path ) if $self->debug;          warn "## class_path = ",dump( $class_path ) if $self->debug;
45    
# Line 92  sub class_meta { Line 98  sub class_meta {
98    
99          if ( ! $class->can('meta') ) {          if ( ! $class->can('meta') ) {
100                  $instance = Moose::Meta::Class->create_anon_class;                  $instance = Moose::Meta::Class->create_anon_class;
101                  warn "class $class isn't Moose, faking anon class" if $self->debug;                  warn "# class $class isn't Moose, faking anon class" if $self->debug;
102                  $meta = $instance->meta;                  $meta = $instance->meta;
103          } elsif( $class->meta->isa('Moose::Meta::Role') ) {          } elsif( $class->meta->isa('Moose::Meta::Role') ) {
104                  $is_role = 1;                  $is_role = 1;
# Line 108  sub class_meta { Line 114  sub class_meta {
114    
115  sub load_class {  sub load_class {
116          my ( $self, $class ) = @_;          my ( $self, $class ) = @_;
117            return if $loaded_class->{$class}++;
118          eval {          eval {
119                  Class::MOP::load_class($class) if ! $loaded_class->{$class}++;                  Class::MOP::load_class($class)
120          };          };
121          warn $@ if $@; # && $@ !~ m/role/;          warn $@ if $@; # && $@ !~ m/role/;
122          warn "# load_class $class" if $self->debug && $loaded_class->{$class} == 1;          warn "# load_class $class" if $self->debug && $loaded_class->{$class} == 1;
# Line 138  sub class_methods { Line 145  sub class_methods {
145    
146          confess "need class" unless $class;          confess "need class" unless $class;
147          if ( ! $class->can('meta') ) {          if ( ! $class->can('meta') ) {
148                  warn "$class doesn't have meta (isn't Moose class)" if $self->debug;                  warn "# $class doesn't have meta (isn't Moose class)" if $self->debug;
149                  return;                  return;
150          }          }
151          my $meta = $class->meta;          my $meta = $class->meta;
# Line 153  sub class_methods { Line 160  sub class_methods {
160          return $methods;          return $methods;
161  }  }
162    
163    =head2 class_runnable
164    
165      my @runnable_methods = $o->class_runnable( $class );
166    
167    =cut
168    
169    sub class_runnable {
170            my ( $self, $class ) = @_;
171            my @methods = grep { m{^as_} || m{_as_} } $self->class_methods( $class );
172            return @methods if wantarray;
173            return \@methods;
174    }
175    
176    sub class_inputs {
177            my ( $self, $class ) = @_;
178            my @inputs = grep { m{^(markup/as_data/as_sponge)$} } $self->class_methods( $class );
179            return @inputs if wantarray;
180            return \@inputs;
181    }
182    
183    =head2 new_frey_class
184    
185      my $instance = $o->new_frey_class( $class, $params );
186    
187    This will apply L<Moose::Role> on the fly to provide accessors for
188    C<data> and C<sponge> in form of C<as_*>
189    
190    See L<http://www.perlmonks.org/?node_id=602389>
191    
192    It is used by L<Frey::Run> and L<Frey::Pipe> to create objects
193    
194    =cut
195    
196    {
197            package Frey::Role::as_data;
198            use Moose::Role;
199    
200            sub as_data {
201                    my ($self) = @_;
202                    $self->data;
203            }
204    
205            package Frey::Role::as_sponge;
206            use Moose::Role;
207            sub as_sponge {
208                    my ($self) = @_;
209                    $self->sponge;
210            }
211    }
212    
213    sub new_frey_class {
214            my ( $self, $class, $params ) = @_;
215            my $instance;
216            
217            if ( $class->meta->isa('Moose::Meta::Role') ) {
218                    $instance = Frey->new;
219                    Frey::Web->meta->apply( $instance );
220                    warn "new_frey_class $class role with Frey::Web";
221            } else {
222                    $instance = $class->new( %$params ) or confess "can't $class->new".dump( %$params );
223                    warn "new_frey_class $class";
224            }
225    
226            if ( $instance->can('data') && ! $instance->can('as_data') ) {
227                    Frey::Role::as_data->meta->apply( $instance );
228                    warn "# apply as_data role to $class";
229            }
230            if ( $instance->can('sponge') && ! $instance->can('as_sponge') ) {
231                    Frey::Role::as_sponge->meta->apply( $instance );
232                    warn "# apply as_sponge role to $class";
233            }
234    
235            if ( ! $instance->can('add_status') ) {
236                    Frey::Web->meta->apply( $instance );
237                    warn "# apply Frey::Web role to $class";
238            }
239    
240            $self->add_status({ $class => $params });
241            return $instance;
242    }
243    
244  1;  1;

Legend:
Removed from v.431  
changed lines
  Added in v.590

  ViewVC Help
Powered by ViewVC 1.1.26