PMDAGETOPTIONS - Online Linux Manual PageSection : 3
Updated : PCP
Source : Performance Co-Pilot

NAMEpmdaGetOpt, pmdaGetOptions − get options from arguments, parsing generic PMDA options

C SYNOPSIS#include <pcp/pmapi.h>
#include <pcp/pmda.h> int pmdaGetOptions(int argc, char *const *argv, pmdaOptions *opts, pmdaInterface *dispatch); int pmdaGetOpt(int argc, char *const *argv, const char *optstring, pmdaInterface *dispatch, int *err); cc ... −lpcp_pmda −lpcp

DESCRIPTIONThese functions are wrappers for pmgetopt_r(3). The behavior of each function is that certain options are assumed to have a predefined behavior which initializes several fields in the pmdaInterface structure. The pmdaGetOptions interface allows both short and long options to be given, whereas pmdaGetOpt allows for short form options only. The options that both pmdaGetOptions and pmdaGetOpt will trap are: −Ddebugspec  Set the PMAPI(3) debugging options to debugspec, as described in PCPIntro(1). Used for controlling levels of trace output while debugging. −ddomain  Set the domain number of this agent. −hhelpfile  Obtain the help text (see pmdaText(3)) for the metrics from this file rather than from the path specified with pmdaDSO(3) or pmdaDaemon(3). −iport  Expect PMCD to connect on inet port (number or name). −6port  Expect PMCD to connect on ipv6 port (number or name). −llogfile  Redirect diagnostics and trace output to logfile. −p  Expect PMCD to supply stdin/stdout pipe. −usocket  Expect PMCD to connect on unix domain socket. The pmdaGetOptions interface will also capture the following options, and store them within the opts parameter: −Uusername  Set the user account name under which the PMDA should execute. Only one of −i, −6, −p and −u may be specified. If none of these three options is given, a pipe (−p) is assumed. When these options are encountered by pmdaGetOpt, the option is processed and the next option is examined. Therefore, pmdaGetOpt will only return when an option other than those listed above is found, or the end of the list is reached. The returned value will be the argument or EOF, respectively. A PMDA can control which of these options the program will accept with either the opts or optstring argument. To accept all the options, the PMDA should call pmdaGetOptions with the short_options field of the opts structure set to the PMDA_OPTIONS macro, or pmdaGetOpt with the option string "D:d:h:i:l:pu:". Any PMDA specific options should be added to these strings in the style of getopt(3), and will be returned by both pmdaGetOptions and pmdaGetOpt if encountered. When a command line option usage error is detected in the pmdaGetOptions interface, the error field of the opts structure will contain a non-zero error count. pmdaGetOpt takes a pointer to an int, err, which is used as an error count. This variable should be initialized to zero before pmdaGetOpt is first called, and tested when pmdaGetOpt returns EOF. Neither pmdaGetOptions nor pmdaGetOpt modify their argc or argv parameters. The global variables used by the system getopt(3) interface may also be used by the caller of pmdaGetOpt within the argument parsing loop. On the other hand, the pmdaGetOptions interface does not utilize global variables at all (neither reading nor modifying them). Instead, these variables can be access via the opts fields of the same name.

DIAGNOSTICSBoth pmdaGetOptions and pmdaGetOpt will display the same error messages as getopt.

CAVEATThe options −D, −d, −i, −l, −p and −u cannot be reused for other purposes by the PMDA, unless using the override method provided by the pmdaGetOptions interface, which operates in the same way as described for the pmGetOptions(3) interface used by PMAPI client tools. The PMDA must be using PMDA_INTERFACE_2 or later, as specified in the call to pmdaDSO(3) or pmdaDaemon(3).

SEE ALSOpmdbg(1), getopt(3), pmgetopt_r(3), pmGetOptions(3), PMAPI(3), PMDA(3), pmdaDaemon(3), pmdaDSO(3) and pmdaText(3).
0
Johanes Gumabo
Data Size   :   14,600 byte
man-p___mdaGetOpt.3Build   :   2024-12-05, 20:55   :  
Visitor Screen   :   x
Visitor Counter ( page / site )   :   3 / 173,821
Visitor ID   :     :  
Visitor IP   :   3.149.29.209   :  
Visitor Provider   :   AMAZON-02   :  
Provider Position ( lat x lon )   :   39.962500 x -83.006100   :   x
Provider Accuracy Radius ( km )   :   1000   :  
Provider City   :   Columbus   :  
Provider Province   :   Ohio ,   :   ,
Provider Country   :   United States   :  
Provider Continent   :   North America   :  
Visitor Recorder   :   Version   :  
Visitor Recorder   :   Library   :  
Online Linux Manual Page   :   Version   :   Online Linux Manual Page - Fedora.40 - march=x86-64 - mtune=generic - 24.12.05
Online Linux Manual Page   :   Library   :   lib_c - 24.10.03 - march=x86-64 - mtune=generic - Fedora.40
Online Linux Manual Page   :   Library   :   lib_m - 24.10.03 - march=x86-64 - mtune=generic - Fedora.40
Data Base   :   Version   :   Online Linux Manual Page Database - 24.04.13 - march=x86-64 - mtune=generic - fedora-38
Data Base   :   Library   :   lib_c - 23.02.07 - march=x86-64 - mtune=generic - fedora.36

Very long time ago, I have the best tutor, Wenzel Svojanovsky . If someone knows the email address of Wenzel Svojanovsky , please send an email to johanes_gumabo@yahoo.co.id .
If error, please print screen and send to johanes_gumabo@yahoo.co.id
Under development. Support me via PayPal.