103 |
return $out; |
return $out; |
104 |
} |
} |
105 |
|
|
|
=head2 methods |
|
|
|
|
|
my @methods = $o->methods; |
|
|
|
|
|
=cut |
|
|
|
|
|
sub methods { |
|
|
my $self = shift; |
|
|
|
|
|
my ( $meta, $is_role ) = $self->class_meta; |
|
|
|
|
|
my $attr; |
|
|
$attr->{$_}++ foreach $meta->get_attribute_list; |
|
|
my @methods = grep { ! defined($attr->{$_}) } $meta->get_method_list; |
|
|
warn "# methods = ",dump( @methods ) if $self->debug; |
|
|
|
|
|
return sort @methods; |
|
|
} |
|
|
|
|
106 |
=head1 OUTPUT GENERATION |
=head1 OUTPUT GENERATION |
107 |
|
|
108 |
=head2 markup |
=head2 markup |
162 |
$name .= qq|<sup title="$role_name">$nr</sup>|; |
$name .= qq|<sup title="$role_name">$nr</sup>|; |
163 |
} |
} |
164 |
qq|<td class="m">$name</td>| |
qq|<td class="m">$name</td>| |
165 |
} $self->methods; |
} $self->class_methods( $class ); |
166 |
|
|
167 |
my @attributes; |
my @attributes; |
168 |
if ( $meta->get_attribute_list ) { |
if ( $meta->get_attribute_list ) { |
169 |
@attributes = map { |
@attributes = map { |
170 |
my $name = $_; |
my $name = $_; |
171 |
my $attr = $meta->get_attribute($name); |
my $attr = $meta->get_attribute($name); |
172 |
warn "## ref attr: ",ref( $attr ); |
warn "## attr $name ref ",ref( $attr ) if $self->debug; |
173 |
my ( $before, $title, $after ) = ( '', '', '' ); |
my ( $before, $title, $after ) = ( '', '', '' ); |
174 |
( $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); |
|
175 |
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/ ) { |
176 |
my $getter; |
my $getter; |
177 |
|
|
213 |
my $pod = Frey::Pod->new( class => $class )->markup; |
my $pod = Frey::Pod->new( class => $class )->markup; |
214 |
$pod = $pod->{body} if ref($pod); |
$pod = $pod->{body} if ref($pod); |
215 |
|
|
216 |
my $Document = PPI::Document->new( $self->class_path( $class ) ); |
my $path = $self->class_path( $class ); |
217 |
|
my $Document = PPI::Document->new( $path ); |
218 |
|
|
219 |
# Create a reusable syntax highlighter |
# Create a reusable syntax highlighter |
220 |
my $Highlight = PPI::HTML->new( |
my $Highlight = PPI::HTML->new( |
221 |
# line_numbers => 1, |
line_numbers => 1, |
222 |
# page => 1, |
# page => 1, |
223 |
# colors => { |
# colors => { |
224 |
# line_number => '#CCCCCC', |
# line_number => '#CCCCCC', |
229 |
# Spit out the HTML |
# Spit out the HTML |
230 |
my $source = $Highlight->html( $Document ); |
my $source = $Highlight->html( $Document ); |
231 |
|
|
232 |
|
$source =~ s{(<span.*?line_number.*>\s*)(\d+)(:\s*</span>)}{$1<a target="editor" href="/editor+$path+$2">$2</a>$3}g; |
233 |
|
|
234 |
|
# strip page html |
235 |
# $source =~ s{^.*<body[^>]+>}{}s; |
# $source =~ s{^.*<body[^>]+>}{}s; |
236 |
# $source =~ s{</body.*$}{}s; |
# $source =~ s{</body.*$}{}s; |
237 |
|
|
238 |
|
|
239 |
use Frey::Run; |
use Frey::Run; |
240 |
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 ); |
241 |
$runnable = " runnable: $runnable" if $runnable; |
$runnable = " runnable: $runnable" if $runnable; |