getsubopt(3)


NAME

   getsubopt - parse suboption arguments from a string

SYNOPSIS

   #include <stdlib.h>

   int getsubopt(char **optionp, char * const *tokens, char **valuep);

   Feature Test Macro Requirements for glibc (see feature_test_macros(7)):

   getsubopt():
       _XOPEN_SOURCE >= 500
           || /* Since glibc 2.12: */ _POSIX_C_SOURCE >= 200809L

DESCRIPTION

   getsubopt()  parses  the list of comma-separated suboptions provided in
   optionp.  (Such a suboption list is typically produced  when  getopt(3)
   is  used  to  parse  a  command  line; see for example the -o option of
   mount(8).)  Each suboption may include an associated  value,  which  is
   separated  from  the suboption name by an equal sign.  The following is
   an example of the kind of string that might be passed in optionp:

       ro,name=xyz

   The tokens argument is a pointer to a NULL-terminated array of pointers
   to  the  tokens  that getsubopt() will look for in optionp.  The tokens
   should be distinct, null-terminated strings  containing  at  least  one
   character, with no embedded equal signs or commas.

   Each call to getsubopt() returns information about the next unprocessed
   suboption in optionp.  The first equal sign in a suboption (if any)  is
   interpreted  as  a  separator  between  the  name and the value of that
   suboption.  The value extends to the  next  comma,  or  (for  the  last
   suboption)  to  the  end  of  the string.  If the name of the suboption
   matches a known name  from  tokens,  and  a  value  string  was  found,
   getsubopt()  sets  *valuep  to  the  address of that string.  The first
   comma in optionp is  overwritten  with  a  null  byte,  so  *valuep  is
   precisely the "value string" for that suboption.

   If  the suboption is recognized, but no value string was found, *valuep
   is set to NULL.

   When getsubopt() returns, optionp points to the next suboption,  or  to
   the null byte ('\0') at the end of the string if the last suboption was
   just processed.

RETURN VALUE

   If the first suboption in optionp is  recognized,  getsubopt()  returns
   the  index  of the matching suboption element in tokens.  Otherwise, -1
   is returned and *valuep is the entire name[=value] string.

   Since *optionp is changed, the  first  suboption  before  the  call  to
   getsubopt()  is not (necessarily) the same as the first suboption after
   getsubopt().

ATTRIBUTES

   For  an  explanation  of  the  terms  used   in   this   section,   see
   attributes(7).

   
   Interface    Attribute      Value   
   
   getsubopt()  Thread safety  MT-Safe 
   

CONFORMING TO

   POSIX.1-2001, POSIX.1-2008.

NOTES

   Since  getsubopt()  overwrites  any  commas  it  finds  in  the  string
   *optionp, that string must be writable; it cannot be a string constant.

EXAMPLE

   The following program expects suboptions following a "-o" option.

   #define _XOPEN_SOURCE 500
   #include <stdlib.h>
   #include <assert.h>
   #include <stdio.h>

   int
   main(int argc, char **argv)
   {
       enum {
           RO_OPT = 0,
           RW_OPT,
           NAME_OPT
       };
       char *const token[] = {
           [RO_OPT]   = "ro",
           [RW_OPT]   = "rw",
           [NAME_OPT] = "name",
           NULL
       };
       char *subopts;
       char *value;
       int opt;

       int readonly = 0;
       int readwrite = 0;
       char *name = NULL;
       int errfnd = 0;

       while ((opt = getopt(argc, argv, "o:")) != -1) {
           switch (opt) {
           case 'o':
               subopts = optarg;
               while (*subopts != '\0' && !errfnd) {

               switch (getsubopt(&subopts, token, &value)) {
               case RO_OPT:
                   readonly = 1;
                   break;

               case RW_OPT:
                   readwrite = 1;
                   break;

               case NAME_OPT:
                   if (value == NULL) {
                       fprintf(stderr, "Missing value for "
                               "suboption '%s'\n", token[NAME_OPT]);
                       errfnd = 1;
                       continue;
                   }

                   name = value;
                   break;

               default:
                   fprintf(stderr, "No match found "
                           "for token: /%s/\n", value);
                   errfnd = 1;
                   break;
               }
           }
           if (readwrite && readonly) {
               fprintf(stderr, "Only one of '%s' and '%s' can be "
                       "specified\n", token[RO_OPT], token[RW_OPT]);
               errfnd = 1;
           }
           break;

           default:
               errfnd = 1;
           }
       }

       if (errfnd || argc == 1) {
           fprintf(stderr, "\nUsage: %s -o <suboptstring>\n", argv[0]);
           fprintf(stderr, "suboptions are 'ro', 'rw', "
                   "and 'name=<value>'\n");
           exit(EXIT_FAILURE);
       }

       /* Remainder of program... */

       exit(EXIT_SUCCESS);
   }

SEE ALSO

   getopt(3)

COLOPHON

   This page is part of release 4.09 of the Linux  man-pages  project.   A
   description  of  the project, information about reporting bugs, and the
   latest    version    of    this    page,    can     be     found     at
   https://www.kernel.org/doc/man-pages/.


More Linux Commands

manpages/Tcl_FSPathSeparator.3.html
Tcl_FSPathSeparator(3) - procedures to interact with any fil
There are several reasons for calling the Tcl_FS API functions (e.g. Tcl_FSAccess and Tcl_FSStat) rather than calling system level functions like access and sta

manpages/hosts_access.3.html
hosts_access(3) - access control library - Linux man page...
The routines described in this document are part of the libwrap.a library. They implement a rule-based access control language with optional shell commands that

manpages/snmp_parse_oid.3.html
snmp_parse_oid(3) - netsnmp_mib_api functions (Man Page)....
The functions dealing with MIB modules fall into four groups - those dealing with initialisation and shutdown, with reading in and parsing MIB files, with searc

manpages/getdtablesize.3.html
getdtablesize(3) get descriptor table size - Linux man page
getdtablesize() returns the maximum number of files a process can have open, one more than the largest possible value for a file descriptor. RETURN VALUE The cu

manpages/err.3.html
err(3) - formatted error messages - Linux manual page.......
The err() and warn() family of functions display a formatted error message on the standard error output. In all cases, the last component of the program name, a

manpages/mallinfo.3.html
mallinfo(3) obtain memory allocation information (Man Page)
The mallinfo() function returns a copy of a structure containing information about memory allocations performed by malloc(3) and related functions. This structu

manpages/scr_init_sp.3ncurses.html
scr_init_sp(3ncurses) - curses screen-pointer extension.....
This implementation can be configured to provide a set of functions which improve the ability to manage multiple screens. This feature can be added to any of th

manpages/git-tar-tree.1.html
git-tar-tree(1) - Create a tar archive of the files in the n
THIS COMMAND IS DEPRECATED. Use git archive with --format=tar option instead (and move the &lt;base&gt; argument to --prefix=base/). Creates a tar archive containing

manpages/XmbufGetWindowAttributes.3.html
XmbufGetWindowAttributes(3) - X multibuffering functions....
The application programming library for the X11 Double-Buffering, Multi-Buffering, and Stereo Extension contains the interfaces described below. With the except

manpages/systemd.exec.5.html
systemd.exec(5) - systemd execution environment configuratio
Unit configuration files for services, sockets, mount points, and swap devices share a subset of configuration options which define the execution environment of

manpages/subscriptions.5.html
subscriptions(5) - Default recommended subscriptions........
The pathetc/subscriptions file contains a list of newsgroups that is returned by the NNTP command LIST SUBSCRIPTIONS . Clients that support this command usually

manpages/XML::XPath::PerlSAX.3pm.html
XML::XPath::PerlSAX(3pm) - A PerlSAX event generator for my
This module generates PerlSAX events to pass to a PerlSAX handler such as XML::DOM::PerlSAX. It operates specifically on my wierd tree format. Unfortunately SAX





We can't live, work or learn in freedom unless the software we use is free.