/[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 467 - (hide annotations)
Wed Nov 19 19:28:09 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 2096 byte(s)
rename class with experimental script
1 dpavlin 300 package Frey::Pipe;
2     use Moose;
3 dpavlin 457 extends 'Frey::ClassLoader';
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 dpavlin 467 Frey::Feed/as_data + uri=http://blog.rot13.org/index.xml | Frey::View::Dumper/as_markup
15 dpavlin 300
16     this will produce following code:
17    
18 dpavlin 467 Frey::View::Dumper->new( data =>
19 dpavlin 455 Frey::Feed->new( uri => 'http://blog.rot13.org/index.xml' )->as_data
20     )->as_markup
21 dpavlin 300
22     =cut
23    
24     has pipe => (
25     is => 'rw',
26     required => 1,
27 dpavlin 467 default => 'Frey::Feed/as_data+uri=http://blog.rot13.org/index.xml|Frey::View::Dumper/as_markup',
28 dpavlin 300 );
29    
30     use Data::Dump qw/dump/;
31    
32 dpavlin 455 sub as_markup {
33 dpavlin 300 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 dpavlin 451 warn "# pipe $part" if $self->debug;
61 dpavlin 457 my $o = $self->new_frey_class( $class, $default );
62 dpavlin 451 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    
67 dpavlin 327 $out = $result;
68 dpavlin 455 $method =~ s{^as_}{};
69 dpavlin 300 $pipe = { $method => $result };
70     } else {
71     die "don't know what to do with '$part' from ",$self->pipe;
72     }
73     }
74    
75 dpavlin 451 warn "# pipe ", $self->title;
76 dpavlin 420
77 dpavlin 418 return $out;
78 dpavlin 300 }
79    
80     1;

  ViewVC Help
Powered by ViewVC 1.1.26