diff options
-rw-r--r-- | ChangeLog | 3 | ||||
-rw-r--r-- | openbsd-compat/getopt.h | 78 | ||||
-rw-r--r-- | openbsd-compat/getopt_long.c | 6 | ||||
-rw-r--r-- | openbsd-compat/openbsd-compat.h | 3 |
4 files changed, 87 insertions, 3 deletions
@@ -9,6 +9,9 @@ | |||
9 | openbsd-compat/getopt_long.c regress/modpipe.c] Remove getopt.c, add | 9 | openbsd-compat/getopt_long.c regress/modpipe.c] Remove getopt.c, add |
10 | portability code to getopt_long.c and switch over Makefile and the ugly | 10 | portability code to getopt_long.c and switch over Makefile and the ugly |
11 | hack in modpipe.c. Fixes bz#1448. | 11 | hack in modpipe.c. Fixes bz#1448. |
12 | - (dtucker) [openbsd-compat/getopt.h openbsd-compat/getopt_long.c | ||
13 | openbsd-compat/openbsd-compat.h] pull in getopt.h from openbsd and plumb | ||
14 | in to use it when we're using our own getopt. | ||
12 | 15 | ||
13 | 20130423 | 16 | 20130423 |
14 | - (djm) [auth.c configure.ac misc.c monitor.c monitor_wrap.c] Support | 17 | - (djm) [auth.c configure.ac misc.c monitor.c monitor_wrap.c] Support |
diff --git a/openbsd-compat/getopt.h b/openbsd-compat/getopt.h new file mode 100644 index 000000000..0311b078b --- /dev/null +++ b/openbsd-compat/getopt.h | |||
@@ -0,0 +1,78 @@ | |||
1 | /* $OpenBSD: getopt.h,v 1.2 2008/06/26 05:42:04 ray Exp $ */ | ||
2 | /* $NetBSD: getopt.h,v 1.4 2000/07/07 10:43:54 ad Exp $ */ | ||
3 | |||
4 | /*- | ||
5 | * Copyright (c) 2000 The NetBSD Foundation, Inc. | ||
6 | * All rights reserved. | ||
7 | * | ||
8 | * This code is derived from software contributed to The NetBSD Foundation | ||
9 | * by Dieter Baron and Thomas Klausner. | ||
10 | * | ||
11 | * Redistribution and use in source and binary forms, with or without | ||
12 | * modification, are permitted provided that the following conditions | ||
13 | * are met: | ||
14 | * 1. Redistributions of source code must retain the above copyright | ||
15 | * notice, this list of conditions and the following disclaimer. | ||
16 | * 2. Redistributions in binary form must reproduce the above copyright | ||
17 | * notice, this list of conditions and the following disclaimer in the | ||
18 | * documentation and/or other materials provided with the distribution. | ||
19 | * | ||
20 | * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS | ||
21 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED | ||
22 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | ||
23 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS | ||
24 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | ||
25 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | ||
26 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | ||
27 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | ||
28 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | ||
29 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | ||
30 | * POSSIBILITY OF SUCH DAMAGE. | ||
31 | */ | ||
32 | |||
33 | #ifndef _GETOPT_H_ | ||
34 | #define _GETOPT_H_ | ||
35 | |||
36 | #include <sys/cdefs.h> | ||
37 | |||
38 | /* | ||
39 | * GNU-like getopt_long() and 4.4BSD getsubopt()/optreset extensions | ||
40 | */ | ||
41 | #define no_argument 0 | ||
42 | #define required_argument 1 | ||
43 | #define optional_argument 2 | ||
44 | |||
45 | struct option { | ||
46 | /* name of long option */ | ||
47 | const char *name; | ||
48 | /* | ||
49 | * one of no_argument, required_argument, and optional_argument: | ||
50 | * whether option takes an argument | ||
51 | */ | ||
52 | int has_arg; | ||
53 | /* if not NULL, set *flag to val when option found */ | ||
54 | int *flag; | ||
55 | /* if flag not NULL, value to set *flag to; else return value */ | ||
56 | int val; | ||
57 | }; | ||
58 | |||
59 | __BEGIN_DECLS | ||
60 | int getopt_long(int, char * const *, const char *, | ||
61 | const struct option *, int *); | ||
62 | int getopt_long_only(int, char * const *, const char *, | ||
63 | const struct option *, int *); | ||
64 | #ifndef _GETOPT_DEFINED_ | ||
65 | #define _GETOPT_DEFINED_ | ||
66 | int getopt(int, char * const *, const char *); | ||
67 | int getsubopt(char **, char * const *, char **); | ||
68 | |||
69 | extern char *optarg; /* getopt(3) external variables */ | ||
70 | extern int opterr; | ||
71 | extern int optind; | ||
72 | extern int optopt; | ||
73 | extern int optreset; | ||
74 | extern char *suboptarg; /* getsubopt(3) external variable */ | ||
75 | #endif | ||
76 | __END_DECLS | ||
77 | |||
78 | #endif /* !_GETOPT_H_ */ | ||
diff --git a/openbsd-compat/getopt_long.c b/openbsd-compat/getopt_long.c index 6b36d0672..e28947430 100644 --- a/openbsd-compat/getopt_long.c +++ b/openbsd-compat/getopt_long.c | |||
@@ -53,7 +53,6 @@ | |||
53 | #include "includes.h" | 53 | #include "includes.h" |
54 | 54 | ||
55 | #if !defined(HAVE_GETOPT) || !defined(HAVE_GETOPT_OPTRESET) | 55 | #if !defined(HAVE_GETOPT) || !defined(HAVE_GETOPT_OPTRESET) |
56 | #include "log.h" | ||
57 | 56 | ||
58 | /* | 57 | /* |
59 | * Some defines to make it easier to keep the code in sync with upstream. | 58 | * Some defines to make it easier to keep the code in sync with upstream. |
@@ -64,11 +63,14 @@ | |||
64 | 63 | ||
65 | #if 0 | 64 | #if 0 |
66 | #include <err.h> | 65 | #include <err.h> |
66 | #include <getopt.h> | ||
67 | #endif | 67 | #endif |
68 | #include <errno.h> | 68 | #include <errno.h> |
69 | #include <getopt.h> | ||
70 | #include <stdlib.h> | 69 | #include <stdlib.h> |
71 | #include <string.h> | 70 | #include <string.h> |
71 | #include <stdarg.h> | ||
72 | |||
73 | #include "log.h" | ||
72 | 74 | ||
73 | int opterr = 1; /* if error message should be printed */ | 75 | int opterr = 1; /* if error message should be printed */ |
74 | int optind = 1; /* index into parent argv vector */ | 76 | int optind = 1; /* index into parent argv vector */ |
diff --git a/openbsd-compat/openbsd-compat.h b/openbsd-compat/openbsd-compat.h index a8c579f49..94d172aaa 100644 --- a/openbsd-compat/openbsd-compat.h +++ b/openbsd-compat/openbsd-compat.h | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $Id: openbsd-compat.h,v 1.55 2013/02/15 01:20:42 dtucker Exp $ */ | 1 | /* $Id: openbsd-compat.h,v 1.56 2013/05/10 08:08:49 dtucker Exp $ */ |
2 | 2 | ||
3 | /* | 3 | /* |
4 | * Copyright (c) 1999-2003 Damien Miller. All rights reserved. | 4 | * Copyright (c) 1999-2003 Damien Miller. All rights reserved. |
@@ -139,6 +139,7 @@ int getgrouplist(const char *, gid_t, gid_t *, int *); | |||
139 | 139 | ||
140 | #if !defined(HAVE_GETOPT) || !defined(HAVE_GETOPT_OPTRESET) | 140 | #if !defined(HAVE_GETOPT) || !defined(HAVE_GETOPT_OPTRESET) |
141 | int BSDgetopt(int argc, char * const *argv, const char *opts); | 141 | int BSDgetopt(int argc, char * const *argv, const char *opts); |
142 | #include "openbsd-compat/getopt.h" | ||
142 | #endif | 143 | #endif |
143 | 144 | ||
144 | #if defined(HAVE_DECL_WRITEV) && HAVE_DECL_WRITEV == 0 | 145 | #if defined(HAVE_DECL_WRITEV) && HAVE_DECL_WRITEV == 0 |