getopt.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /* $NetBSD: getopt.h,v 1.4 2000/07/07 10:43:54 ad Exp $ */
  2. /* $FreeBSD: src/include/getopt.h,v 1.1 2002/09/29 04:14:30 eric Exp $ */
  3. /*-
  4. * Copyright (c) 2000 The NetBSD Foundation, Inc.
  5. * All rights reserved.
  6. *
  7. * This code is derived from software contributed to The NetBSD Foundation
  8. * by Dieter Baron and Thomas Klausner.
  9. *
  10. * Redistribution and use in source and binary forms, with or without
  11. * modification, are permitted provided that the following conditions
  12. * are met:
  13. * 1. Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in the
  17. * documentation and/or other materials provided with the distribution.
  18. * 3. All advertising materials mentioning features or use of this software
  19. * must display the following acknowledgement:
  20. * This product includes software developed by the NetBSD
  21. * Foundation, Inc. and its contributors.
  22. * 4. Neither the name of The NetBSD Foundation nor the names of its
  23. * contributors may be used to endorse or promote products derived
  24. * from this software without specific prior written permission.
  25. *
  26. * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
  27. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
  28. * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  29. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
  30. * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  31. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  32. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  33. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  34. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  35. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  36. * POSSIBILITY OF SUCH DAMAGE.
  37. */
  38. #ifndef _GETOPT_H_
  39. #define _GETOPT_H_
  40. #ifdef _WIN32
  41. /* from <sys/cdefs.h> */
  42. # ifdef __cplusplus
  43. # define __BEGIN_DECLS extern "C" {
  44. # define __END_DECLS }
  45. # else
  46. # define __BEGIN_DECLS
  47. # define __END_DECLS
  48. # endif
  49. # define __P(args) args
  50. #endif
  51. /*#ifndef _WIN32
  52. #include <sys/cdefs.h>
  53. #include <unistd.h>
  54. #endif*/
  55. #ifdef _WIN32
  56. # if !defined(GETOPT_API)
  57. # define GETOPT_API __declspec(dllimport)
  58. # endif
  59. #endif
  60. /*
  61. * Gnu like getopt_long() and BSD4.4 getsubopt()/optreset extensions
  62. */
  63. #if !defined(_POSIX_SOURCE) && !defined(_XOPEN_SOURCE)
  64. #define no_argument 0
  65. #define required_argument 1
  66. #define optional_argument 2
  67. struct option {
  68. /* name of long option */
  69. const char *name;
  70. /*
  71. * one of no_argument, required_argument, and optional_argument:
  72. * whether option takes an argument
  73. */
  74. int has_arg;
  75. /* if not NULL, set *flag to val when option found */
  76. int *flag;
  77. /* if flag not NULL, value to set *flag to; else return value */
  78. int val;
  79. };
  80. __BEGIN_DECLS
  81. GETOPT_API int getopt_long __P((int, char * const *, const char *,
  82. const struct option *, int *));
  83. __END_DECLS
  84. #endif
  85. #ifdef _WIN32
  86. /* These are global getopt variables */
  87. __BEGIN_DECLS
  88. GETOPT_API extern int opterr, /* if error message should be printed */
  89. optind, /* index into parent argv vector */
  90. optopt, /* character checked for validity */
  91. optreset; /* reset getopt */
  92. GETOPT_API extern char* optarg; /* argument associated with option */
  93. /* Original getopt */
  94. GETOPT_API int getopt __P((int, char * const *, const char *));
  95. __END_DECLS
  96. #endif
  97. #endif /* !_GETOPT_H_ */