tcpprep_opts.h 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. /* -*- buffer-read-only: t -*- vi: set ro:
  2. *
  3. * DO NOT EDIT THIS FILE (tcpprep_opts.h)
  4. *
  5. * It has been AutoGen-ed
  6. * From the definitions ../../src/tcpprep_opts.def
  7. * and the template file options
  8. *
  9. * Generated from AutoOpts 42:1:17 templates.
  10. *
  11. * AutoOpts is a copyrighted work. This header file is not encumbered
  12. * by AutoOpts licensing, but is provided under the licensing terms chosen
  13. * by the tcpprep author or copyright holder. AutoOpts is
  14. * licensed under the terms of the LGPL. The redistributable library
  15. * (``libopts'') is licensed under the terms of either the LGPL or, at the
  16. * users discretion, the BSD license. See the AutoOpts and/or libopts sources
  17. * for details.
  18. *
  19. * The tcpprep program is copyrighted and licensed
  20. * under the following terms:
  21. *
  22. * Copyright (C) 2000-2024 Aaron Turner and Fred Klassen, all rights reserved.
  23. * This is free software. It is licensed for use, modification and
  24. * redistribution under the terms of the GNU General Public License,
  25. * version 3 or later <http://gnu.org/licenses/gpl.html>
  26. *
  27. * tcpprep is free software: you can redistribute it and/or modify it
  28. * under the terms of the GNU General Public License as published by the
  29. * Free Software Foundation, either version 3 of the License, or
  30. * (at your option) any later version.
  31. *
  32. * tcpprep is distributed in the hope that it will be useful, but
  33. * WITHOUT ANY WARRANTY; without even the implied warranty of
  34. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  35. * See the GNU General Public License for more details.
  36. *
  37. * You should have received a copy of the GNU General Public License along
  38. * with this program. If not, see <http://www.gnu.org/licenses/>.
  39. */
  40. /**
  41. * This file contains the programmatic interface to the Automated
  42. * Options generated for the tcpprep program.
  43. * These macros are documented in the AutoGen info file in the
  44. * "AutoOpts" chapter. Please refer to that doc for usage help.
  45. */
  46. #ifndef AUTOOPTS_TCPPREP_OPTS_H_GUARD
  47. #define AUTOOPTS_TCPPREP_OPTS_H_GUARD 1
  48. #include "config.h"
  49. #include <autoopts/options.h>
  50. #include <stdarg.h>
  51. #include <stdnoreturn.h>
  52. /**
  53. * Ensure that the library used for compiling this generated header is at
  54. * least as new as the version current when the header template was released
  55. * (not counting patch version increments). Also ensure that the oldest
  56. * tolerable version is at least as old as what was current when the header
  57. * template was released.
  58. */
  59. #define AO_TEMPLATE_VERSION 172033
  60. #if (AO_TEMPLATE_VERSION < OPTIONS_MINIMUM_VERSION) \
  61. || (AO_TEMPLATE_VERSION > OPTIONS_STRUCT_VERSION)
  62. # error option template version mismatches autoopts/options.h header
  63. Choke Me.
  64. #endif
  65. #if GCC_VERSION > 40400
  66. #define NOT_REACHED __builtin_unreachable();
  67. #else
  68. #define NOT_REACHED
  69. #endif
  70. /**
  71. * Enumeration of each option type for tcpprep
  72. */
  73. typedef enum {
  74. INDEX_OPT_DBUG = 0,
  75. INDEX_OPT_AUTO = 1,
  76. INDEX_OPT_CIDR = 2,
  77. INDEX_OPT_REGEX = 3,
  78. INDEX_OPT_PORT = 4,
  79. INDEX_OPT_MAC = 5,
  80. INDEX_OPT_REVERSE = 6,
  81. INDEX_OPT_COMMENT = 7,
  82. INDEX_OPT_NO_ARG_COMMENT = 8,
  83. INDEX_OPT_INCLUDE = 9,
  84. INDEX_OPT_EXCLUDE = 10,
  85. INDEX_OPT_CACHEFILE = 11,
  86. INDEX_OPT_PCAP = 12,
  87. INDEX_OPT_PRINT_COMMENT = 13,
  88. INDEX_OPT_PRINT_INFO = 14,
  89. INDEX_OPT_PRINT_STATS = 15,
  90. INDEX_OPT_SERVICES = 16,
  91. INDEX_OPT_NONIP = 17,
  92. INDEX_OPT_RATIO = 18,
  93. INDEX_OPT_MINMASK = 19,
  94. INDEX_OPT_MAXMASK = 20,
  95. INDEX_OPT_VERBOSE = 21,
  96. INDEX_OPT_DECODE = 22,
  97. INDEX_OPT_VERSION = 23,
  98. INDEX_OPT_LESS_HELP = 24,
  99. INDEX_OPT_SUPPRESS_WARNINGS = 25,
  100. INDEX_OPT_HELP = 26,
  101. INDEX_OPT_MORE_HELP = 27,
  102. INDEX_OPT_SAVE_OPTS = 28,
  103. INDEX_OPT_LOAD_OPTS = 29
  104. } teOptIndex;
  105. /** count of all options for tcpprep */
  106. #define OPTION_CT 30
  107. /**
  108. * Interface defines for all options. Replace "n" with the UPPER_CASED
  109. * option name (as in the teOptIndex enumeration above).
  110. * e.g. HAVE_OPT(DBUG)
  111. */
  112. #define DESC(n) (tcpprepOptions.pOptDesc[INDEX_OPT_## n])
  113. /** 'true' if an option has been specified in any way */
  114. #define HAVE_OPT(n) (! UNUSED_OPT(& DESC(n)))
  115. /** The string argument to an option. The argument type must be \"string\". */
  116. #define OPT_ARG(n) (DESC(n).optArg.argString)
  117. /** Mask the option state revealing how an option was specified.
  118. * It will be one and only one of \a OPTST_SET, \a OPTST_PRESET,
  119. * \a OPTST_DEFINED, \a OPTST_RESET or zero.
  120. */
  121. #define STATE_OPT(n) (DESC(n).fOptState & OPTST_SET_MASK)
  122. /** Count of option's occurrances *on the command line*. */
  123. #define COUNT_OPT(n) (DESC(n).optOccCt)
  124. /** mask of \a OPTST_SET and \a OPTST_DEFINED. */
  125. #define ISSEL_OPT(n) (SELECTED_OPT(&DESC(n)))
  126. /** 'true' if \a HAVE_OPT would yield 'false'. */
  127. #define ISUNUSED_OPT(n) (UNUSED_OPT(& DESC(n)))
  128. /** 'true' if OPTST_DISABLED bit not set. */
  129. #define ENABLED_OPT(n) (! DISABLED_OPT(& DESC(n)))
  130. /** number of stacked option arguments.
  131. * Valid only for stacked option arguments. */
  132. #define STACKCT_OPT(n) (((tArgList*)(DESC(n).optCookie))->useCt)
  133. /** stacked argument vector.
  134. * Valid only for stacked option arguments. */
  135. #define STACKLST_OPT(n) (((tArgList*)(DESC(n).optCookie))->apzArgs)
  136. /** Reset an option. */
  137. #define CLEAR_OPT(n) STMTS( \
  138. DESC(n).fOptState &= OPTST_PERSISTENT_MASK; \
  139. if ((DESC(n).fOptState & OPTST_INITENABLED) == 0) \
  140. DESC(n).fOptState |= OPTST_DISABLED; \
  141. DESC(n).optCookie = NULL )
  142. /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
  143. /**
  144. * Enumeration of tcpprep exit codes
  145. */
  146. typedef enum {
  147. TCPPREP_EXIT_SUCCESS = 0,
  148. TCPPREP_EXIT_FAILURE = 1,
  149. TCPPREP_EXIT_USAGE_ERROR = 64,
  150. TCPPREP_EXIT_NO_CONFIG_INPUT = 66,
  151. TCPPREP_EXIT_LIBOPTS_FAILURE = 70
  152. } tcpprep_exit_code_t;
  153. /**
  154. * Interface defines for specific options.
  155. * @{
  156. */
  157. #define VALUE_OPT_DBUG 'd'
  158. #ifdef DEBUG
  159. #define OPT_VALUE_DBUG (DESC(DBUG).optArg.argInt)
  160. #endif /* DEBUG */
  161. #define VALUE_OPT_AUTO 'a'
  162. #define VALUE_OPT_CIDR 'c'
  163. #define VALUE_OPT_REGEX 'r'
  164. #define VALUE_OPT_PORT 'p'
  165. #define VALUE_OPT_MAC 'e'
  166. #define VALUE_OPT_REVERSE 0x1001
  167. #define VALUE_OPT_COMMENT 'C'
  168. #define VALUE_OPT_NO_ARG_COMMENT 0x1002
  169. #define VALUE_OPT_INCLUDE 'x'
  170. #define VALUE_OPT_EXCLUDE 'X'
  171. #define VALUE_OPT_CACHEFILE 'o'
  172. #define VALUE_OPT_PCAP 'i'
  173. #define VALUE_OPT_PRINT_COMMENT 'P'
  174. #define VALUE_OPT_PRINT_INFO 'I'
  175. #define VALUE_OPT_PRINT_STATS 'S'
  176. #define VALUE_OPT_SERVICES 's'
  177. #define VALUE_OPT_NONIP 'N'
  178. #define VALUE_OPT_RATIO 'R'
  179. #define VALUE_OPT_MINMASK 'm'
  180. #define OPT_VALUE_MINMASK (DESC(MINMASK).optArg.argInt)
  181. #define VALUE_OPT_MAXMASK 'M'
  182. #define OPT_VALUE_MAXMASK (DESC(MAXMASK).optArg.argInt)
  183. #define VALUE_OPT_VERBOSE 'v'
  184. #ifdef ENABLE_VERBOSE
  185. #define SET_OPT_VERBOSE STMTS( \
  186. DESC(VERBOSE).optActualIndex = 21; \
  187. DESC(VERBOSE).optActualValue = VALUE_OPT_VERBOSE; \
  188. DESC(VERBOSE).fOptState &= OPTST_PERSISTENT_MASK; \
  189. DESC(VERBOSE).fOptState |= OPTST_SET )
  190. #endif /* ENABLE_VERBOSE */
  191. #define VALUE_OPT_DECODE 'A'
  192. #define VALUE_OPT_VERSION 'V'
  193. #define VALUE_OPT_LESS_HELP 'h'
  194. #define VALUE_OPT_SUPPRESS_WARNINGS 'w'
  195. #define SET_OPT_SUPPRESS_WARNINGS STMTS( \
  196. DESC(SUPPRESS_WARNINGS).optActualIndex = 25; \
  197. DESC(SUPPRESS_WARNINGS).optActualValue = VALUE_OPT_SUPPRESS_WARNINGS; \
  198. DESC(SUPPRESS_WARNINGS).fOptState &= OPTST_PERSISTENT_MASK; \
  199. DESC(SUPPRESS_WARNINGS).fOptState |= OPTST_SET )
  200. /** option flag (value) for help-value option */
  201. #define VALUE_OPT_HELP 'H'
  202. /** option flag (value) for more-help-value option */
  203. #define VALUE_OPT_MORE_HELP '!'
  204. /** option flag (value) for save-opts-value option */
  205. #define VALUE_OPT_SAVE_OPTS 0x1003
  206. /** option flag (value) for load-opts-value option */
  207. #define VALUE_OPT_LOAD_OPTS 0x1004
  208. #define SET_OPT_SAVE_OPTS(a) STMTS( \
  209. DESC(SAVE_OPTS).fOptState &= OPTST_PERSISTENT_MASK; \
  210. DESC(SAVE_OPTS).fOptState |= OPTST_SET; \
  211. DESC(SAVE_OPTS).optArg.argString = (char const*)(a))
  212. /*
  213. * Interface defines not associated with particular options
  214. */
  215. #define ERRSKIP_OPTERR STMTS(tcpprepOptions.fOptSet &= ~OPTPROC_ERRSTOP)
  216. #define ERRSTOP_OPTERR STMTS(tcpprepOptions.fOptSet |= OPTPROC_ERRSTOP)
  217. #define RESTART_OPT(n) STMTS( \
  218. tcpprepOptions.curOptIdx = (n); \
  219. tcpprepOptions.pzCurOpt = NULL )
  220. #define START_OPT RESTART_OPT(1)
  221. #define USAGE(c) (*tcpprepOptions.pUsageProc)(&tcpprepOptions, c)
  222. #ifdef __cplusplus
  223. extern "C" {
  224. #endif
  225. /* * * * * *
  226. *
  227. * Declare the tcpprep option descriptor.
  228. */
  229. extern tOptions tcpprepOptions;
  230. #if defined(ENABLE_NLS)
  231. # ifndef _
  232. # include <stdio.h>
  233. # ifndef HAVE_GETTEXT
  234. extern char * gettext(char const *);
  235. # else
  236. # include <libintl.h>
  237. # endif
  238. # ifndef ATTRIBUTE_FORMAT_ARG
  239. # define ATTRIBUTE_FORMAT_ARG(_a)
  240. # endif
  241. static inline char* aoGetsText(char const* pz) ATTRIBUTE_FORMAT_ARG(1);
  242. static inline char* aoGetsText(char const* pz) {
  243. if (pz == NULL) return NULL;
  244. return (char*)gettext(pz);
  245. }
  246. # define _(s) aoGetsText(s)
  247. # endif /* _() */
  248. # define OPT_NO_XLAT_CFG_NAMES STMTS(tcpprepOptions.fOptSet |= \
  249. OPTPROC_NXLAT_OPT_CFG;)
  250. # define OPT_NO_XLAT_OPT_NAMES STMTS(tcpprepOptions.fOptSet |= \
  251. OPTPROC_NXLAT_OPT|OPTPROC_NXLAT_OPT_CFG;)
  252. # define OPT_XLAT_CFG_NAMES STMTS(tcpprepOptions.fOptSet &= \
  253. ~(OPTPROC_NXLAT_OPT|OPTPROC_NXLAT_OPT_CFG);)
  254. # define OPT_XLAT_OPT_NAMES STMTS(tcpprepOptions.fOptSet &= \
  255. ~OPTPROC_NXLAT_OPT;)
  256. #else /* ENABLE_NLS */
  257. # define OPT_NO_XLAT_CFG_NAMES
  258. # define OPT_NO_XLAT_OPT_NAMES
  259. # define OPT_XLAT_CFG_NAMES
  260. # define OPT_XLAT_OPT_NAMES
  261. # ifndef _
  262. # define _(_s) _s
  263. # endif
  264. #endif /* ENABLE_NLS */
  265. #ifdef __cplusplus
  266. }
  267. #endif
  268. #endif /* AUTOOPTS_TCPPREP_OPTS_H_GUARD */
  269. /* tcpprep_opts.h ends here */