35 |
$class =~ s{^lib/}{}; |
$class =~ s{^lib/}{}; |
36 |
$class =~ s{\.pm$}{}; |
$class =~ s{\.pm$}{}; |
37 |
$class =~ s{/}{::}g; |
$class =~ s{/}{::}g; |
38 |
if ( $class =~ m{Mojo} ) { |
if ( 0 && $class =~ m{Mojo} ) { # FIXME remove dead code |
39 |
$self->TODO( "Mojo support" ); |
$self->TODO( "Mojo support" ); |
40 |
return; |
return; |
41 |
} |
} |
61 |
my $path = $class; |
my $path = $class; |
62 |
$path =~ s{::}{/}g; |
$path =~ s{::}{/}g; |
63 |
$path .= '.pm'; |
$path .= '.pm'; |
64 |
$path = $INC{$path}; |
if ( defined $INC{$path} ) { |
65 |
warn "# $class from INC $path"; |
$path = $INC{$path}; |
66 |
$class_path->{$class} = $path || confess "can't find path for $class"; |
warn "# $class from INC $path"; |
67 |
|
$class_path->{$class} = $path; |
68 |
|
} elsif ( $path =~ s{\.pm$}{} && -e "lib/${path}.pod" ) { |
69 |
|
return "lib/${path}.pod"; |
70 |
|
} else { |
71 |
|
confess "can't find $class at $path"; |
72 |
|
} |
73 |
} |
} |
74 |
return $class_path->{$class}; |
return $class_path->{$class}; |
75 |
} |
} |
216 |
} |
} |
217 |
} |
} |
218 |
|
|
219 |
|
our $syntax_checked_last; |
220 |
|
|
221 |
sub new_frey_class { |
sub new_frey_class { |
222 |
my ( $self, $class, $params ) = @_; |
my ( $self, $class, $params ) = @_; |
223 |
my $instance; |
my $instance; |
224 |
|
|
225 |
|
my $path = $self->class_path( $class ); |
226 |
|
if ( $syntax_checked_last->{$class} != -C $path ) { |
227 |
|
my $syntax = `perl -Ilib -wc $path 2>&1`; |
228 |
|
warn "# syntax: $syntax"; |
229 |
|
$syntax_checked_last->{$class} = -C $class; |
230 |
|
} |
231 |
|
|
232 |
if ( $class->meta->isa('Moose::Meta::Role') ) { |
if ( $class->meta->isa('Moose::Meta::Role') ) { |
233 |
$instance = Frey->new; |
$instance = Frey->new; |
234 |
Frey::Web->meta->apply( $instance ); |
Frey::Web->meta->apply( $instance ); |
235 |
warn "new_frey_class $class role with Frey::Web"; |
warn "new_frey_class $class role with Frey::Web"; |
236 |
} else { |
} else { |
237 |
$params->{request_url} = $self->request_url; |
if ( $self->can('request_url') ) { |
238 |
|
$params->{request_url} = $self->request_url; |
239 |
|
} else { |
240 |
|
warn "## $self doesn't have request_url"; |
241 |
|
} |
242 |
$instance = $class->new( %$params ) or confess "can't $class->new".dump( %$params ); |
$instance = $class->new( %$params ) or confess "can't $class->new".dump( %$params ); |
243 |
warn "new_frey_class $class"; |
warn "new_frey_class $class"; |
244 |
} |
} |