flowreplay_opts.h 6.9 KB

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