flowreplay_opts.h 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. /* -*- buffer-read-only: t -*- vi: set ro:
  2. *
  3. * DO NOT EDIT THIS FILE (flowreplay_opts.h)
  4. *
  5. * It has been AutoGen-ed Sunday August 26, 2007 at 01:08:04 PM PDT
  6. * From the definitions flowreplay_opts.def
  7. * and the template file options
  8. *
  9. * Generated from AutoOpts 30:0:5 templates.
  10. */
  11. /*
  12. * This file was produced by an AutoOpts template. AutoOpts is a
  13. * copyrighted work. This header file is not encumbered by AutoOpts
  14. * licensing, but is provided under the licensing terms chosen by the
  15. * flowreplay author or copyright holder. AutoOpts is licensed under
  16. * the terms of the LGPL. The redistributable library (``libopts'') is
  17. * licensed under the terms of either the LGPL or, at the users discretion,
  18. * the BSD license. See the AutoOpts and/or libopts sources for details.
  19. *
  20. * This source file is copyrighted and licensed under the following terms:
  21. *
  22. * flowreplay copyright 2004-2007 Aaron Turner - all rights reserved
  23. *
  24. * flowreplay is free software copyrighted by Aaron Turner.
  25. *
  26. * Redistribution and use in source and binary forms, with or without
  27. * modification, are permitted provided that the following conditions
  28. * are met:
  29. * 1. Redistributions of source code must retain the above copyright
  30. * notice, this list of conditions and the following disclaimer.
  31. * 2. Redistributions in binary form must reproduce the above copyright
  32. * notice, this list of conditions and the following disclaimer in the
  33. * documentation and/or other materials provided with the distribution.
  34. * 3. Neither the name ``Aaron Turner'' nor the name of any other
  35. * contributor may be used to endorse or promote products derived
  36. * from this software without specific prior written permission.
  37. *
  38. * flowreplay IS PROVIDED BY Aaron Turner ``AS IS'' AND ANY EXPRESS
  39. * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  40. * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  41. * ARE DISCLAIMED. IN NO EVENT SHALL Aaron Turner OR ANY OTHER CONTRIBUTORS
  42. * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  43. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  44. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
  45. * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  46. * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  47. * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  48. * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  49. */
  50. /*
  51. * This file contains the programmatic interface to the Automated
  52. * Options generated for the flowreplay program.
  53. * These macros are documented in the AutoGen info file in the
  54. * "AutoOpts" chapter. Please refer to that doc for usage help.
  55. */
  56. #ifndef AUTOOPTS_FLOWREPLAY_OPTS_H_GUARD
  57. #define AUTOOPTS_FLOWREPLAY_OPTS_H_GUARD 1
  58. #include "config.h"
  59. #include <autoopts/options.h>
  60. /*
  61. * Ensure that the library used for compiling this generated header is at
  62. * least as new as the version current when the header template was released
  63. * (not counting patch version increments). Also ensure that the oldest
  64. * tolerable version is at least as old as what was current when the header
  65. * template was released.
  66. */
  67. #define AO_TEMPLATE_VERSION 122880
  68. #if (AO_TEMPLATE_VERSION < OPTIONS_MINIMUM_VERSION) \
  69. || (AO_TEMPLATE_VERSION > OPTIONS_STRUCT_VERSION)
  70. # error option template version mismatches autoopts/options.h header
  71. Choke Me.
  72. #endif
  73. /*
  74. * Enumeration of each option:
  75. */
  76. typedef enum {
  77. INDEX_OPT_DBUG = 0,
  78. INDEX_OPT_VERBOSE = 1,
  79. INDEX_OPT_DECODE = 2,
  80. INDEX_OPT_MODE = 3,
  81. INDEX_OPT_WAIT = 4,
  82. INDEX_OPT_TARGETIP = 5,
  83. INDEX_OPT_FILTER = 6,
  84. INDEX_OPT_CLIENTNET = 7,
  85. INDEX_OPT_SERVERNET = 8,
  86. INDEX_OPT_NOSYN = 9,
  87. INDEX_OPT_SLIMIT = 10,
  88. INDEX_OPT_VERSION = 11,
  89. INDEX_OPT_LESS_HELP = 12,
  90. INDEX_OPT_HELP = 13,
  91. INDEX_OPT_MORE_HELP = 14,
  92. INDEX_OPT_SAVE_OPTS = 15,
  93. INDEX_OPT_LOAD_OPTS = 16
  94. } teOptIndex;
  95. #define OPTION_CT 17
  96. /*
  97. * Interface defines for all options. Replace "n" with the UPPER_CASED
  98. * option name (as in the teOptIndex enumeration above).
  99. * e.g. HAVE_OPT( DBUG )
  100. */
  101. #define DESC(n) (flowreplayOptions.pOptDesc[INDEX_OPT_## n])
  102. #define HAVE_OPT(n) (! UNUSED_OPT(& DESC(n)))
  103. #define OPT_ARG(n) (DESC(n).optArg.argString)
  104. #define STATE_OPT(n) (DESC(n).fOptState & OPTST_SET_MASK)
  105. #define COUNT_OPT(n) (DESC(n).optOccCt)
  106. #define ISSEL_OPT(n) (SELECTED_OPT(&DESC(n)))
  107. #define ISUNUSED_OPT(n) (UNUSED_OPT(& DESC(n)))
  108. #define ENABLED_OPT(n) (! DISABLED_OPT(& DESC(n)))
  109. #define STACKCT_OPT(n) (((tArgList*)(DESC(n).optCookie))->useCt)
  110. #define STACKLST_OPT(n) (((tArgList*)(DESC(n).optCookie))->apzArgs)
  111. #define CLEAR_OPT(n) STMTS( \
  112. DESC(n).fOptState &= OPTST_PERSISTENT_MASK; \
  113. if ( (DESC(n).fOptState & OPTST_INITENABLED) == 0) \
  114. DESC(n).fOptState |= OPTST_DISABLED; \
  115. DESC(n).optCookie = NULL )
  116. /*
  117. * Interface defines for specific options.
  118. */
  119. #ifdef DEBUG
  120. #define VALUE_OPT_DBUG 'd'
  121. #define OPT_VALUE_DBUG (DESC(DBUG).optArg.argInt)
  122. #endif /* DEBUG */
  123. #ifdef ENABLE_VERBOSE
  124. #define VALUE_OPT_VERBOSE 'v'
  125. #define SET_OPT_VERBOSE STMTS( \
  126. DESC(VERBOSE).optActualIndex = 1; \
  127. DESC(VERBOSE).optActualValue = VALUE_OPT_VERBOSE; \
  128. DESC(VERBOSE).fOptState &= OPTST_PERSISTENT_MASK; \
  129. DESC(VERBOSE).fOptState |= OPTST_SET )
  130. #endif /* ENABLE_VERBOSE */
  131. #ifdef ENABLE_VERBOSE
  132. #define VALUE_OPT_DECODE 'A'
  133. #endif /* ENABLE_VERBOSE */
  134. #define VALUE_OPT_MODE 'm'
  135. #define VALUE_OPT_WAIT 'w'
  136. #define VALUE_OPT_TARGETIP 't'
  137. #define VALUE_OPT_FILTER 'f'
  138. #define VALUE_OPT_CLIENTNET 'c'
  139. #define VALUE_OPT_SERVERNET 's'
  140. #define VALUE_OPT_NOSYN 'n'
  141. #define VALUE_OPT_SLIMIT 'l'
  142. #define VALUE_OPT_VERSION 'V'
  143. #define VALUE_OPT_LESS_HELP 'h'
  144. #define VALUE_OPT_HELP 'H'
  145. #define VALUE_OPT_MORE_HELP '!'
  146. #define VALUE_OPT_SAVE_OPTS INDEX_OPT_SAVE_OPTS
  147. #define VALUE_OPT_LOAD_OPTS INDEX_OPT_LOAD_OPTS
  148. #define SET_OPT_SAVE_OPTS(a) STMTS( \
  149. DESC(SAVE_OPTS).fOptState &= OPTST_PERSISTENT_MASK; \
  150. DESC(SAVE_OPTS).fOptState |= OPTST_SET; \
  151. DESC(SAVE_OPTS).optArg.argString = (char const*)(a) )
  152. /*
  153. * Interface defines not associated with particular options
  154. */
  155. #define ERRSKIP_OPTERR STMTS( flowreplayOptions.fOptSet &= ~OPTPROC_ERRSTOP )
  156. #define ERRSTOP_OPTERR STMTS( flowreplayOptions.fOptSet |= OPTPROC_ERRSTOP )
  157. #define RESTART_OPT(n) STMTS( \
  158. flowreplayOptions.curOptIdx = (n); \
  159. flowreplayOptions.pzCurOpt = NULL )
  160. #define START_OPT RESTART_OPT(1)
  161. #define USAGE(c) (*flowreplayOptions.pUsageProc)( &flowreplayOptions, c )
  162. /* extracted from /opt/local/share/autogen/opthead.tpl near line 380 */
  163. /* * * * * *
  164. *
  165. * Declare the flowreplay option descriptor.
  166. */
  167. #ifdef __cplusplus
  168. extern "C" {
  169. #endif
  170. extern tOptions flowreplayOptions;
  171. #ifndef _
  172. # if ENABLE_NLS
  173. # include <stdio.h>
  174. static inline char* aoGetsText( char const* pz ) {
  175. if (pz == NULL) return NULL;
  176. return (char*)gettext( pz );
  177. }
  178. # define _(s) aoGetsText(s)
  179. # else /* ENABLE_NLS */
  180. # define _(s) s
  181. # endif /* ENABLE_NLS */
  182. #endif
  183. #ifdef __cplusplus
  184. }
  185. #endif
  186. #endif /* AUTOOPTS_FLOWREPLAY_OPTS_H_GUARD */
  187. /* flowreplay_opts.h ends here */