flowreplay_opts.h 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  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 Thursday July 28, 2005 at 09:54:29 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. * Enumeration of each option:
  50. */
  51. typedef enum {
  52. INDEX_OPT_DBUG = 0,
  53. INDEX_OPT_VERBOSE = 1,
  54. INDEX_OPT_DECODE = 2,
  55. INDEX_OPT_MODE = 3,
  56. INDEX_OPT_WAIT = 4,
  57. INDEX_OPT_TARGETIP = 5,
  58. INDEX_OPT_FILTER = 6,
  59. INDEX_OPT_CLIENTNET = 7,
  60. INDEX_OPT_SERVERNET = 8,
  61. INDEX_OPT_NOSYN = 9,
  62. INDEX_OPT_SLIMIT = 10,
  63. INDEX_OPT_VERSION = 11,
  64. INDEX_OPT_LESS_HELP = 12,
  65. INDEX_OPT_HELP = 13,
  66. INDEX_OPT_MORE_HELP = 14,
  67. INDEX_OPT_SAVE_OPTS = 15,
  68. INDEX_OPT_LOAD_OPTS = 16
  69. } teOptIndex;
  70. #define OPTION_CT 17
  71. /*
  72. * Interface defines for all options. Replace "n" with
  73. * the UPPER_CASED option name (as in the teOptIndex
  74. * enumeration above). e.g. HAVE_OPT( DBUG )
  75. */
  76. #define DESC(n) flowreplayOptions.pOptDesc[INDEX_OPT_ ## n]
  77. #define HAVE_OPT(n) (! UNUSED_OPT(& DESC(n)))
  78. #define OPT_ARG(n) (DESC(n).pzLastArg)
  79. #define STATE_OPT(n) (DESC(n).fOptState & OPTST_SET_MASK)
  80. #define COUNT_OPT(n) (DESC(n).optOccCt)
  81. #define ISSEL_OPT(n) (SELECTED_OPT(&DESC(n)))
  82. #define ISUNUSED_OPT(n) (UNUSED_OPT(& DESC(n)))
  83. #define ENABLED_OPT(n) (! DISABLED_OPT(& DESC(n)))
  84. #define STACKCT_OPT(n) (((tArgList*)(DESC(n).optCookie))->useCt)
  85. #define STACKLST_OPT(n) (((tArgList*)(DESC(n).optCookie))->apzArgs)
  86. #define CLEAR_OPT(n) STMTS( \
  87. DESC(n).fOptState &= OPTST_PERSISTENT; \
  88. if ( (DESC(n).fOptState & OPTST_INITENABLED) == 0) \
  89. DESC(n).fOptState |= OPTST_DISABLED; \
  90. DESC(n).optCookie = NULL )
  91. /*
  92. * Interface defines for specific options.
  93. */
  94. #define VALUE_OPT_DBUG 'd'
  95. #define OPT_VALUE_DBUG (*(unsigned long*)(&DESC(DBUG).pzLastArg))
  96. #ifdef HAVE_TCPDUMP
  97. #define VALUE_OPT_VERBOSE 'v'
  98. #define SET_OPT_VERBOSE STMTS( \
  99. DESC(VERBOSE).optActualIndex = 1; \
  100. DESC(VERBOSE).optActualValue = VALUE_OPT_VERBOSE; \
  101. DESC(VERBOSE).fOptState &= OPTST_PERSISTENT; \
  102. DESC(VERBOSE).fOptState |= OPTST_SET )
  103. #endif /* HAVE_TCPDUMP */
  104. #ifdef HAVE_TCPDUMP
  105. #define VALUE_OPT_DECODE 'A'
  106. #endif /* HAVE_TCPDUMP */
  107. #define VALUE_OPT_MODE 'm'
  108. #define VALUE_OPT_WAIT 'w'
  109. #define VALUE_OPT_TARGETIP 't'
  110. #define VALUE_OPT_FILTER 'f'
  111. #define VALUE_OPT_CLIENTNET 'c'
  112. #define VALUE_OPT_SERVERNET 's'
  113. #define VALUE_OPT_NOSYN 'n'
  114. #define VALUE_OPT_SLIMIT 'l'
  115. #define VALUE_OPT_VERSION 'V'
  116. #define VALUE_OPT_LESS_HELP 'h'
  117. #define VALUE_OPT_SAVE_OPTS INDEX_OPT_SAVE_OPTS
  118. #define VALUE_OPT_LOAD_OPTS INDEX_OPT_LOAD_OPTS
  119. #define VALUE_OPT_HELP 'H'
  120. #define VALUE_OPT_MORE_HELP '!'
  121. #define SET_OPT_SAVE_OPTS(a) STMTS( \
  122. DESC(SAVE_OPTS).fOptState &= OPTST_PERSISTENT; \
  123. DESC(SAVE_OPTS).fOptState |= OPTST_SET; \
  124. DESC(SAVE_OPTS).pzLastArg = (tCC*)(a) )
  125. /*
  126. * Interface defines not associated with particular options
  127. */
  128. #define ERRSKIP_OPTERR STMTS( flowreplayOptions.fOptSet &= ~OPTPROC_ERRSTOP )
  129. #define ERRSTOP_OPTERR STMTS( flowreplayOptions.fOptSet |= OPTPROC_ERRSTOP )
  130. #define RESTART_OPT(n) STMTS( \
  131. flowreplayOptions.curOptIdx = (n); \
  132. flowreplayOptions.pzCurOpt = NULL )
  133. #define START_OPT RESTART_OPT(1)
  134. #define USAGE(c) (*flowreplayOptions.pUsageProc)( &flowreplayOptions, c )
  135. /* extracted from /usr/local/share/autogen/opthead.tpl near line 246 */
  136. /* * * * * *
  137. *
  138. * Declare the flowreplay option descriptor.
  139. */
  140. #ifdef __cplusplus
  141. extern "C" {
  142. #endif
  143. extern tOptions flowreplayOptions;
  144. #ifndef _
  145. # if ENABLE_NLS
  146. # include <stdio.h>
  147. static inline char* aoGetsText( const char* pz ) {
  148. if (pz == NULL) return NULL;
  149. return (char*)gettext( pz );
  150. }
  151. # define _(s) aoGetsText(s)
  152. # else /* ENABLE_NLS */
  153. # define _(s) s
  154. # endif /* ENABLE_NLS */
  155. #endif
  156. #ifdef __cplusplus
  157. }
  158. #endif
  159. #endif /* AUTOOPTS_FLOWREPLAY_OPTS_H_GUARD */