|  |  |  | libtinynotify-cli Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#include <tinynotify-cli.h> typedef NotifyCLIFlags; int notify_cli_flags_get_local (NotifyCLIFlags flags); int notify_cli_flags_get_systemwide (NotifyCLIFlags flags); int notify_cli_flags_get_foreground (NotifyCLIFlags flags); int notify_cli_flags_get_background (NotifyCLIFlags flags); int notify_cli_flags_get_timeout (NotifyCLIFlags flags); Notification notification_new_from_cmdline (int argc,char *argv[],const char *version_str,NotifyCLIFlags *flags);
The libtinynotify-cli helper library provides the routines for simple
command-line argument parsing (using getopt()) and turning those into
a Notification instance.
To use it, simply add the necessary include to your code, and replace
the notification_new() function with our notification_new_from_cmdline().
The other functions work as usual, and the resulting Notification is freed
with notification_free(), as usual.
Although libtinynotify-cli links with the actual libtinynotify itself, and uses its header, one should refer to the libtinynotify pkg-config package explicitly and include its header anyway.
typedef struct _notify_cli_flags* NotifyCLIFlags;
A type describing a set of additional notification flags as returned
by notification_new_from_cmdline().
int                 notify_cli_flags_get_local          (NotifyCLIFlags flags);
Check whether a local notification was requested.
| 
 | flags returned by notification_new_from_cmdline() | 
| Returns : | a non-zero value if local notification was explicitly requested, zero otherwise. | 
int                 notify_cli_flags_get_systemwide     (NotifyCLIFlags flags);
Check whether a system-wide notification was requested.
| 
 | flags returned by notification_new_from_cmdline() | 
| Returns : | a non-zero value if system-wide notification was explicitly requested, zero otherwise. | 
int                 notify_cli_flags_get_foreground     (NotifyCLIFlags flags);
Check whether running in the foreground (waiting for notification to be closed) was requested.
| 
 | flags returned by notification_new_from_cmdline() | 
| Returns : | a non-zero value if running in the foreground was explicitly requested, zero otherwise. | 
int                 notify_cli_flags_get_background     (NotifyCLIFlags flags);
Check whether running in the background (waiting for notification to be closed) is necessary. This may be a case when actions are used, and running in foreground was not requested.
| 
 | flags returned by notification_new_from_cmdline() | 
| Returns : | a non-zero value if running in the background is necessary, zero otherwise. | 
int                 notify_cli_flags_get_timeout        (NotifyCLIFlags flags);
Get the expected timeout for program run.
| 
 | flags returned by notification_new_from_cmdline() | 
| Returns : | the timeout, in milliseconds | 
Notification notification_new_from_cmdline (int argc,char *argv[],const char *version_str,NotifyCLIFlags *flags);
Parse the command-line options and create a new Notification instance from them (with unformatted summary & body).
This function does handle complete command-line parsing for the application,
including handling invalid args, --help and --version. It should be called
ASAP, and if it returns NULL, the application should terminate immediately
and quietly (it will handle the necessary output itself).
The pointer at location pointed by flags argument will be set to point
to an internal buffer holding flag string. That string will contain
single-letter codes for any additional flags requested by user.
| 
 | command-line argument count | 
| 
 | command-line argument values | 
| 
 | string to output on --version | 
| 
 | location to store additional flags | 
| Returns : | a newly-allocated Notification instance, or NULLif application
should terminate (invalid args, --help, --version) |