Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

387 lines
10 KiB

  1. /*++
  2. UTEST.C
  3. Test program for the options subsystem. Must compile under
  4. NT and UNIX
  5. Created, 5/24/1997 by DavidCHR
  6. --*/
  7. #include "private.h"
  8. optEnumStruct enums[] = {
  9. { "one", (PVOID) 1, "should end up 1" },
  10. { "two", (PVOID) 2, "should end up 2" },
  11. { "beef", (PVOID)(UINT_PTR)(UINT) 0xdeadbeef, "should be 0xdeadbeef" },
  12. { "beefs", (PVOID)(UINT_PTR)(UINT) 0xbadf00d, "should be 0xbadf00d" },
  13. { "secret", (PVOID) 60, }, // shouldn't show in help
  14. TERMINATE_ARRAY
  15. };
  16. ULONG enumTestVariable=0;
  17. PCHAR SubString = NULL;
  18. optionStruct substructOptions[] = {
  19. { "h", NULL, OPT_HELP },
  20. { "substr", &SubString, OPT_STRING, "Substring option" },
  21. TERMINATE_ARRAY
  22. };
  23. PCHAR FuncString1 = NULL;
  24. PCHAR FuncString2 = NULL;
  25. PCHAR StringOption = NULL;
  26. int IntegerOption = 0L;
  27. BOOL BooleanOption = FALSE;
  28. float FloatOption = 0.0;
  29. PCHAR UndocumentedString = NULL;
  30. PWCHAR WideCharOption = NULL;
  31. UNICODE_STRING UnicodeStringOption = { 0 };
  32. int MyOptFunc( IN int argc,
  33. IN PCHAR *argv );
  34. BOOL MyOptFunc2( IN BOOL fHelp,
  35. IN POPT_FUNC_PARAMETER_DATA pData );
  36. optionStruct sampleOptions[ ] = {
  37. { "help", NULL, OPT_HELP },
  38. { "?", NULL, OPT_HELP },
  39. { NULL, NULL, OPT_DUMMY, "-----------------------------" },
  40. { NULL, NULL, OPT_CONTINUE, "These are the useful options:" },
  41. { NULL, NULL, OPT_DUMMY, "-----------------------------" },
  42. { "enum", &enumTestVariable, OPT_ENUMERATED,
  43. "Test enumerated type", enums },
  44. { "mask", &enumTestVariable, OPT_ENUMERATED | OPT_ENUM_IS_MASK,
  45. "Test enumerated type with OPT_ENUM_IS_MASK", enums },
  46. { "substruct", substructOptions, OPT_SUBOPTION | OPT_RECURSE,
  47. "substruct:help for help" },
  48. { "recurse", sampleOptions, OPT_SUBOPTION, "recurse:help for help" },
  49. { "string", &StringOption, OPT_STRING | OPT_ENVIRONMENT, "String Option",
  50. "StringOption" },
  51. { NULL, NULL, OPT_CONTINUE, "Use this option to request a string" },
  52. { "int", &IntegerOption, OPT_INT | OPT_ENVIRONMENT, "integer option",
  53. "IntegerOption" },
  54. { NULL, NULL, OPT_CONTINUE, "Use this option to request an integer" },
  55. { "func", MyOptFunc, OPT_FUNC, "function option" },
  56. { NULL, NULL, OPT_CONTINUE, "Use this option to request two strings" },
  57. { "func2", &IntegerOption, OPT_FUNC2, "FUNC2 option",
  58. MyOptFunc2 },
  59. { "bool", &BooleanOption, OPT_BOOL, "boolean option" },
  60. { NULL, NULL, OPT_CONTINUE, "Use this option to request a boolean" },
  61. { "float", &FloatOption, OPT_FLOAT, "floating point option" },
  62. { NULL, NULL, OPT_CONTINUE, "Use this option to request a float" },
  63. { "wstring",&WideCharOption, OPT_WSTRING | OPT_ENVIRONMENT,
  64. "Wide Char String option", "WideCharOption" },
  65. { "ustring",&UnicodeStringOption, OPT_USTRING | OPT_ENVIRONMENT,
  66. "Unicode String Option", "UnicodeStringOption" },
  67. { "hidden", &UndocumentedString, OPT_STRING | OPT_HIDDEN,
  68. "you should never see this line. This option is OPT_HIDDEN" },
  69. { "stop", NULL, OPT_STOP_PARSING,
  70. "halts parsing of the command line." },
  71. { NULL, NULL, OPT_DUMMY | OPT_NOHEADER, "" },
  72. { NULL, NULL, OPT_DUMMY | OPT_NOHEADER,
  73. "Example: utest /string \"foo bar baz\" /int 0x15 +bool /float 3.14" },
  74. { NULL, NULL, OPT_PAUSE },
  75. TERMINATE_ARRAY
  76. };
  77. int
  78. MyOptFunc( int argc,
  79. PCHAR *argv ) {
  80. if ( ( argv == NULL ) || (argc < 3 ) ) {
  81. /* this means the user requested help */
  82. fprintf( stderr, "func [string1] [string2]\n" );
  83. return 0;
  84. }
  85. printf( "MyOptFunc was called. argc=%d.\n", argc );
  86. FuncString1 = argv[1];
  87. FuncString2 = argv[2];
  88. return 3; /* number of arguments eaten--
  89. -func argv[1] argv[2] == 3 options */
  90. }
  91. VOID
  92. DumpArgs( int argc,
  93. PCHAR argv[] ) {
  94. int i;
  95. for ( i = 0 ; i < argc ; i++ ) {
  96. fprintf( stderr, "arg %d = %s\n", i, argv[i] );
  97. }
  98. }
  99. BOOL
  100. MyOptFunc2( IN BOOL fHelp,
  101. IN POPT_FUNC_PARAMETER_DATA pData ) {
  102. #if OPT_FUNC_PARAMETER_VERSION != 1
  103. #error "OptFuncParameterVersion has changed. Update this function."
  104. #endif
  105. optionStruct OptFunc2Options[] = {
  106. { "help", NULL, OPT_HELP },
  107. { "FuncString1", &FuncString1, OPT_INT },
  108. { "FuncString2", &FuncString2, OPT_INT },
  109. { "recurse", sampleOptions, OPT_SUBOPTION,
  110. "points back to the toplevel structure. Very amusing. :-)" },
  111. { "STOP", NULL, OPT_STOP_PARSING,
  112. "halts parsing within the Func2." },
  113. TERMINATE_ARRAY
  114. };
  115. if ( fHelp ) {
  116. CHAR buffer[ 255 ];
  117. PrintUsageEntry( stderr,
  118. "[-/+]", // switch characters
  119. pData->argv[0], // command GUARANTEED TO EXIST
  120. "->", // separator
  121. "Exercises the OPT_FUNC2 interface. Options follow",
  122. FALSE ); // FALSE--> do not repeat switch.
  123. sprintf( buffer, "-> options %s takes ", pData->argv[0] );
  124. PrintUsageEntry( stderr,
  125. NULL,
  126. NULL,
  127. "-=", // the NULLs will fill with this string.
  128. buffer,
  129. TRUE );
  130. sprintf( buffer, "(%s) ", pData->argv[0] );
  131. PrintUsage( stderr,
  132. 0L, // flags
  133. OptFunc2Options,
  134. buffer );
  135. PrintUsageEntry( stderr,
  136. NULL,
  137. NULL,
  138. "-*",
  139. "-> (end of OPT_FUNC2 options)",
  140. TRUE );
  141. return TRUE;
  142. } else {
  143. if ( pData->optionVersion != OPT_FUNC_PARAMETER_VERSION ) {
  144. fprintf( stderr,
  145. "WARNING: option library out of sync with header\n" );
  146. }
  147. fprintf( stderr,
  148. "MyOptFunc2 called. Data follows:\n"
  149. "pData->optionVersion = %d\n"
  150. "pData->dataField = 0x%p\n"
  151. "pData->argc = %d\n"
  152. "pData->argv = 0x%p\n"
  153. "pData->optionFlags = 0x%x\n"
  154. "pData->pSaveQueue = 0x%p\n",
  155. pData->optionVersion,
  156. pData->dataFieldPointer,
  157. pData->argc,
  158. pData->argv,
  159. pData->optionFlags,
  160. pData->pSaveQueue );
  161. fprintf( stderr, "%s arguments are:\n", pData->argv[0] );
  162. DumpArgs( pData->argc, pData->argv );
  163. if ( ParseOptionsEx( pData->argc-1,
  164. pData->argv+1,
  165. OptFunc2Options,
  166. pData->optionFlags,
  167. &pData->pSaveQueue,
  168. &pData->argsused,
  169. &pData->argv ) ) {
  170. fprintf( stderr,
  171. "pData->argsused IN = %d\n", pData->argsused );
  172. pData->argsused = pData->argc - pData->argsused;
  173. fprintf( stderr,
  174. "pData->argsused OUT = %d\n", pData->argsused );
  175. } else return FALSE;
  176. }
  177. fprintf( stderr, "\n Leaving OPT_FUNC2. \n\n" );
  178. return TRUE;
  179. }
  180. int
  181. __cdecl
  182. main( int argc,
  183. char *argv[] ) {
  184. BOOL foo;
  185. PVOID pCleanup = NULL;
  186. optEnumStruct parserOptions[] = {
  187. { "skip", (PVOID) OPT_FLAG_SKIP_UNKNOWNS,
  188. "OPT_FLAG_SKIP_UNKNOWNS" },
  189. { "reassemble", (PVOID) OPT_FLAG_REASSEMBLE,
  190. "OPT_FLAG_REASSEMBLE" },
  191. { "terminate", (PVOID) OPT_FLAG_TERMINATE,
  192. "OPT_FLAG_TERMINATE" },
  193. TERMINATE_ARRAY
  194. };
  195. ULONG ParserFlag = OPT_FLAG_REASSEMBLE;
  196. #ifndef DEBUG_OPTIONS
  197. BOOL DebugFlag = 0; // will be ignored... just here for convenience
  198. #endif
  199. optionStruct singleOption[] = {
  200. { "utestHelp", NULL, OPT_HELP },
  201. { "parserFlag", &ParserFlag, OPT_ENUMERATED,
  202. "flags to pass to ParseOptionsEx", parserOptions },
  203. { "headerlength", &OptMaxHeaderLength, OPT_INT,
  204. "OptMaxHeaderLength value (formatting)" },
  205. { "commandLength", &OptMaxCommandLength, OPT_INT,
  206. "OptMaxCommandLength value (formatting)" },
  207. { "separatorLength", &OptMaxSeparatorLength, OPT_INT,
  208. "OptMaxSeparatorLength value (formatting)" },
  209. { "descriptionLength", &OptMaxDescriptionLength, OPT_INT,
  210. "OptMaxDescriptionLength value (formatting)" },
  211. { "debug", &DebugFlag, OPT_INT, "Debugger status" },
  212. TERMINATE_ARRAY
  213. };
  214. DebugFlag |= OPTION_DEBUGGING_LEVEL;
  215. foo = ParseOptionsEx( argc-1, argv+1, singleOption,
  216. 0, &pCleanup, &argc, &argv );
  217. ParserFlag |= OPT_FLAG_MEMORYLIST_OK;
  218. fprintf( stderr,
  219. "first ParseOptionsEx returned 0x%x \n"
  220. " saveQueue 0x%p \n"
  221. " passing in flags 0x%x \n",
  222. foo, pCleanup, ParserFlag );
  223. if ( argc ) {
  224. ULONG i;
  225. fprintf( stderr, "%d new options: \n", argc );
  226. DumpArgs( argc, argv );
  227. fprintf( stderr, "\n" );
  228. }
  229. foo = ParseOptionsEx( argc, argv, sampleOptions, ParserFlag,
  230. &pCleanup, &argc, &argv );
  231. fprintf( stderr,
  232. "ParseOptionsEx returns %d\n"
  233. " new argv = 0x%p\n"
  234. " new argc = %d \n",
  235. foo, argv, argc );
  236. DumpArgs( argc, argv );
  237. printf( "Formatting values were:\n"
  238. "\tOptMaxHeaderLength = %d\n"
  239. "\tOptMaxCommandLength = %d\n"
  240. "\tOptMaxSeparatorLength = %d\n"
  241. "\tOptMaxDescriptionLength = %d\n",
  242. OptMaxHeaderLength,
  243. OptMaxCommandLength,
  244. OptMaxSeparatorLength,
  245. OptMaxDescriptionLength );
  246. printf( "\nOptions used:\n"
  247. "\tstring = \"%hs\"\n"
  248. "\tint = %d \n"
  249. "\tBool = 0x%x \n"
  250. /* "Float = %f \n" */
  251. "\twstring = L\"%ws\"\n"
  252. "\tustring = (unicode string) %wZ \n"
  253. "\thidden = \"%hs\"\n"
  254. "\tsubstruct:substr = \"%hs\"\n"
  255. "\tfuncString1 = \"%hs\"\n"
  256. "\tfuncString2 = \"%hs\"\n"
  257. "\tenum = %d (0x%x)\n",
  258. StringOption,
  259. IntegerOption,
  260. BooleanOption,
  261. /* FloatOption, */ /* floating point not loaded?
  262. What does that mean?! */
  263. WideCharOption,
  264. &UnicodeStringOption,
  265. UndocumentedString,
  266. SubString,
  267. FuncString1,
  268. FuncString2,
  269. enumTestVariable, enumTestVariable );
  270. CleanupOptionDataEx( pCleanup );
  271. return foo;
  272. }