/[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 418 - (hide annotations)
Tue Nov 18 16:54:10 2008 UTC (15 years, 5 months ago) by dpavlin
File size: 1967 byte(s)
Add title to Frey::Web and use it
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     my $params = $pipe;
45 dpavlin 386 $params = {} unless defined $params;
46 dpavlin 300 if ( defined $args ) {
47 dpavlin 377 $args =~ s{^[\?\+\s]}{};
48 dpavlin 384 warn "# class $class method $method args '$args'", $pipe ? " pipe args " . join(',',keys %$pipe) : '' if $self->debug;
49 dpavlin 401 push @{ $self->status }, { $class =>$args };
50 dpavlin 300 map {
51 dpavlin 377 my ( $name, $value ) = ( $1, $2 ) if m{^([^=]+)=(.+)$} || confess "can't parse '$_'";
52 dpavlin 300 $params->{$name} = $value;
53 dpavlin 377 } split(/\s*\+\s/, $args)
54 dpavlin 300 }
55 dpavlin 386
56     my ( $html, $default ) = Frey::Action->new( class => $class, params => $params )->params_form;
57 dpavlin 414 warn "$class need more params than ",dump( $default ) if $html && $self->debug; # FIXME replace with query
58 dpavlin 386
59     my $code = '$result = ' . $class . '->new' . dump( %$default ) . '->' . $method . '();';
60 dpavlin 414 warn "# pipe $part -> $code" if $self->debug;
61 dpavlin 300 my $result;
62     eval $code;
63     die $@ if $@;
64     warn "# result ",ref( $result );
65 dpavlin 327 # $out .= qq{<span class="frey-popdown">$part<code>} . dump( $result ) . '</code><span><hr>';
66     $out = $result;
67 dpavlin 300 $pipe = { $method => $result };
68     } else {
69     die "don't know what to do with '$part' from ",$self->pipe;
70     }
71     }
72    
73 dpavlin 418 return $out;
74 dpavlin 300 }
75    
76     1;

  ViewVC Help
Powered by ViewVC 1.1.26