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

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

revision 187 by dpavlin, Sat Sep 13 15:31:54 2008 UTC revision 308 by dpavlin, Wed Nov 5 19:13:01 2008 UTC
# Line 1  Line 1 
1  package Frey::ClassBrowser;  package Frey::ClassBrowser;
2  use Moose;  use Moose;
3    
4  extends 'Frey';  extends 'Frey::ClassLoader';
 with 'Frey::Web';  
5    
6  use Frey::ClassLoader;  use Frey::Run;
7    
8  our $markup;  our $markup;
9    
10  sub markup {  sub markup {
11            my $self = shift;
12          return $markup if $markup;          return $markup if $markup;
         my $f = Frey::ClassLoader->new;  
13          my $html;          my $html;
14          foreach my $package ( $f->classes ) {          foreach my $class ( $self->classes ) {
15                  $html .= qq|<tr><td><a href="/~/$package" title="| . $f->package_path( $package ) . qq|">$package</a></td><td>|;                  $html .= qq|<tr><td><a href="/$class" title="| . $self->class_path( $class ) . qq|">$class</a></td><td>|;
16                  if ( $package->can('meta') ) {                  if ( $class->can('meta') ) {
17                          if ( $package->meta->isa('Moose::Meta::Role') ) {                          if ( $class->meta->isa('Moose::Meta::Role') ) {
18                                  $html .= qq|role|;                                  $html .= qq|role|;
19                          } else {                          } else {
20                                  $html .= qq|<a href="/od/$package">design</a>| if $package->can('collection');                                  $html .= qq|<a href="/Frey-ObjectDesigner?class=$class">design</a>| if $class->can('collection');
21                          }                          }
22                  }                  }
23                  my @inspect;                  my @inspect;
24                  push @inspect, qq|<a href="/ob/$package">collection</a>| if $package->can('collection_table');                  push @inspect, qq|<a href="/Frey-ObjectBrowser?class=$class">collection</a>| if $class->can('collection_table');
25                  push @inspect, qq|<a href="/markup/$package">markup</a>| if $package->can('markup');                  foreach my $try ( Frey::Run->execute ) {
26                  push @inspect, qq|<a href="/html/$package">html</a>| if $package->can('html');                          push @inspect, qq|<a href="/$class/$try">$try</a>| if $class->can($try);
27                    }
28                  $html .= qq|</td><td>| . join('&nbsp;', @inspect) . qq|</td></tr>|;                  $html .= qq|</td><td>| . join('&nbsp;', @inspect) . qq|</td></tr>|;
29          }          }
30          $html = "<table>$html</table>" if $html;          $html = "<table>$html</table>" if $html;
31          $markup = $html;          $markup = $html;
32  }  }
33    
 sub html {  
         my ( $self, $req ) = @_;  
         my $html = $self->page( body => qq|<h1>Classes</h1>| . $self->markup );  
         $req->print( $html );  
 }  
   
34  1;  1;

Legend:
Removed from v.187  
changed lines
  Added in v.308

  ViewVC Help
Powered by ViewVC 1.1.26