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

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

revision 380 by dpavlin, Mon Nov 17 18:42:51 2008 UTC revision 407 by dpavlin, Tue Nov 18 12:02:57 2008 UTC
# Line 188  sub markup { Line 188  sub markup {
188          @attributes = map {          @attributes = map {
189                          my $name = $_;                          my $name = $_;
190                          my $attr = $meta->get_attribute($name);                          my $attr = $meta->get_attribute($name);
191                          warn "## ref attr: ",ref( $attr );                          warn "## attr $name ref ",ref( $attr ) if $self->debug;
192                          my ( $before, $title, $after ) = ( '', '', '' );                          my ( $before, $title, $after ) = ( '', '', '' );
193                          ( $before, $title, $after ) = ( '<b>', ' title="required"', '</b>' ) if $attr->is_required;                          ( $before, $title, $after ) = ( '<b>', ' title="required"', '</b>' ) if $attr->is_required;
 warn $attr->dump(3);  
194                          foreach my $check ( qw/has_type_constraint has_handles is_weak_ref is_required is_lazy should_coerce should_auto_deref has_default has_trigger has_documentation has_applied_traits/ ) {                          foreach my $check ( qw/has_type_constraint has_handles is_weak_ref is_required is_lazy should_coerce should_auto_deref has_default has_trigger has_documentation has_applied_traits/ ) {
195                                  my $getter;                                  my $getter;
196                                                                    
# Line 233  warn $attr->dump(3); Line 232  warn $attr->dump(3);
232          my $pod = Frey::Pod->new( class => $class )->markup;          my $pod = Frey::Pod->new( class => $class )->markup;
233          $pod = $pod->{body} if ref($pod);          $pod = $pod->{body} if ref($pod);
234    
235          my $Document = PPI::Document->new( $self->class_path( $class ) );          my $path = $self->class_path( $class );
236            my $Document = PPI::Document->new( $path );
237    
238          # Create a reusable syntax highlighter          # Create a reusable syntax highlighter
239          my $Highlight = PPI::HTML->new(          my $Highlight = PPI::HTML->new(
240  #               line_numbers => 1,                  line_numbers => 1,
241  #               page => 1,  #               page => 1,
242  #               colors => {  #               colors => {
243  #                       line_number => '#CCCCCC',  #                       line_number => '#CCCCCC',
# Line 248  warn $attr->dump(3); Line 248  warn $attr->dump(3);
248          # Spit out the HTML          # Spit out the HTML
249          my $source = $Highlight->html( $Document );          my $source = $Highlight->html( $Document );
250    
251            $source =~ s{(<span.*?line_number.*>\s*)(\d+)(:\s*</span>)}{$1<a target="editor" href="/editor+$path+$2">$2</a>$3}g;
252    
253            # strip page html
254  #       $source =~ s{^.*<body[^>]+>}{}s;  #       $source =~ s{^.*<body[^>]+>}{}s;
255  #       $source =~ s{</body.*$}{}s;  #       $source =~ s{</body.*$}{}s;
256    
257    
258          use Frey::Run;          use Frey::Run;
259          my $runnable = join("\n", map { qq|<a href="/$class/$_">$_</a>| } grep { $class->can($_) } Frey::Run->runnable );          my $runnable = join("\n", map { qq|<a href="/$class/$_">$_</a>| } grep { $class->can($_) } Frey::Run->runnable );
260          $runnable = " runnable: $runnable" if $runnable;          $runnable = " runnable: $runnable" if $runnable;
261    
262          my $html = {          my $html = {
263                  title => $class,                  title => $class,
264                  body => join("\n"                  body => join("\n",
265                          , qq|<h1>$class</h1>|,                          qq|<h1>$class</h1>|,
266                          , qq|<div class="frey-introspect">$superclasses\n$roles\n$runnable\n|,                          qq|<div class="frey-introspect">$superclasses\n$roles\n$runnable\n|,
267                          , ( $pod ? qq|<a href="#___top" title="Skip to POD" class="frey-skip">pod</a>| : '' )                          $pod    ? qq|<a class="frey-skip" href="#___top" title="Skip to POD"    >pod</a>|    : '',
268                          , qq|<a href="#source" title="Skip to source" class="frey-skip">source</a>|                          $source ? qq|<a class="frey-skip" href="#source" title="Skip to source" >source</a>| : '',
269                          , qq|$table\n$pod\n</div>\n|                          qq|$table\n$pod\n</div>\n|,
270                          , qq|<h1>Source</h1><a name="source"></a><div class="frey-source">$source</div>|                          qq|<h1>Source</h1><a name="source"></a><div class="frey-source">$source</div>|,
271                  ),                  ),
272          };          };
273    

Legend:
Removed from v.380  
changed lines
  Added in v.407

  ViewVC Help
Powered by ViewVC 1.1.26