OpenMPI  0.1.1
show_help.h File Reference

The "show help" subsystem (SHS) in Open MPI is intended to help the developer convey meaningful information to the user (read longer than is convenient in a single printf), particularly when errors occur. More...

#include "opal_config.h"
#include <stdarg.h>

Go to the source code of this file.

Typedefs

typedef int(* opal_show_help_fn_t )(const char *filename, const char *topic, bool want_error_header,...)
 Look up a text message in a text file and display it to the stderr using printf()-like substitutions (d, s, etc.). More...
 
typedef int(* opal_show_vhelp_fn_t )(const char *filename, const char *topic, bool want_error_header, va_list ap)
 This function does the same thing as opal_show_help(), but accepts a va_list form of varargs.
 

Functions

BEGIN_C_DECLS OPAL_DECLSPEC int opal_show_help_init (void)
 
OPAL_DECLSPEC int opal_show_help_finalize (void)
 
OPAL_DECLSPEC char * opal_show_help_string (const char *filename, const char *topic, bool want_error_header,...)
 This function does the same thing as opal_show_help(), but returns its output in a string (that must be freed by the caller).
 
OPAL_DECLSPEC char * opal_show_help_vstring (const char *filename, const char *topic, bool want_error_header, va_list ap)
 This function does the same thing as opal_show_help_string(), but accepts a va_list form of varargs.
 
OPAL_DECLSPEC int opal_show_help_add_dir (const char *directory)
 This function adds another search location for the files that back show_help messages. More...
 
OPAL_DECLSPEC int opal_show_help_finish_parsing (void)
 

Variables

OPAL_DECLSPEC opal_show_help_fn_t opal_show_help
 
OPAL_DECLSPEC opal_show_vhelp_fn_t opal_show_vhelp
 

Detailed Description

The "show help" subsystem (SHS) in Open MPI is intended to help the developer convey meaningful information to the user (read longer than is convenient in a single printf), particularly when errors occur.

The SHS allows the storage of arbitrary-length help messages in text files which can be parameterized by text filename, message name, POSIX locale, and printf()-style parameters (e.g., "%s", "%d", etc.). Note that the primary purpose of the SHS is to display help messages, but it can actually be used to display any arbitrary text messages.

The function opal_show_help() is used to find a help message and display it. Its important parameters are a filename, message name, and printf()-style varargs parameters used to substitute into the message.

It was originally intended that this system would support a very simple version of i18n-like support, but we got (strong) feedback that i18n support was not desired. So it never happened.

As such, the file lookup is quite straightforward – the caller passes in the filename to find the help message, and the SHS looks for that file in $pkgdatadir (typically $prefix/share/openmpi).

Once the file is successfully opened, the SHS looks for the appropriate help message to display. It looks for the message name in the file, reads in the message, and displays it. printf()-like substitutions are performed (e.g., d, s, etc.) – opal_show_help() takes a variable legnth argument list that are used for these substitutions.

The format of the help file is simplistic:

  • Comments begin with #. Any characters after a # on a line are ignored. It is not possible to escape a #.
  • Message names are on a line by themselves and marked with []. Names can be any ASCII string within the [] (excluding the characters newline, linefeed, [, ], and #).
  • Messages are any characters between message names and/or the end of the file.

Here's a sample helpfile:

This is a comment.

[topic 1] Here's the first message. Let's substitute in an integer: d. The quick brown fox jumped over the lazy s.

This is another comment – it's not displayed in the first message.

[another:topic:foo:foo:foo] This is the second message. Let's just keep rolling along to get to the second line in the message for this example.

It is expected that help messages will be grouped by filename; similar messages should be in a single file. For example, an MCA component may install its own helpfile in Open MPI's $pkgdatadir, and therefore the component can invoke opal_show_help() to display its own help messages.

Message files in $pkgdatadir have a naming convention: they generally start with the prefix "help-" and are followed by a name descriptive of what kind of messages they contain. MCA components should generally abide by the MCA prefix rule, with the exception that they should start the filename with "help-", as mentioned previously.

Typedef Documentation

typedef int(* opal_show_help_fn_t)(const char *filename, const char *topic, bool want_error_header,...)

Look up a text message in a text file and display it to the stderr using printf()-like substitutions (d, s, etc.).

Parameters
filenameFile where the text messages are contained.
topicString index of which message to display from the text file.
want_error_headerDisplay error-bar line header and footer with the message.
varargsAny additional parameters are substituted, printf()-style into the help message that is displayed.

This function looks for the filename in the $pkgdatadir (typically $prefix/share/openmpi), and looks up the message based on the topic, and displays it. If want_error_header is true, a header and footer of asterisks are also displayed.

Function Documentation

OPAL_DECLSPEC int opal_show_help_add_dir ( const char *  directory)

This function adds another search location for the files that back show_help messages.

Locations will be searched starting with the prefix installation directory, then cycled through any additional directories in the order they were added

This interface allows libraries that use OMPI to take advantage of the show_help functionality. OMPI defines the show_help directory based on where OMPI was installed. However, if the library wants to use show_help to provide error output specific to itself, then it nees to tell show_help how to find its own show_help files - without interfering with the linked ORTE libs when they need to do show_help.

References opal_argv_append_nosize().