summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--openbsd-compat/getopt.h78
-rw-r--r--openbsd-compat/getopt_long.c6
-rw-r--r--openbsd-compat/openbsd-compat.h3
4 files changed, 87 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index e0604abe1..650400f83 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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
1320130423 1620130423
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
45struct 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
60int getopt_long(int, char * const *, const char *,
61 const struct option *, int *);
62int getopt_long_only(int, char * const *, const char *,
63 const struct option *, int *);
64#ifndef _GETOPT_DEFINED_
65#define _GETOPT_DEFINED_
66int getopt(int, char * const *, const char *);
67int getsubopt(char **, char * const *, char **);
68
69extern char *optarg; /* getopt(3) external variables */
70extern int opterr;
71extern int optind;
72extern int optopt;
73extern int optreset;
74extern 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
73int opterr = 1; /* if error message should be printed */ 75int opterr = 1; /* if error message should be printed */
74int optind = 1; /* index into parent argv vector */ 76int 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)
141int BSDgetopt(int argc, char * const *argv, const char *opts); 141int 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