1 package # hide from PAUSE
2 DBIx::Class::Admin::Usage;
5 use base 'Getopt::Long::Descriptive::Usage';
7 use base 'Class::Accessor::Grouped';
11 __PACKAGE__->mk_group_accessors('simple', 'synopsis', 'short_description');
14 Getopt::Long::Descriptive::prog_name();
18 my ($self,$field, $value) = @_;
19 my $prog_name = prog_name();
20 $value =~ s/%c/$prog_name/g;
21 $self->next::method($field, $value);
26 # This returns the usage formated as a pod document
29 return join qq{\n}, $self->pod_leader_text, $self->pod_option_text, $self->pod_authorlic_text;
35 return qq{=head1 NAME\n\n}.prog_name()." - ".$self->short_description().qq{\n\n}.
36 qq{=head1 SYNOPSIS\n\n}.$self->leader_text().qq{\n}.$self->synopsis().qq{\n\n};
40 sub pod_authorlic_text {
44 'See L<DBIx::Class/CONTRIBUTORS>',
46 'You may distribute this code under the same terms as Perl itself',
54 my @options = @{ $self->{options} || [] };
56 return $string unless @options;
58 $string .= "=head1 OPTIONS\n\n=over\n\n";
60 foreach my $opt (@options) {
61 my $spec = $opt->{spec};
62 my $desc = $opt->{desc};
63 next if ($desc eq 'hidden');
64 if ($desc eq 'spacer') {
65 $string .= "=back\n\n=head2 $spec\n\n=cut\n\n=over\n\n";
69 $spec = Getopt::Long::Descriptive->_strip_assignment($spec);
70 $string .= "=item " . join " or ", map { length > 1 ? "B<--$_>" : "B<-$_>" }
72 $string .= "\n\n$desc\n\n=cut\n\n";
75 $string .= "=back\n\n";