PLplot
5.15.0
|
Go to the source code of this file.
Classes | |
struct | PLOptionInfo |
struct | DrvOptCmd |
Macros | |
#define | OPTMAX 1024 |
#define | PL_MAX_OPT_TABLES 10 |
Typedefs | |
typedef struct DrvOptCmd | DrvOptCmd |
Variables | |
static PLCHAR_VECTOR | program = NULL |
static PLCHAR_VECTOR | usage = NULL |
static int | mode_full |
static int | mode_quiet |
static int | mode_nodelete |
static int | mode_showall |
static int | mode_noprogram |
static int | mode_nodash |
static int | mode_skip |
static char | opttmp [OPTMAX] |
static PLOptionTable | ploption_table [] |
static PLCHAR_VECTOR | plplot_notes [] |
PLOptionInfo | ploption_info_default |
PLOptionInfo | ploption_info [PL_MAX_OPT_TABLES] |
static DrvOptCmd | drv_opt = { NULL, NULL, NULL } |
static int | tables = 1 |
This file contains routines to extract & process command flags. The command flags recognized by PLplot are stored in the "ploption_table" structure, along with strings giving the syntax, long help message, and option handler.
The command line parser – plparseopts() – removes all recognized flags (decreasing argc accordingly), so that invalid input may be readily detected. It can also be used to process user command line flags. The user can merge an option table of type PLOptionTable into the internal option table info structure using plMergeOpts(). Or, the user can specify that ONLY the external table(s) be parsed by calling plClearOpts() before plMergeOpts().
The default action taken by plparseopts() is as follows:
These behaviors may be controlled through the "mode" argument, which can have the following bits set:
PL_PARSE_FULL – Full parsing of command line and all error messages enabled, including program exit when an error occurs. Anything on the command line that isn't recognized as a valid option or option argument is flagged as an error.
PL_PARSE_QUIET – Turns off all output except in the case of errors.
PL_PARSE_NODELETE – Turns off deletion of processed arguments.
PL_PARSE_SHOWALL – Show invisible options
PL_PARSE_NOPROGRAM – Specified if argv[0] is NOT a pointer to the program name.
PL_PARSE_NODASH – Set if leading dash is NOT required.
PL_PARSE_SKIP – Set to quietly skip over any unrecognized args.
Note: if you want to have both your option and a PLplot option of the same name processed (e.g. the -v option in plrender), do the following:
See plrender.c for examples of actual usage.
Definition in file plargs.c.
Process options list using current ploptions_info structure. An error in parsing the argument list causes a program exit if mode_full is set, otherwise the function returns with an error.
p_argc | pointer to a value that ONLY keeps track of number of arguments after processing. |
argv | ? |
mode | ? |
PLINT c_plsetopt | ( | PLCHAR_VECTOR | opt, |
PLCHAR_VECTOR | opt_arg | ||
) |
|
static |
|
static |
|
static |
Performs appropriate action for option "a": Sets plot aspect ratio on page
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot aspect ratio. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "auto_path": Sets additional directories to autoload
PL_UNUSED( | opt ) Not used. |
opt_arg | Additional directories to add the the load path (?). |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "bg": Sets background color (rgb represented in hex on command line) and alpha (represented as floating point on the command line with underscore delimiter), e.g., -bg ff0000 (set background to red with an alpha value of MAX_PLFLT_ALPHA ==> opaque) -bg ff0000_0.1 (set background to red with an alpha value of 0.1)
PL_UNUSED( | opt ) Not used. |
opt_arg | Background RGB color in hex (in 3-digit of 6-digit format) followed by optional combination of "_" + floating-point alpha value. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "bufmax": Sets size of data buffer for tk driver
PL_UNUSED( | opt ) Not used. |
opt_arg | Size of the data buffer for the tk driver. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Sets color table 0 based on a cmap0.pal file.
PL_UNUSED( | opt ) Not used. |
opt_arg | Name of color map 0 .pal file. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Sets color table 1 based on a cmap1.pal file.
PL_UNUSED( | opt ) Not used. |
opt_arg | Name of a color map 1 .pal file. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "db": Double buffer X output (update only done on eop or Expose)
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "debug": Turn on debugging flag
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "dev": Sets output device keyword
PL_UNUSED( | opt ) Not used. |
opt_arg | The name of the output device. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Sets device compression
PL_UNUSED( | opt ) Not used. |
opt_arg | Device compression (?). |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "dpi": Set dpi resolution for output device e.g., "-dpi 600x300", will set X dpi to 600 and Y dpi to 300 or e.g., "-dpi 1200" Will set both X and Y dpi to 1200 dpi
PL_UNUSED( | opt ) Not used. |
opt_arg | DPI descriptor string. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Get driver specific options in the form <option[=value]>[,option[=value]]* If "value" is not specified, it defaults to "1".
PL_UNUSED( | opt ) Not used. |
opt_arg | The driver specific option. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
For the case where the boundary of the filled region is self-intersecting, use the even-odd fill rule rather than the default nonzero fill rule.
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "fam": Enables family output files
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "fbeg": Starts with the specified family member number.
PL_UNUSED( | opt ) Not used. |
opt_arg | Number of the first plot. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "fflen": Specify minimum field length for family member number.
PL_UNUSED( | opt ) Not used. |
opt_arg | Size of the family number field (e.g. "1", "01", "001" ?) |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "finc": Specify increment between family members.
PL_UNUSED( | opt ) Not used. |
opt_arg | Amount to increment the plot number between plots. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "freeaspect": Allow aspect ratio to adjust to orientation swaps.
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "fsiz": Sets size of a family member file (may be somewhat larger since eof must occur at a page break). Also turns on familying. Example usage:
-fsiz 5M (5 MB) -fsiz 300K (300 KB) -fsiz .3M (same) -fsiz .5G (half a GB)
Note case of the trailing suffix doesn't matter. If no suffix, defaults to MB.
PL_UNUSED( | opt ) Not used. |
opt_arg | Family size setting. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "geo": Set geometry for output window, i.e., "-geometry WIDTHxHEIGHT+XOFF+YOFF" where WIDTHxHEIGHT, +XOFF+YOFF, or both must be present, and +XOFF+YOFF stands for one of the four combinations +XOFF+YOFF, +XOFF-YOFF, -XOFF+YOFF, and -XOFF-YOFF. Some examples are the following: -geometry 400x300, -geometry -100+200, and -geometry 400x300-100+200.
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot geometry descriptor. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "h": Issues help message
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 2.
|
static |
|
static |
Performs appropriate action for option "hack": Enables driver-specific hack(s)
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "jx": Sets relative justification in x
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot relative justification in x(?) |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "jy": Sets relative justification in y
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot relative justification in y(?) |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Make PLplot portable to all LC_NUMERIC locales.
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "mar": Sets relative margin width
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot margin width. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Sets the filename of the PLplot metafile that will be read.
PL_UNUSED( | opt ) Not used. |
opt_arg | Input PLplot metafile. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Sets the filename of the PLplot metafile that will be written.
PL_UNUSED( | opt ) Not used. |
opt_arg | Output PLplot metafile. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "ncol0": Sets number of colors to allocate in cmap 0 (upper bound).
PL_UNUSED( | opt ) Not used. |
opt_arg | Number of color map 0 colors. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "ncol1": Sets number of colors to allocate in cmap 1 (upper bound).
PL_UNUSED( | opt ) Not used. |
opt_arg | Number of color map 1 colors. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "nopixmap": Disables use of pixmaps in X drivers
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "np": Disables pause between pages
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "o": Sets output file name
PL_UNUSED( | opt ) Not used. |
opt_arg | The file family name. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "ori": Sets orientation
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot orientation. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "plserver": Sets name to use when invoking server (Tcl/TK driver only)
PL_UNUSED( | opt ) Not used. |
opt_arg | Name of Tcl/TK server (?). |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "plwindow": Sets PLplot window name
PL_UNUSED( | opt ) Not used. |
opt_arg | Name of the window. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "portrait": Set portrait mode. If plsc->portrait = 1, then the orientation for certain drivers is changed by 90 deg to portrait orientation from the default landscape orientation used by PLplot while the aspect ratio allowed to adjust using freeaspect. N.B. the driver list where this flag is honored is currently limited to psc, ps, and pstex. A 90 deg rotation is just not appropriate for certain other drivers. These drivers where portrait mode is ignored include display drivers (e.g., xwin, tk), drivers which are subequently going to be transformed to another form (e.g., meta), or drivers which are normally used for web publishing (e.g., png, jpeg). That said, the case is not entirely clear for all drivers so the list of drivers where portrait mode is honored may increase in the future. To add to the list simply copy the small bit of code from ps.c that has to do with pls->portrait to the appropriate driver file.
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "px": Set packing in x
PL_UNUSED( | opt ) Not used. |
opt_arg | X packing (?). |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "py": Set packing in y
PL_UNUSED( | opt ) Not used. |
opt_arg | Y packing (?). |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "server_name": Sets main window name of server (Tcl/TK driver only)
PL_UNUSED( | opt ) Not used. |
opt_arg | The name of the main window. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
File name for plserver tk_file option
PL_UNUSED( | opt ) Not used. |
opt_arg | Tk file name. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "v": Issues version message
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 2.
|
static |
|
static |
Performs appropriate action for option "verbose": Turn on verbosity flag
PL_UNUSED( | opt ) Not used. |
PL_UNUSED( | opt_arg ) Not used. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "width": Sets pen width
PL_UNUSED( | opt ) Not used. |
opt_arg | Plot pen width. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
|
static |
Performs appropriate action for option "wplt": Sets (zoom) window into plot (e.g. "0,0,0.5,0.5")
PL_UNUSED( | opt ) Not used. |
opt_arg | Zoom setting. |
PL_UNUSED( | client_data ) Not used. |
returns 0.
|
static |
void plClearOpts | ( | void | ) |
void plHelpDrvOpts | ( | DrvOpt * | acc_opt | ) |
PLINT plMergeOpts | ( | PLOptionTable * | options, |
PLCHAR_VECTOR | name, | ||
PLCHAR_VECTOR * | notes | ||
) |
void plP_FreeDrvOpts | ( | void | ) |
int plParseDrvOpts | ( | DrvOpt * | acc_opt | ) |
void plResetOpts | ( | void | ) |
void plSetUsage | ( | PLCHAR_VECTOR | program_string, |
PLCHAR_VECTOR | usage_string | ||
) |
|
static |
|
static |
PLOptionInfo ploption_info[PL_MAX_OPT_TABLES] |
PLOptionInfo ploption_info_default |
|
static |
PLPLOT options data structure definition.
The table is defined as follows
typedef struct { PLCHAR_VECTOR opt; int (*handler) (PLCHAR_VECTOR, PLCHAR_VECTOR, void *); void *client_data; void *var; long mode; PLCHAR_VECTOR syntax; PLCHAR_VECTOR desc; } PLOptionTable;
where each entry has the following meaning:
opt option string handler pointer to function for processing the option and (optionally) its argument client_data pointer to data that gets passed to (*handler) var address of variable to set based on "mode" mode governs handling of option (see below) syntax short syntax description desc long syntax description
The syntax and or desc strings can be NULL if the option is never to be described. Usually this is only used for obsolete arguments; those we just wish to hide from normal use are better made invisible (which are made visible by either specifying -showall first or PL_PARSE_SHOWALL).
The mode bits are:
PL_OPT_ARG Option has an argument PL_OPT_NODELETE Don't delete after processing PL_OPT_INVISIBLE Make invisible (usually for debugging) PL_OPT_DISABLED Ignore this option
The following mode bits cause the option to be processed as specified:
PL_OPT_FUNC Call function handler (opt, opt_arg) PL_OPT_BOOL Set *var=1 PL_OPT_INT Set *var=atoi(opt_arg) PL_OPT_FLOAT Set *var=atof(opt_arg) PL_OPT_STRING Set *var=opt_arg
where opt points to the option string and opt_arg points to the argument string.
|
static |
|
static |
|
static |