]> granicus.if.org Git - postgresql/blob - src/port/getopt.c
Adjust comments previously moved to column 1 by pgident.
[postgresql] / src / port / getopt.c
1 /* This is used by psql under Win32 */
2
3 /*
4  * Copyright (c) 1987, 1993, 1994
5  *      The Regents of the University of California.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *        notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *        notice, this list of conditions and the following disclaimer in the
14  *        documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *        must display the following acknowledgement:
17  *      This product includes software developed by the University of
18  *      California, Berkeley and its contributors.
19  * 4. Neither the name of the University nor the names of its contributors
20  *        may be used to endorse or promote products derived from this software
21  *        without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26  * ARE DISCLAIMED.      IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33  */
34
35 #include "c.h"
36
37
38 #if defined(LIBC_SCCS) && !defined(lint)
39 static char sccsid[] = "@(#)getopt.c    8.3 (Berkeley) 4/27/95";
40 #endif   /* LIBC_SCCS and not lint */
41
42 #include <stdio.h>
43 #include <stdlib.h>
44 #include <string.h>
45
46 int                     opterr = 1,                     /* if error message should be printed */
47                         optind = 1,                     /* index into parent argv vector */
48                         optopt,                         /* character checked for validity */
49                         optreset;                       /* reset getopt */
50 char       *optarg;                             /* argument associated with option */
51
52 #define BADCH   (int)'?'
53 #define BADARG  (int)':'
54 #define EMSG    ""
55
56 /*
57  * getopt
58  *      Parse argc/argv argument vector.
59  */
60 int
61 getopt(nargc, nargv, ostr)
62 int                     nargc;
63 char       *const * nargv;
64 const char *ostr;
65 {
66         static char *place = EMSG;      /* option letter processing */
67         char       *oli;                        /* option letter list index */
68
69         if (optreset || !*place)
70         {                                                       /* update scanning pointer */
71                 optreset = 0;
72                 if (optind >= nargc || *(place = nargv[optind]) != '-')
73                 {
74                         place = EMSG;
75                         return -1;
76                 }
77                 if (place[1] && *++place == '-' && place[1] == '\0')
78                 {                                               /* found "--" */
79                         ++optind;
80                         place = EMSG;
81                         return -1;
82                 }
83         }                                                       /* option letter okay? */
84         if ((optopt = (int) *place++) == (int) ':' ||
85                 !(oli = strchr(ostr, optopt)))
86         {
87                 /*
88                  * if the user didn't specify '-' as an option, assume it means
89                  * -1.
90                  */
91                 if (optopt == (int) '-')
92                         return -1;
93                 if (!*place)
94                         ++optind;
95                 if (opterr && *ostr != ':')
96                         (void) fprintf(stderr,
97                                                    "illegal option -- %c\n", optopt);
98                 return BADCH;
99         }
100         if (*++oli != ':')
101         {                                                       /* don't need argument */
102                 optarg = NULL;
103                 if (!*place)
104                         ++optind;
105         }
106         else
107         {                                                       /* need an argument */
108                 if (*place)                             /* no white space */
109                         optarg = place;
110                 else if (nargc <= ++optind)
111                 {                                               /* no arg */
112                         place = EMSG;
113                         if (*ostr == ':')
114                                 return BADARG;
115                         if (opterr)
116                                 (void) fprintf(stderr,
117                                                            "option requires an argument -- %c\n",
118                                                            optopt);
119                         return BADCH;
120                 }
121                 else
122                         /* white space */
123                         optarg = nargv[optind];
124                 place = EMSG;
125                 ++optind;
126         }
127         return optopt;                          /* dump back option letter */
128 }