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

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

revision 386 by dpavlin, Mon Nov 17 22:40:22 2008 UTC revision 418 by dpavlin, Tue Nov 18 16:54:10 2008 UTC
# Line 1  Line 1 
1  package Frey::Pipe;  package Frey::Pipe;
2  use Moose;  use Moose;
3  extends 'Frey';  extends 'Frey';
4    with 'Frey::Web';
5    
6  use Frey::Action;  use Frey::Action;
7    
# Line 34  sub markup { Line 35  sub markup {
35          my $out;          my $out;
36          my $pipe;          my $pipe;
37    
38            $self->title( ref($self) . ' | ' . $self->pipe );
39    
40          foreach my $part ( split(/\|/, $self->pipe ) ) {          foreach my $part ( split(/\|/, $self->pipe ) ) {
41                  warn "# part: '$part'";                  warn "# part: '$part'";
42                  if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) {                  if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) {
# Line 43  sub markup { Line 46  sub markup {
46                          if ( defined $args ) {                          if ( defined $args ) {
47                                  $args =~ s{^[\?\+\s]}{};                                  $args =~ s{^[\?\+\s]}{};
48                                  warn "# class $class method $method args '$args'", $pipe ? " pipe args " . join(',',keys %$pipe) : '' if $self->debug;                                  warn "# class $class method $method args '$args'", $pipe ? " pipe args " . join(',',keys %$pipe) : '' if $self->debug;
49                                    push @{ $self->status }, { $class =>$args };
50                                  map {                                  map {
51                                          my ( $name, $value ) = ( $1, $2 ) if m{^([^=]+)=(.+)$} || confess "can't parse '$_'";                                          my ( $name, $value ) = ( $1, $2 ) if m{^([^=]+)=(.+)$} || confess "can't parse '$_'";
52                                          $params->{$name} = $value;                                          $params->{$name} = $value;
# Line 50  sub markup { Line 54  sub markup {
54                          }                          }
55    
56                          my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;                          my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;
57                          warn "$class need more params than ",dump( $default ) if $html; # FIXME replace with query                          warn "$class need more params than ",dump( $default ) if $html && $self->debug; # FIXME replace with query
58    
59                          my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();';                          my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();';
60                          warn "# pipe $part -> $code";                          warn "# pipe $part -> $code" if $self->debug;
61                          my $result;                          my $result;
62                          eval $code;                          eval $code;
63                          die $@ if $@;                          die $@ if $@;
# Line 66  sub markup { Line 70  sub markup {
70                  }                  }
71          }          }
72    
73          return '<code>' . $self->pipe . '</code>' . $out;          return $out;
74  }  }
75    
76  1;  1;

Legend:
Removed from v.386  
changed lines
  Added in v.418

  ViewVC Help
Powered by ViewVC 1.1.26