Provided by: libcommandable-perl_0.11-1_all bug

NAME

       "Commandable::Output" - abstractions for printing output from commands

DESCRIPTION

       This package contains default implementations of methods for providing printed output from commands
       implemented using Commandable. These methods are provided for the convenience of user code, and are also
       used by built-in commands provided by the "Commandable" system itself.

       Implementations are permitted (encouraged, even) to replace any of these methods in order to customise
       their behaviour.

   WITH "String::Tagged"
       If String::Tagged and Convert::Color are available, this module applies formatting to strings by using
       the String::Tagged::Formatting conventions.  The "format_heading" and "format_note" methods will return
       results as instances of "String::Tagged", suitable to pass into the main "printf" method.

METHODS

   printf
          Commandable::Output->printf( $format, @args )

       The main output method, used to send messages for display to the user. The arguments are formatted into a
       single string by Perl's "printf" function.  This method does not append a linefeed. To output a complete
       line of text, remember to include the "\n" at the end of the format string.

       The default implementation writes output on the terminal via STDOUT.

       In cases where the output should be sent to some other place (perhaps a GUI display widget of some kind),
       the application should replace this method with something that writes the display to somewhere more
       appropriate. Don't forget to use "sprintf" to format the arguments into a string.

          no warnings 'redefine';
          sub Commandable::Output::printf
          {
             shift; # the package name
             my ( $format, @args ) = @_;

             my $str = sprintf $format, @args;

             $gui_display_widget->append_text( $str );
          }

       If String::Tagged::Terminal is available, the output will be printed using this module, by first
       converting the format string and arguments using "from_sprintf" in String::Tagged and then constructing a
       terminal string using "new_from_formatting" in String::Tagged::Terminal. This means the default
       implementation will be able to output formatted strings using the String::Tagged::Formatting conventions.

   print_heading
          Commandable::Output->print_heading( $text, $level )

       Used to send output that should be considered like a section heading.  $level may be an integer used to
       express sub-levels; increasing values from 1 upwards indicate increasing sub-levels.

       The default implementation formats the text string using "format_heading" then prints it using "printf"
       with a trailing linefeed.

   format_heading
          $str = Commandable::Output->format_heading( $text, $level )

       Returns a value for printing, to represent a section heading for the given text and level.

       The default implementation applies the following formatting if "String::Tagged" is available:

       Level 1
           Underlined

       Level 2
           Underlined, cyan colour

       Level 3
           Bold

   format_note
          $str = Commandable::Output->format_note( $text, $level )

       Returns a value for printing, to somehow highlight the given text (which should be a short word or
       string) at the given level.

       The default implementation applies the following formatting if "String::Tagged" is available:

       Level 0
           Bold, yellow colour

       Level 1
           Bold, cyan colour

       Level 2
           Bold, magenta colour

AUTHOR

       Paul Evans <leonerd@leonerd.org.uk>