testargdbl.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451
  1. /*******************************************************************************
  2. * This file is part of the argtable3 library.
  3. *
  4. * Copyright (C) 2013-2019 Tom G. Huang
  5. * <tomghuang@gmail.com>
  6. * All rights reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions are met:
  10. * * Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * * Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * * Neither the name of STEWART HEITMANN nor the names of its contributors
  16. * may be used to endorse or promote products derived from this software
  17. * without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  20. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  21. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  22. * ARE DISCLAIMED. IN NO EVENT SHALL STEWART HEITMANN BE LIABLE FOR ANY DIRECT,
  23. * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
  24. * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  25. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  26. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  28. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. ******************************************************************************/
  30. #include <float.h>
  31. #include <string.h>
  32. #include "CuTest.h"
  33. #include "argtable3.h"
  34. #if defined(_MSC_VER)
  35. #pragma warning(push)
  36. #pragma warning(disable : 4204)
  37. #endif
  38. void test_argdbl_basic_001(CuTest* tc) {
  39. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  40. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  41. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  42. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  43. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  44. struct arg_end* end = arg_end(20);
  45. void* argtable[] = {a, b, c, d, e, end};
  46. int nerrors;
  47. char* argv[] = {"program", "0", NULL};
  48. int argc = sizeof(argv) / sizeof(char*) - 1;
  49. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  50. nerrors = arg_parse(argc, argv, argtable);
  51. CuAssertTrue(tc, nerrors == 0);
  52. CuAssertTrue(tc, a->count == 1);
  53. CuAssertDblEquals(tc, a->dval[0], 0, DBL_EPSILON);
  54. CuAssertTrue(tc, b->count == 0);
  55. CuAssertTrue(tc, c->count == 0);
  56. CuAssertTrue(tc, d->count == 0);
  57. CuAssertTrue(tc, e->count == 0);
  58. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  59. }
  60. void test_argdbl_basic_002(CuTest* tc) {
  61. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  62. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  63. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  64. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  65. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  66. struct arg_end* end = arg_end(20);
  67. void* argtable[] = {a, b, c, d, e, end};
  68. int nerrors;
  69. char* argv[] = {"program", "1.234", NULL};
  70. int argc = sizeof(argv) / sizeof(char*) - 1;
  71. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  72. nerrors = arg_parse(argc, argv, argtable);
  73. CuAssertTrue(tc, nerrors == 0);
  74. CuAssertTrue(tc, a->count == 1);
  75. CuAssertDblEquals(tc, a->dval[0], 1.234, DBL_EPSILON);
  76. CuAssertTrue(tc, b->count == 0);
  77. CuAssertTrue(tc, c->count == 0);
  78. CuAssertTrue(tc, d->count == 0);
  79. CuAssertTrue(tc, e->count == 0);
  80. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  81. }
  82. void test_argdbl_basic_003(CuTest* tc) {
  83. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  84. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  85. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  86. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  87. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  88. struct arg_end* end = arg_end(20);
  89. void* argtable[] = {a, b, c, d, e, end};
  90. int nerrors;
  91. char* argv[] = {"program", "1.8", "2.3", NULL};
  92. int argc = sizeof(argv) / sizeof(char*) - 1;
  93. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  94. nerrors = arg_parse(argc, argv, argtable);
  95. CuAssertTrue(tc, nerrors == 0);
  96. CuAssertTrue(tc, a->count == 1);
  97. CuAssertDblEquals(tc, a->dval[0], 1.8, DBL_EPSILON);
  98. CuAssertTrue(tc, b->count == 1);
  99. CuAssertDblEquals(tc, b->dval[0], 2.3, DBL_EPSILON);
  100. CuAssertTrue(tc, c->count == 0);
  101. CuAssertTrue(tc, d->count == 0);
  102. CuAssertTrue(tc, e->count == 0);
  103. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  104. }
  105. void test_argdbl_basic_004(CuTest* tc) {
  106. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  107. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  108. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  109. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  110. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  111. struct arg_end* end = arg_end(20);
  112. void* argtable[] = {a, b, c, d, e, end};
  113. int nerrors;
  114. char* argv[] = {"program", "5", "7", "9", NULL};
  115. int argc = sizeof(argv) / sizeof(char*) - 1;
  116. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  117. nerrors = arg_parse(argc, argv, argtable);
  118. CuAssertTrue(tc, nerrors == 0);
  119. CuAssertTrue(tc, a->count == 1);
  120. CuAssertDblEquals(tc, a->dval[0], 5, DBL_EPSILON);
  121. CuAssertTrue(tc, b->count == 1);
  122. CuAssertDblEquals(tc, b->dval[0], 7, DBL_EPSILON);
  123. CuAssertTrue(tc, c->count == 1);
  124. CuAssertDblEquals(tc, c->dval[0], 9, DBL_EPSILON);
  125. CuAssertTrue(tc, d->count == 0);
  126. CuAssertTrue(tc, e->count == 0);
  127. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  128. }
  129. void test_argdbl_basic_005(CuTest* tc) {
  130. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  131. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  132. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  133. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  134. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  135. struct arg_end* end = arg_end(20);
  136. void* argtable[] = {a, b, c, d, e, end};
  137. int nerrors;
  138. char* argv[] = {"program", "1.9998", "-d", "13e-1", "-D", "17e-1", "--delta", "36e-1", NULL};
  139. int argc = sizeof(argv) / sizeof(char*) - 1;
  140. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  141. nerrors = arg_parse(argc, argv, argtable);
  142. CuAssertTrue(tc, nerrors == 0);
  143. CuAssertTrue(tc, a->count == 1);
  144. CuAssertDblEquals(tc, a->dval[0], 1.9998, DBL_EPSILON);
  145. CuAssertTrue(tc, b->count == 0);
  146. CuAssertTrue(tc, c->count == 0);
  147. CuAssertTrue(tc, d->count == 3);
  148. CuAssertDblEquals(tc, d->dval[0], 13e-1, DBL_EPSILON);
  149. CuAssertDblEquals(tc, d->dval[1], 17e-1, DBL_EPSILON);
  150. CuAssertDblEquals(tc, d->dval[2], 36e-1, DBL_EPSILON);
  151. CuAssertTrue(tc, e->count == 0);
  152. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  153. }
  154. void test_argdbl_basic_006(CuTest* tc) {
  155. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  156. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  157. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  158. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  159. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  160. struct arg_end* end = arg_end(20);
  161. void* argtable[] = {a, b, c, d, e, end};
  162. int nerrors;
  163. char* argv[] = {"program", "1.2", "2.3", "4.5", "--eps", "8.3456789", NULL};
  164. int argc = sizeof(argv) / sizeof(char*) - 1;
  165. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  166. nerrors = arg_parse(argc, argv, argtable);
  167. CuAssertTrue(tc, nerrors == 0);
  168. CuAssertTrue(tc, a->count == 1);
  169. CuAssertDblEquals(tc, a->dval[0], 1.2, DBL_EPSILON);
  170. CuAssertTrue(tc, b->count == 1);
  171. CuAssertDblEquals(tc, b->dval[0], 2.3, DBL_EPSILON);
  172. CuAssertTrue(tc, c->count == 1);
  173. CuAssertDblEquals(tc, c->dval[0], 4.5, DBL_EPSILON);
  174. CuAssertTrue(tc, d->count == 0);
  175. CuAssertTrue(tc, e->count == 1);
  176. CuAssertDblEquals(tc, e->dval[0], 8.3456789, DBL_EPSILON);
  177. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  178. }
  179. void test_argdbl_basic_007(CuTest* tc) {
  180. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  181. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  182. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  183. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  184. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  185. struct arg_end* end = arg_end(20);
  186. void* argtable[] = {a, b, c, d, e, end};
  187. int nerrors;
  188. char* argv[] = {"program", "1.2", "2.3", "4.5", "--eqn", "8.3456789", NULL};
  189. int argc = sizeof(argv) / sizeof(char*) - 1;
  190. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  191. nerrors = arg_parse(argc, argv, argtable);
  192. CuAssertTrue(tc, nerrors == 0);
  193. CuAssertTrue(tc, a->count == 1);
  194. CuAssertDblEquals(tc, a->dval[0], 1.2, DBL_EPSILON);
  195. CuAssertTrue(tc, b->count == 1);
  196. CuAssertDblEquals(tc, b->dval[0], 2.3, DBL_EPSILON);
  197. CuAssertTrue(tc, c->count == 1);
  198. CuAssertDblEquals(tc, c->dval[0], 4.5, DBL_EPSILON);
  199. CuAssertTrue(tc, d->count == 0);
  200. CuAssertTrue(tc, e->count == 1);
  201. CuAssertDblEquals(tc, e->dval[0], 8.3456789, DBL_EPSILON);
  202. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  203. }
  204. void test_argdbl_basic_008(CuTest* tc) {
  205. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  206. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  207. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  208. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  209. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  210. struct arg_end* end = arg_end(20);
  211. void* argtable[] = {a, b, c, d, e, end};
  212. int nerrors;
  213. char* argv[] = {"program", "1.2", "2.3", "4.5", "--eqn", "8.345", "-D", "0.234", NULL};
  214. int argc = sizeof(argv) / sizeof(char*) - 1;
  215. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  216. nerrors = arg_parse(argc, argv, argtable);
  217. CuAssertTrue(tc, nerrors == 0);
  218. CuAssertTrue(tc, a->count == 1);
  219. CuAssertDblEquals(tc, a->dval[0], 1.2, DBL_EPSILON);
  220. CuAssertTrue(tc, b->count == 1);
  221. CuAssertDblEquals(tc, b->dval[0], 2.3, DBL_EPSILON);
  222. CuAssertTrue(tc, c->count == 1);
  223. CuAssertDblEquals(tc, c->dval[0], 4.5, DBL_EPSILON);
  224. CuAssertTrue(tc, d->count == 1);
  225. CuAssertDblEquals(tc, d->dval[0], 0.234, DBL_EPSILON);
  226. CuAssertTrue(tc, e->count == 1);
  227. CuAssertDblEquals(tc, e->dval[0], 8.345, DBL_EPSILON);
  228. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  229. }
  230. void test_argdbl_basic_009(CuTest* tc) {
  231. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  232. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  233. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  234. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  235. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  236. struct arg_end* end = arg_end(20);
  237. void* argtable[] = {a, b, c, d, e, end};
  238. int nerrors;
  239. char* argv[] = {"program", "1", "2", "3", "4", NULL};
  240. int argc = sizeof(argv) / sizeof(char*) - 1;
  241. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  242. nerrors = arg_parse(argc, argv, argtable);
  243. CuAssertTrue(tc, nerrors == 1);
  244. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  245. }
  246. void test_argdbl_basic_010(CuTest* tc) {
  247. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  248. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  249. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  250. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  251. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  252. struct arg_end* end = arg_end(20);
  253. void* argtable[] = {a, b, c, d, e, end};
  254. int nerrors;
  255. char* argv[] = {"program", "1", "2", "3", "4", NULL};
  256. int argc = sizeof(argv) / sizeof(char*) - 1;
  257. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  258. nerrors = arg_parse(argc, argv, argtable);
  259. CuAssertTrue(tc, nerrors == 1);
  260. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  261. }
  262. void test_argdbl_basic_011(CuTest* tc) {
  263. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  264. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  265. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  266. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  267. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  268. struct arg_end* end = arg_end(20);
  269. void* argtable[] = {a, b, c, d, e, end};
  270. int nerrors;
  271. char* argv[] = {"program", "1", "2", "3", "-d1", "-d2", "-d3", "-d4", NULL};
  272. int argc = sizeof(argv) / sizeof(char*) - 1;
  273. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  274. nerrors = arg_parse(argc, argv, argtable);
  275. CuAssertTrue(tc, nerrors == 1);
  276. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  277. }
  278. void test_argdbl_basic_012(CuTest* tc) {
  279. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  280. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  281. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  282. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  283. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  284. struct arg_end* end = arg_end(20);
  285. void* argtable[] = {a, b, c, d, e, end};
  286. int nerrors;
  287. char* argv[] = {"program", "1", "2", "3", "--eps", NULL};
  288. int argc = sizeof(argv) / sizeof(char*) - 1;
  289. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  290. nerrors = arg_parse(argc, argv, argtable);
  291. CuAssertTrue(tc, nerrors == 1);
  292. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  293. }
  294. void test_argdbl_basic_013(CuTest* tc) {
  295. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  296. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  297. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  298. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  299. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  300. struct arg_end* end = arg_end(20);
  301. void* argtable[] = {a, b, c, d, e, end};
  302. int nerrors;
  303. char* argv[] = {"program", "1", "2", "3", "--eps", "3", "--eqn", "6", NULL};
  304. int argc = sizeof(argv) / sizeof(char*) - 1;
  305. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  306. nerrors = arg_parse(argc, argv, argtable);
  307. CuAssertTrue(tc, nerrors == 1);
  308. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  309. }
  310. void test_argdbl_basic_014(CuTest* tc) {
  311. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  312. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  313. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  314. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  315. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  316. struct arg_end* end = arg_end(20);
  317. void* argtable[] = {a, b, c, d, e, end};
  318. int nerrors;
  319. char* argv[] = {"program", "hello", NULL};
  320. int argc = sizeof(argv) / sizeof(char*) - 1;
  321. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  322. nerrors = arg_parse(argc, argv, argtable);
  323. CuAssertTrue(tc, nerrors == 1);
  324. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  325. }
  326. void test_argdbl_basic_015(CuTest* tc) {
  327. struct arg_dbl* a = arg_dbl1(NULL, NULL, "a", "a is <double>");
  328. struct arg_dbl* b = arg_dbl0(NULL, NULL, "b", "b is <double>");
  329. struct arg_dbl* c = arg_dbl0(NULL, NULL, "c", "c is <double>");
  330. struct arg_dbl* d = arg_dbln("dD", "delta", "<double>", 0, 3, "d can occur 0..3 times");
  331. struct arg_dbl* e = arg_dbl0(NULL, "eps,eqn", "<double>", "eps is optional");
  332. struct arg_end* end = arg_end(20);
  333. void* argtable[] = {a, b, c, d, e, end};
  334. int nerrors;
  335. char* argv[] = {"program", "4", "hello", NULL};
  336. int argc = sizeof(argv) / sizeof(char*) - 1;
  337. CuAssertTrue(tc, arg_nullcheck(argtable) == 0);
  338. nerrors = arg_parse(argc, argv, argtable);
  339. CuAssertTrue(tc, nerrors == 1);
  340. arg_freetable(argtable, sizeof(argtable) / sizeof(argtable[0]));
  341. }
  342. CuSuite* get_argdbl_testsuite() {
  343. CuSuite* suite = CuSuiteNew();
  344. SUITE_ADD_TEST(suite, test_argdbl_basic_001);
  345. SUITE_ADD_TEST(suite, test_argdbl_basic_002);
  346. SUITE_ADD_TEST(suite, test_argdbl_basic_003);
  347. SUITE_ADD_TEST(suite, test_argdbl_basic_004);
  348. SUITE_ADD_TEST(suite, test_argdbl_basic_005);
  349. SUITE_ADD_TEST(suite, test_argdbl_basic_006);
  350. SUITE_ADD_TEST(suite, test_argdbl_basic_007);
  351. SUITE_ADD_TEST(suite, test_argdbl_basic_008);
  352. SUITE_ADD_TEST(suite, test_argdbl_basic_009);
  353. SUITE_ADD_TEST(suite, test_argdbl_basic_010);
  354. SUITE_ADD_TEST(suite, test_argdbl_basic_011);
  355. SUITE_ADD_TEST(suite, test_argdbl_basic_012);
  356. SUITE_ADD_TEST(suite, test_argdbl_basic_013);
  357. SUITE_ADD_TEST(suite, test_argdbl_basic_014);
  358. SUITE_ADD_TEST(suite, test_argdbl_basic_015);
  359. return suite;
  360. }
  361. #if defined(_MSC_VER)
  362. #pragma warning(pop)
  363. #endif