/[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 327 by dpavlin, Thu Nov 6 20:56:44 2008 UTC revision 386 by dpavlin, Mon Nov 17 22:40:22 2008 UTC
# Line 1  Line 1 
1  package Frey::Pipe;  package Frey::Pipe;
2  use Moose;  use Moose;
3    extends 'Frey';
4    
5    use Frey::Action;
6    
7  =head1 DESCRIPTION  =head1 DESCRIPTION
8    
# Line 33  sub markup { Line 36  sub markup {
36    
37          foreach my $part ( split(/\|/, $self->pipe ) ) {          foreach my $part ( split(/\|/, $self->pipe ) ) {
38                  warn "# part: '$part'";                  warn "# part: '$part'";
39                  if ( $part =~ m{^([^/]+)/([^\+]+)(\+.*)?$} ) {                  if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) {
40                          my ( $class, $method, $args ) = ( $1, $2, $3 );                          my ( $class, $method, $args ) = ( $1, $2, $3 );
41                          my $params = $pipe;                          my $params = $pipe;
42                            $params = {} unless defined $params;
43                          if ( defined $args ) {                          if ( defined $args ) {
44                                  $args =~ s/^\+//;                                  $args =~ s{^[\?\+\s]}{};
45                                  warn "# class $class method $method args $args", $pipe ? " pipe args " . join(',',keys %$pipe) : '';                                  warn "# class $class method $method args '$args'", $pipe ? " pipe args " . join(',',keys %$pipe) : '' if $self->debug;
46                                  map {                                  map {
47                                          my ( $name, $value ) = ( $1, $2 ) if m{^([^=]+)=(.+)$};                                          my ( $name, $value ) = ( $1, $2 ) if m{^([^=]+)=(.+)$} || confess "can't parse '$_'";
48                                          $params->{$name} = $value;                                          $params->{$name} = $value;
49                                  } split(/[\s\+]/, $args)                                  } split(/\s*\+\s/, $args)
50                          }                          }
51                          my $code = '$result = ' . $class . '->new' . dump( %$params ) . '->' . $method . '();';  
52                            my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;
53                            warn "$class need more params than ",dump( $default ) if $html; # FIXME replace with query
54    
55                            my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();';
56                          warn "# pipe $part -> $code";                          warn "# pipe $part -> $code";
57                          my $result;                          my $result;
58                          eval $code;                          eval $code;
# Line 58  sub markup { Line 66  sub markup {
66                  }                  }
67          }          }
68    
69          return $out;          return '<code>' . $self->pipe . '</code>' . $out;
70  }  }
71    
72  1;  1;

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

  ViewVC Help
Powered by ViewVC 1.1.26