/[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 519 by dpavlin, Tue Nov 25 17:15:18 2008 UTC
# Line 1  Line 1 
1  package Frey::Pipe;  package Frey::Pipe;
2  use Moose;  use Moose;
3  extends 'Frey';  extends 'Frey::ClassLoader';
4    with 'Frey::Web';
5    
6  use Frey::Action;  use Frey::Action;
7    
# Line 10  Shell pipes for structured data Line 11  Shell pipes for structured data
11    
12  =head1 EXAMPLE  =head1 EXAMPLE
13    
14   Frey::Feed/data + uri=http://blog.rot13.org/index.xml | Frey::Dumper/markup   Frey::Feed/as_data + uri=http://blog.rot13.org/index.xml | Frey::View::Dumper/as_markup
15    
16  this will produce following code:  this will produce following code:
17    
18          Frey::Dumper->new( data =>          Frey::View::Dumper->new( data =>
19                  Frey::Feed->new( uri => 'http://blog.rot13.org/index.xml' )->data                  Frey::Feed->new( uri => 'http://blog.rot13.org/index.xml' )->as_data
20          )->markup          )->as_markup
21    
22  =cut  =cut
23    
24  has pipe => (  has pipe => (
25          is => 'rw',          is => 'rw',
26          required => 1,          required => 1,
27          default => 'Frey::Feed/data+uri=http://blog.rot13.org/index.xml|Frey::Dumper/markup',          default => 'Frey::Feed/as_data+uri=http://blog.rot13.org/index.xml|Frey::View::Dumper/as_markup',
28  );  );
29    
30  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
31    
32  sub markup {  sub as_markup {
33          my ($self) = @_;          my ($self) = @_;
34    
35          my $out;          my $out;
36          my $pipe;          my $pipe;
37    
38            $self->title( $self->pipe );
39    
40            my @parts;
41    
42          foreach my $part ( split(/\|/, $self->pipe ) ) {          foreach my $part ( split(/\|/, $self->pipe ) ) {
43                  warn "# part: '$part'";                  warn "# part: '$part'";
44                  if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) {                  if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) {
# Line 50  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 = $self->new_frey_class( $class, $default );
62                            my $result = $o->$method;
63                            warn "# result ",length( $result ), " bytes ", ref($result);
64    
65                            $self->add_status({ $part => { $class => { method => $method, args => $args } } });
66    
67                            $self->content_type( $o->content_type ) if $o->can('content_type');
68    
                         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>';  
69                          $out = $result;                          $out = $result;
70                            $method =~ s{^as_}{};
71                          $pipe = { $method => $result };                          $pipe = { $method => $result };
72                  } else {                  } else {
73                          die "don't know what to do with '$part' from ",$self->pipe;                          die "don't know what to do with '$part' from ",$self->pipe;
74                  }                  }
75          }          }
76    
77          return '<code>' . $self->pipe . '</code>' . $out;          return $out;
78  }  }
79    
80  1;  1;

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

  ViewVC Help
Powered by ViewVC 1.1.26