The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

@* $myclass

VERSION

@* version: @* $app_name, $app_version

Automatically generated by the Perl Swagger Codegen project:

Build date: @* $generated_date
Build package: @* $generator_class
Codegen version:

INHERITANCE

Base class(es)

@* $isa

Direct subclasses

@* $dsub

All subclasses

@* $sub

COMPOSITION

@* composes the following roles: $myclass

. format ROLES_POD = =head2 @* $rolepkg

Requires:

@* $role_reqs

. format ROLES_POD_CLOSE =

. # ----- / format specs ----- }

sub _printmethods { my ($self, $how) = @_;

        if ($how eq 'narrow') {
                print <<HEAD;
METHODS
-------
HEAD
        }
        elsif ($how eq 'wide') {
                $~ = 'METHODHEAD';
                write;
        }
        elsif ($how eq 'pod') {
                $~ = 'METHODHEAD_POD';
                write;
        }
        else {
                die "Don't know how to print '$how'";
        }
        
        $self->_printmethod($_, $how) for uniq sort $self->meta->get_all_method_names; #$self->meta->get_method_list, 
        
        if ($how eq 'pod') {
                $~ = 'METHOD_POD_CLOSE';
                write;
        }

}

sub _printmethod { my ($self, $methodname, $how) = @_; return if $methodname =~ /^_/; return if $self->meta->has_attribute($methodname); my %internal = map {$_ => 1} qw(BUILD BUILDARGS meta can new DEMOLISHALL DESTROY DOES isa BUILDALL does VERSION dump ); return if $internal{$methodname}; my $method = $self->meta->get_method($methodname) or return; # symbols imported into namespaces i.e. not known by Moose

        return if $method->original_package_name eq __PACKAGE__;
        
        my $delegate_to = '';
        my $via = '';
        my $on = '';
        my $doc = '';
        my $original_pkg = $method->original_package_name;
        if ($method->can('associated_attribute')) {
                $delegate_to = $method->delegate_to_method;
                my $aa = $method->associated_attribute;
                $on = $aa->{isa};
                $via = $aa->{name};
                $original_pkg = $on; 
                $doc = $original_pkg->method_documentation->{$delegate_to}->{summary};
        }
        else {
            $doc = $method->documentation;
        }
        
        if ($how eq 'narrow') {
                $~ = 'METHOD_NARROW';
                write;
        }
        elsif ($how eq 'pod' and $delegate_to) {
                $~ = 'METHOD_POD_DELEGATED';
                write;
        }
        elsif ($how eq 'pod') {
                $~ = 'METHOD_POD';
                write;
        }
        else {
                $~ = 'METHOD';
                write;
        }
        

# ----- format specs ----- format METHODHEAD =

METHODS ------- Name delegates to on via =========================================================================================================================================================================== . format METHOD = @<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< @<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<... @<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<... @<<<<<<<<<<<<<<<<... $methodname, $delegate_to, $on, $via .

        format METHOD_NARROW =
@*
$methodname
    original pkg: @*
                  $original_pkg
    delegates to: @*
                  $delegate_to
              on: @*
                  $on
             via: @*
                  $via

.

        format METHODHEAD_POD = 

METHODS

.

        format METHOD_POD = 
        

@*() $methodname

       Defined in: @*
            $original_pkg

. format METHOD_POD_DELEGATED =

@*() $methodname

       Defined in: @*
                   $original_pkg
     Delegates to: @*()
                   $delegate_to
               On: @* 
                   $on
              Via: @*()
                   $via
              Doc: @*
                   $doc
          Same as: $self->@*->@*()
                     $via, $delegate_to

. format METHOD_POD_CLOSE =

. # ----- / format specs ----- }

sub _printattrs { my ($self, $how) = @_;

        if ($how eq 'narrow') {
                print <<HEAD;
ATTRIBUTES
----------
HEAD
        }
        elsif ($how eq 'wide') {
                $~ = 'ATTRHEAD';
                write;
        }
        elsif ($how eq 'pod') {
                $~ = 'ATTRHEAD_POD';
                write;
        }
        else {
                die "Don't know how to print attributes '$how'";
        }
        
        $self->_printattr($_, $how) for sort $self->meta->get_attribute_list;
        
        if ($how eq 'pod') {
                $~ = 'ATTR_POD_CLOSE';
                write;
        }
}

sub _printattr { my ($self, $attrname, $how) = @_; return if $attrname =~ /^_/; my $attr = $self->meta->get_attribute($attrname) or die "No attr for $attrname";

        my $is;
        $is = 'rw' if $attr->get_read_method && $attr->get_write_method;
        $is = 'ro' if $attr->get_read_method && ! $attr->get_write_method;
        $is = 'wo' if $attr->get_write_method && ! $attr->get_read_method;
        $is = '--' if ! $attr->get_write_method && ! $attr->get_read_method;
        $is or die "No \$is for $attrname";
        
        my $tc = $attr->type_constraint || '';
        my $from = $attr->associated_class->name || '';
        my $reqd = $attr->is_required ? 'yes' : 'no';
        my $lazy = $attr->is_lazy ? 'yes' : 'no';
        my $has_doc = $attr->has_documentation ? 'yes' : 'no'; # *_api attributes will never have doc, but other attributes might have
        my $doc = $attr->documentation || '';
        my $handles = join ', ', sort @{$attr->handles || []};
        $handles ||= '';
        
        if ($how eq 'narrow') {
                $~ = 'ATTR_NARROW';
        }
        elsif ($how eq 'pod') {
                $~ = 'ATTR_POD';
        }
        else {
                $~ = 'ATTR';
        }

        write;

# ----- format specs ----- format ATTRHEAD =

ATTRIBUTES ---------- Name is isa reqd lazy doc handles ============================================================================================================== . format ATTR = @<<<<<<<<<<<<<<<<< @< @<<<<<<<<<<<<<<<<<<<<<<<< @<<< @<<< @<< ^<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< $attrname, $is, $tc, $reqd, $lazy, $has_doc, $handles ^<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< ~~ $handles .

        format ATTR_NARROW = 
@*
$attrname
         is: @*
             $is
        isa: @*
             $tc
       reqd: @*
             $reqd
       lazy: @*
             $lazy
        doc: @*
             $doc
    handles: ^<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
             $handles
             ^<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< ~~
             $handles

. format ATTRHEAD_POD = =head1 ATTRIBUTES

. format ATTR_POD =

@* $attrname

         is: @*
             $is
        isa: @*
             $tc
       reqd: @*
             $reqd
       lazy: @*
             $lazy
        doc: @*
             $doc
    handles: ^<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
             $handles
             ^<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< ~~
             $handles

. format ATTR_POD_CLOSE =

. # ----- / format specs ----- }

1;