/[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

Annotation of /trunk/lib/Frey/Pipe.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 420 - (hide annotations)
Tue Nov 18 17:11:08 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 2102 byte(s)
push pipe elements into status
1 dpavlin 300 package Frey::Pipe;
2     use Moose;
3 dpavlin 384 extends 'Frey';
4 dpavlin 401 with 'Frey::Web';
5 dpavlin 368
6 dpavlin 386 use Frey::Action;
7    
8 dpavlin 300 =head1 DESCRIPTION
9    
10     Shell pipes for structured data
11    
12     =head1 EXAMPLE
13    
14     Frey::Feed/data + uri=https://blog.rot13.org/index.xml | Frey::Dumper/markup
15    
16     this will produce following code:
17    
18     Frey::Dumper->new( data =>
19     Frey::Feed->new( uri => 'https://blog.rot13.org/index.xml' )->data
20     )->markup
21    
22     =cut
23    
24     has pipe => (
25     is => 'rw',
26     required => 1,
27     default => 'Frey::Feed/data+uri=https://blog.rot13.org/index.xml|Frey::Dumper/markup',
28     );
29    
30     use Data::Dump qw/dump/;
31    
32     sub markup {
33     my ($self) = @_;
34    
35     my $out;
36     my $pipe;
37    
38 dpavlin 418 $self->title( ref($self) . ' | ' . $self->pipe );
39    
40 dpavlin 300 foreach my $part ( split(/\|/, $self->pipe ) ) {
41     warn "# part: '$part'";
42 dpavlin 377 if ( $part =~ m{^([^/]+)/([^\+\?]+)(.*)?$} ) {
43 dpavlin 300 my ( $class, $method, $args ) = ( $1, $2, $3 );
44 dpavlin 420 push @{ $self->status }, { $class => { method => $method, args => $args } };
45 dpavlin 300 my $params = $pipe;
46 dpavlin 386 $params = {} unless defined $params;
47 dpavlin 300 if ( defined $args ) {
48 dpavlin 377 $args =~ s{^[\?\+\s]}{};
49 dpavlin 384 warn "# class $class method $method args '$args'", $pipe ? " pipe args " . join(',',keys %$pipe) : '' if $self->debug;
50 dpavlin 401 push @{ $self->status }, { $class =>$args };
51 dpavlin 300 map {
52 dpavlin 377 my ( $name, $value ) = ( $1, $2 ) if m{^([^=]+)=(.+)$} || confess "can't parse '$_'";
53 dpavlin 300 $params->{$name} = $value;
54 dpavlin 377 } split(/\s*\+\s/, $args)
55 dpavlin 300 }
56 dpavlin 386
57     my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;
58 dpavlin 414 warn "$class need more params than ",dump( $default ) if $html && $self->debug; # FIXME replace with query
59 dpavlin 386
60     my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();';
61 dpavlin 414 warn "# pipe $part -> $code" if $self->debug;
62 dpavlin 300 my $result;
63     eval $code;
64     die $@ if $@;
65     warn "# result ",ref( $result );
66 dpavlin 327 # $out .= qq{<span class="frey-popdown">$part<code>} . dump( $result ) . '</code><span><hr>';
67     $out = $result;
68 dpavlin 300 $pipe = { $method => $result };
69     } else {
70     die "don't know what to do with '$part' from ",$self->pipe;
71     }
72     }
73    
74 dpavlin 420 warn "# pipe ", $self->title, dump( $self->status );
75    
76 dpavlin 418 return $out;
77 dpavlin 300 }
78    
79     1;

  ViewVC Help
Powered by ViewVC 1.1.26