$help

EOHELP }

sub get_example_help_for_method { my ($self, $method) = @_; my $example_pod = ''; my $example_count = 0; for my $example ($self->svc->get_examples_for_method($method)) { $example_count++; $example_pod .= "=item $method"; while (my ($name, $value) = each %$example) { $example_pod .= " --$name"; $example_pod .= " $value" if defined $value; } $example_pod .= "\n\n"; }

if (length $example_pod) {
    $example_pod = "=over 4\n\n$example_pod\n\n=back\n\n";
}

if ($example_count == 1) {
    $example_pod = "Example:\n\n$example_pod";
} elsif ($example_count > 1) {
    $example_pod = "Examples:\n\n$example_pod";
}
$example_pod;
}

sub pod_to_text { my ($self, $pod) = @_;

open my $pod_fh, '<', \$pod or
    die "can't open filehandle to scalar \$pod";
my $text = '';
open my $text_fh, '>', \$text or
    die "can't open filehandle to scalar \$text";
my $parser = Pod::Text->new;
$parser->parse_from_filehandle($pod_fh, $text_fh);
close $pod_fh or die "can't close filehandle to scalar \$pod";
close $text_fh or die "can't close filehandle to scalar \$text";

$text;
}

sub summary_for_service_method { my ($self, $method) = @_; $self->svc->get_summary_for_method($method); }

# don't call this just "help_for_service_method", or Term::Shell's # find_handler() will find it and assume that there's a command # "for_service_method".

sub get_help_for_service_method { my ($self, $method) = @_; my $description = $self->svc->get_description_for_method($method); my $param_help = $self->get_param_help_for_method($method); my $example_pod = $self->get_example_help_for_method($method); my $pod = <<EOPOD; =pod

$method

$description

$param_help

$example_pod

NAME

Data::Conveyor - stage-based conveyor-belt-like ticket handling system

SYNOPSIS

None yet (see below).

DESCRIPTION

None yet. This is an early release; fully functional, but undocumented. The next release will have more documentation.

TAGS

If you talk about this module in blogs, on del.icio.us or anywhere else, please use the dataconveyor tag.

BUGS AND LIMITATIONS

No bugs have been reported.

Please report any bugs or feature requests to bug-data-conveyor@rt.cpan.org, or through the web interface at http://rt.cpan.org.

INSTALLATION

See perlmodinstall for information and options on installing Perl modules.

AVAILABILITY

The latest version of this module is available from the Comprehensive Perl Archive Network (CPAN). Visit <http://www.perl.com/CPAN/> to find a CPAN site near you. Or see <http://www.perl.com/CPAN/authors/id/M/MA/MARCEL/>.

AUTHORS

Marcel Grünauer, <marcel@cpan.org>

Florian Helmberger <fh@univie.ac.at>

Achim Adam <ac@univie.ac.at>

Mark Hofstetter <mh@univie.ac.at>

Heinz Ekker <ek@univie.ac.at>

COPYRIGHT AND LICENSE

Copyright 2007 by Marcel Grünauer

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.