parse_cl.cpp 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. /******************************************************************************
  2. **
  3. ** parse_cl.cpp
  4. **
  5. ** Thu Aug 6 19:42:25 2020
  6. ** Linux 5.4.0-42-generic (#46-Ubuntu SMP Fri Jul 10 00:24:02 UTC 2020) x86_64
  7. ** cerik@Erik-VBox-Ubuntu (Erik Cota-Robles)
  8. **
  9. ** Copyright (c) 2020 Erik Cota-Robles
  10. **
  11. ** Definition of command line parser class
  12. **
  13. ** Automatically created by genparse v0.9.3
  14. **
  15. ** See http://genparse.sourceforge.net for details and updates
  16. **
  17. **
  18. ******************************************************************************/
  19. #include <stdlib.h>
  20. #if defined(_WIN32) || defined(WIN32)
  21. #include "getopt.h"
  22. #else
  23. #include <getopt.h>
  24. #endif
  25. #include "parse_cl.h"
  26. /*----------------------------------------------------------------------------
  27. **
  28. ** Cmdline::Cmdline ()
  29. **
  30. ** Constructor method.
  31. **
  32. **--------------------------------------------------------------------------*/
  33. Cmdline::Cmdline (int argc, char *argv[]) // ISO C++17 not allowed: throw (std::string )
  34. {
  35. extern char *optarg;
  36. extern int optind;
  37. int c;
  38. static struct option long_options[] =
  39. {
  40. {"echo", no_argument, NULL, 'e'},
  41. {"noStun", no_argument, NULL, 'n'},
  42. {"stunServer", required_argument, NULL, 's'},
  43. {"stunPort", required_argument, NULL, 't'},
  44. {"webSocketServer", required_argument, NULL, 'w'},
  45. {"webSocketPort", required_argument, NULL, 'x'},
  46. {"help", no_argument, NULL, 'h'},
  47. {"version", no_argument, NULL, 'v'},
  48. {NULL, 0, NULL, 0}
  49. };
  50. _program_name += argv[0];
  51. /* default values */
  52. _e = false;
  53. _n = false;
  54. _s = "stun.l.google.com";
  55. _t = 19302;
  56. _w = "localhost";
  57. _x = 8000;
  58. _h = false;
  59. _v = false;
  60. optind = 0;
  61. while ((c = getopt_long (argc, argv, "s:t:w:x:enhv", long_options, &optind)) != - 1)
  62. {
  63. switch (c)
  64. {
  65. case 'e':
  66. _e = true;
  67. break;
  68. case 'n':
  69. _n = true;
  70. break;
  71. case 's':
  72. _s = optarg;
  73. break;
  74. case 't':
  75. _t = atoi (optarg);
  76. if (_t < 0)
  77. {
  78. std::string err;
  79. err += "parameter range error: t must be >= 0";
  80. throw (std::range_error(err));
  81. }
  82. if (_t > 65535)
  83. {
  84. std::string err;
  85. err += "parameter range error: t must be <= 65535";
  86. throw (std::range_error(err));
  87. }
  88. break;
  89. case 'w':
  90. _w = optarg;
  91. break;
  92. case 'x':
  93. _x = atoi (optarg);
  94. if (_x < 0)
  95. {
  96. std::string err;
  97. err += "parameter range error: x must be >= 0";
  98. throw (std::range_error(err));
  99. }
  100. if (_x > 65535)
  101. {
  102. std::string err;
  103. err += "parameter range error: x must be <= 65535";
  104. throw (std::range_error(err));
  105. }
  106. break;
  107. case 'h':
  108. _h = true;
  109. this->usage (EXIT_SUCCESS);
  110. break;
  111. case 'v':
  112. _v = true;
  113. this->version (EXIT_SUCCESS);
  114. break;
  115. default:
  116. this->usage (EXIT_FAILURE);
  117. }
  118. } /* while */
  119. _optind = optind;
  120. }
  121. /*----------------------------------------------------------------------------
  122. **
  123. ** Cmdline::usage () and version()
  124. **
  125. ** Print out usage (or version) information, then exit.
  126. **
  127. **--------------------------------------------------------------------------*/
  128. void Cmdline::usage (int status)
  129. {
  130. if (status != EXIT_SUCCESS)
  131. std::cerr << "Try `" << _program_name << " --help' for more information.\n";
  132. else
  133. {
  134. std::cout << "\
  135. usage: " << _program_name << " [ -enstwxhv ] \n\
  136. libdatachannel client implementing WebRTC Data Channels with WebSocket signaling\n\
  137. [ -e ] [ --echo ] (type=FLAG)\n\
  138. Echo data channel messages back to sender rather than putting to stdout.\n\
  139. [ -n ] [ --noStun ] (type=FLAG)\n\
  140. Do NOT use a stun server (overrides -s and -t).\n\
  141. [ -s ] [ --stunServer ] (type=STRING, default=stun.l.google.com)\n\
  142. Stun server URL or IP address.\n\
  143. [ -t ] [ --stunPort ] (type=INTEGER, range=0...65535, default=19302)\n\
  144. Stun server port.\n\
  145. [ -w ] [ --webSocketServer ] (type=STRING, default=localhost)\n\
  146. Web socket server URL or IP address.\n\
  147. [ -x ] [ --webSocketPort ] (type=INTEGER, range=0...65535, default=8000)\n\
  148. Web socket server port.\n\
  149. [ -h ] [ --help ] (type=FLAG)\n\
  150. Display this help and exit.\n\
  151. [ -v ] [ --version ] (type=FLAG)\n\
  152. Output version information and exit.\n";
  153. }
  154. exit (status);
  155. }
  156. void Cmdline::version (int status)
  157. {
  158. std::cout << _program_name << " v0.5\n";
  159. exit (status);
  160. }