/[Frey]/trunk/lib/Frey/Server.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/Server.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 178 by dpavlin, Thu Jul 17 21:07:16 2008 UTC revision 179 by dpavlin, Sun Aug 31 17:44:03 2008 UTC
# Line 46  sub main { Line 46  sub main {
46    
47  #       warn $req->request->header('User_Agent');  #       warn $req->request->header('User_Agent');
48    
49            sub run_markup {
50                    my ( $req, $class ) = @_;
51    
52                    my %params = $req->params;
53    
54                    my @required =
55                            grep {
56                                    defined $_ && !defined( $params{$_} )
57                            }
58                            map {
59                                    my $attr = $class->meta->get_attribute($_);
60                                    $attr->is_required && $_
61                            } $class->meta->get_attribute_list;
62    
63                    warn "## required = ",dump( @required );
64                    warn "## params = ",dump( %params );
65    
66                    my $html;
67    
68                    if ( @required ) {
69                            $html = qq|<form method="post">|;
70                            $html .= qq|<input type="text" name="$_">| foreach @required;
71                            $html .= qq|<input type="submit" value="Run $class"></form>|;
72                    } else {
73                            my $o = $class->new( %params );
74                            $o->depends if $o->can('depends');
75                            $html = $o->markup;
76                    }
77    
78                    warn ">>> markup $class ",length( $html ), " bytes\n";
79                    return $html;
80            }
81    
82    
83  #       eval {  #       eval {
84          {          {
85    
# Line 57  sub main { Line 91  sub main {
91                          $f = Frey::ObjectBrowser->new( fey_class => $1 );                          $f = Frey::ObjectBrowser->new( fey_class => $1 );
92                  } elsif ( $path =~ m!/od/([^/]+)(.*)! ) {                  } elsif ( $path =~ m!/od/([^/]+)(.*)! ) {
93                          $f = Frey::ObjectDesigner->new( fey_class => $1 );                          $f = Frey::ObjectDesigner->new( fey_class => $1 );
                 } elsif ( $path =~ m!/pod/([^/]+)(.*)! ) {  
                         $f = Frey::Pod->new( class => $1 );  
94                  } elsif ( $path =~ m!/markup/([^/]+)(.*)! ) {                  } elsif ( $path =~ m!/markup/([^/]+)(.*)! ) {
95                          my $o = $1->new( $req->params );                          $req->print( run_markup( $req, $1 )  );
                         $o->depends if $o->can('depends');  
                         my $html = $o->markup( $req->params );  
                         warn ">>> markup $1 ",length( $html ), " bytes\n";  
                         $req->print( $html );  
96                  } else {                  } else {
97                          $f = Frey::ClassBrowser->new;                          $f = Frey::ClassBrowser->new;
98                  }                  }

Legend:
Removed from v.178  
changed lines
  Added in v.179

  ViewVC Help
Powered by ViewVC 1.1.26