/[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 401 by dpavlin, Tue Nov 18 02:17:06 2008 UTC revision 451 by dpavlin, Wed Nov 19 04:14:12 2008 UTC
# Line 35  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{^([^/]+)/([^\+\?]+)(.*)?$} ) {
43                          my ( $class, $method, $args ) = ( $1, $2, $3 );                          my ( $class, $method, $args ) = ( $1, $2, $3 );
44                            push @{ $self->status }, { $class => { method => $method, args => $args } };
45                          my $params = $pipe;                          my $params = $pipe;
46                          $params = {} unless defined $params;                          $params = {} unless defined $params;
47                          if ( defined $args ) {                          if ( defined $args ) {
# Line 52  sub markup { Line 55  sub markup {
55                          }                          }
56    
57                          my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;                          my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;
58                          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
59    
60                            warn "# pipe $part" if $self->debug;
61                            my $o = $class->new( %$default );
62                            my $result = $o->$method;
63                            warn "# result ",length( $result ), " bytes ", ref($result);
64    
65                            $self->content_type( $o->content_type ) if $o->can('content_type');
66    
                         my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();';  
                         warn "# pipe $part -> $code";  
                         my $result;  
                         eval $code;  
                         die $@ if $@;  
                         warn "# result ",ref( $result );  
 #                       $out .= qq{<span class="frey-popdown">$part<code>} . dump( $result ) . '</code><span><hr>';  
67                          $out = $result;                          $out = $result;
68                          $pipe = { $method => $result };                          $pipe = { $method => $result };
69                  } else {                  } else {
# Line 68  sub markup { Line 71  sub markup {
71                  }                  }
72          }          }
73    
74          return '<code>' . $self->pipe . '</code>' . $out;          warn "# pipe ", $self->title;
75    
76            return $out;
77  }  }
78    
79  1;  1;

Legend:
Removed from v.401  
changed lines
  Added in v.451

  ViewVC Help
Powered by ViewVC 1.1.26