diff options
-rw-r--r-- | usr.sbin/pkg_add/Makefile | 3 | ||||
-rw-r--r-- | usr.sbin/pkg_add/pod/OpenBSD::State.pod | 117 |
2 files changed, 119 insertions, 1 deletions
diff --git a/usr.sbin/pkg_add/Makefile b/usr.sbin/pkg_add/Makefile index 284e3d43da4..4577ae74c56 100644 --- a/usr.sbin/pkg_add/Makefile +++ b/usr.sbin/pkg_add/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.66 2010/06/15 08:26:39 espie Exp $ +# $OpenBSD: Makefile,v 1.67 2010/06/25 12:03:54 espie Exp $ .include <bsd.own.mk> @@ -98,6 +98,7 @@ PODS= \ OpenBSD::PkgSpec \ OpenBSD::RequiredBy \ OpenBSD::Search \ + OpenBSD::State \ OpenBSD::Ustar \ OpenBSD::Vstat diff --git a/usr.sbin/pkg_add/pod/OpenBSD::State.pod b/usr.sbin/pkg_add/pod/OpenBSD::State.pod new file mode 100644 index 00000000000..f589b5a8d94 --- /dev/null +++ b/usr.sbin/pkg_add/pod/OpenBSD::State.pod @@ -0,0 +1,117 @@ +$OpenBSD: OpenBSD::State.pod,v 1.1 2010/06/25 12:03:54 espie Exp $ + +=head1 NAME + +OpenBSD::State - user interface framework + +=head1 SYNOPSIS + + package MyCmd::State; + use OpenBSD::State; + our @ISA = qw(OpenBSD::State); + + ... + package myCmd; + + my $state = MyCmd::State->new("cmd"); + $state->handle_options('abc', '[-abc]'); + + ... + $state->say("I'm sorry #1, I'm afraid I can't do that", $user); + +=head1 DESCRIPTION + +C<OpenBSD::State> is the base class responsible for handling all user +interface needs of C<pkg_*(1)> commands. + +As such, it contains internal state elements relevant to the working of +various commands. It should be used for option handling, usage printing, +asking questions, or printing out values. + +C<OpenBSD::State> is designed for inheritance. + +It provides default behavior for options -v and -D value. + +Subclass C<OpenBSD::State::AddCreateDelete> adds progressmeter behavior, along +with options -m, -n and -x. + +Some methods can be used and overriden safely. + +=over 4 + +=item $class->new($cmdname, @params) + +create a new state object of the desired class. +C<$cmdname> is mandatory to options usage printing. +C<@params> are passed unchanged to C<init>. +Don't override, override C<init> instead. + +=item $state->init(@params); + +initialize C<$state> based on C<@params>. +Meant to be overridden. Always call C<$state-E<gt>SUPER::init(@params)> at end. + +=item $state->handle_options($opt_string, @usage); + +handle options to relevant to this command. Takes a C<OpenBSD::Getopt> +C<$opt_string>, and a set of C<@usage> lines that will be printed if +necessary. + +Option results are stored in the C<$state-E<gt>{opt}> hash. This can +be primed according to C<OpenBSD::Getopt> documentation for options that +require code. + +Unless C<$state-E<gt>{no_exports}> is set, options will also be exported to +calling package, for legacy commands that still use C<our ($opt_x)> constructs. + +In case of an error, usage will call C<die>. + +Meant to be overriden. A subclass C<handle_options> will normally do +all option parsing and stuff the results in the C<$state> object. + +=item $state->usage($extra, @args) + +print out usage line, as set in C<handle_options>, along with possible +extra hints, following C<errprint> conventions. + +=item $state->print($msg, @args); + +display a formatted message for the user. +Any C<#n> substring will be replaced by the nth argument from C<@args>. +Numbering starts at 1, C<#0> can be used to display an actual C<#>. + +All messages displayed by C<OpenBSD::State> using commands should use +this framework, so that messages can be translated (eventually). + +Do not print directly to C<STDOUT> as this might garble the display +(especially with a progressmeter). + +=item $state->errprint($msg, @args); + +like C<print>, but on C<STDERR>. + +=item $state->say($msg, @args); + +like C<print>, with a line feed. + +=item $state->errsay($msg, @args); + +like C<errprint>, with a line feed. + +=item $state->fatal($msg, @args); + +use the same conventions as C<errsay>, but call C<die> with the resulting +string. + +=item $state->f($msg, @args); + +basic formatting function used by C<print> and friends, return the formatted +string. + +=back + +=head1 BUGS + +User interface needs are not fully fleshed out and C<OpenBSD::State> is +a work-in-progress. What's described here should hopefully no longer +change too much. |