parser_standard_options.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454
  1. /*!
  2. * \file gis/parser_standard_options.c
  3. *
  4. * \brief GIS Library - Argument parsing functions (standard options)
  5. *
  6. * (C) 2001-2009 by the GRASS Development Team
  7. *
  8. * This program is free software under the GNU General Public License
  9. * (>=v2). Read the file COPYING that comes with GRASS for details.
  10. *
  11. * \author Original author CERL
  12. * \author Soeren Gebbert added Dec. 2009 WPS process_description document
  13. */
  14. #include "parser_local_proto.h"
  15. /*!
  16. * \brief Create standardised Option structure.
  17. *
  18. * This function will create a standardised Option structure defined
  19. * by parameter opt. A list of valid parameters can be found in gis.h.
  20. * It allocates memory for the Option structure and returns a pointer
  21. * to this memory.
  22. *
  23. * If an invalid parameter was specified a empty Option structure will
  24. * be returned (not NULL).
  25. *
  26. * - general:
  27. * - G_OPT_DB_WHERE
  28. * - G_OPT_DB_COLUMN
  29. * - G_OPT_DB_COLUMNS
  30. * - G_OPT_DB_TABLE
  31. * - G_OPT_DB_DRIVER
  32. * - G_OPT_DB_DATABASE
  33. * - G_OPT_DB_SCHEMA
  34. *
  35. * - imagery:
  36. * - G_OPT_I_GROUP
  37. * - G_OPT_I_SUBGROUP
  38. *
  39. * - raster:
  40. * - G_OPT_R_INPUT
  41. * - G_OPT_R_INPUTS
  42. * - G_OPT_R_OUTPUT
  43. * - G_OPT_R_MAP
  44. * - G_OPT_R_MAPS
  45. * - G_OPT_R_BASE
  46. * - G_OPT_R_COVER
  47. * - G_OPT_R_ELEV
  48. * - G_OPT_R_ELEVS
  49. *
  50. * - raster3d:
  51. * - G_OPT_R3_INPUT
  52. * - G_OPT_R3_INPUTS
  53. * - G_OPT_R3_OUTPUT
  54. * - G_OPT_R3_MAP
  55. * - G_OPT_R3_MAPS
  56. *
  57. * - vector:
  58. * - G_OPT_V_INPUT
  59. * - G_OPT_V_INPUTS
  60. * - G_OPT_V_OUTPUT
  61. * - G_OPT_V_MAP
  62. * - G_OPT_V_MAPS
  63. * - G_OPT_V_TYPE
  64. * - G_OPT_V_FIELD
  65. * - G_OPT_V_CAT
  66. * - G_OPT_V_CATS
  67. *
  68. * \param opt type of Option struct to create
  69. *
  70. * \return pointer to an Option struct
  71. */
  72. struct Option *G_define_standard_option(int opt)
  73. {
  74. struct Option *Opt;
  75. Opt = G_define_option();
  76. switch (opt) {
  77. case G_OPT_DB_WHERE:
  78. Opt->key = "where";
  79. Opt->type = TYPE_STRING;
  80. Opt->key_desc = "sql_query";
  81. Opt->required = NO;
  82. Opt->label = _("WHERE conditions of SQL statement without 'where' keyword");
  83. Opt->description = _("Example: income < 1000 and inhab >= 10000");
  84. break;
  85. case G_OPT_DB_TABLE:
  86. Opt->key = "table";
  87. Opt->type = TYPE_STRING;
  88. Opt->key_desc = "name";
  89. Opt->required = NO;
  90. Opt->multiple = NO;
  91. Opt->description = _("Table name");
  92. Opt->gisprompt = "old_dbtable,dbtable,dbtable";
  93. break;
  94. case G_OPT_DB_DRIVER:
  95. Opt->key = "driver";
  96. Opt->type = TYPE_STRING;
  97. Opt->key_desc = "name";
  98. Opt->required = NO;
  99. Opt->multiple = NO;
  100. Opt->description = _("Driver name");
  101. Opt->gisprompt = "old_dbdriver,dbdriver,dbdriver";
  102. break;
  103. case G_OPT_DB_DATABASE:
  104. Opt->key = "database";
  105. Opt->type = TYPE_STRING;
  106. Opt->key_desc = "name";
  107. Opt->required = NO;
  108. Opt->multiple = NO;
  109. Opt->description = _("Database name");
  110. Opt->gisprompt = "old_dbname,dbname,dbname";
  111. break;
  112. case G_OPT_DB_SCHEMA:
  113. Opt->key = "schema";
  114. Opt->type = TYPE_STRING;
  115. Opt->key_desc = "name";
  116. Opt->required = NO;
  117. Opt->multiple = NO;
  118. Opt->label = _("Database schema");
  119. Opt->description = _("Do not use this option if schemas "
  120. "are not supported by driver/database server");
  121. break;
  122. case G_OPT_DB_COLUMN:
  123. Opt->key = "column";
  124. Opt->type = TYPE_STRING;
  125. Opt->key_desc = "name";
  126. Opt->required = NO;
  127. Opt->multiple = NO;
  128. Opt->description = _("Name of attribute column");
  129. Opt->gisprompt = "old_dbcolumn,dbcolumn,dbcolumn";
  130. break;
  131. case G_OPT_DB_COLUMNS:
  132. Opt->key = "columns";
  133. Opt->type = TYPE_STRING;
  134. Opt->key_desc = "name";
  135. Opt->required = NO;
  136. Opt->multiple = YES;
  137. Opt->description = _("Name of attribute column(s)");
  138. Opt->gisprompt = "old_dbcolumn,dbcolumn,dbcolumn";
  139. break;
  140. /* imagery group */
  141. case G_OPT_I_GROUP:
  142. Opt->key = "group";
  143. Opt->type = TYPE_STRING;
  144. Opt->key_desc = "name";
  145. Opt->required = YES;
  146. Opt->gisprompt = "old,group,group";
  147. Opt->description = _("Name of input imagery group");
  148. break;
  149. case G_OPT_I_SUBGROUP:
  150. Opt->key = "subgroup";
  151. Opt->type = TYPE_STRING;
  152. Opt->key_desc = "name";
  153. Opt->required = YES;
  154. Opt->gisprompt = "old,subgroup,subgroup";
  155. Opt->description = _("Name of input imagery subgroup");
  156. break;
  157. /* raster maps */
  158. case G_OPT_R_INPUT:
  159. Opt->key = "input";
  160. Opt->type = TYPE_STRING;
  161. Opt->key_desc = "name";
  162. Opt->required = YES;
  163. Opt->gisprompt = "old,cell,raster";
  164. Opt->description = _("Name of input raster map");
  165. break;
  166. case G_OPT_R_INPUTS:
  167. Opt->key = "input";
  168. Opt->type = TYPE_STRING;
  169. Opt->key_desc = "name";
  170. Opt->required = YES;
  171. Opt->multiple = YES;
  172. Opt->gisprompt = "old,cell,raster";
  173. Opt->description = _("Name of input raster map(s)");
  174. break;
  175. case G_OPT_R_OUTPUT:
  176. Opt->key = "output";
  177. Opt->type = TYPE_STRING;
  178. Opt->key_desc = "name";
  179. Opt->required = YES;
  180. Opt->gisprompt = "new,cell,raster";
  181. Opt->description = _("Name for output raster map");
  182. break;
  183. case G_OPT_R_MAP:
  184. Opt->key = "map";
  185. Opt->type = TYPE_STRING;
  186. Opt->key_desc = "name";
  187. Opt->required = YES;
  188. Opt->gisprompt = "old,cell,raster";
  189. Opt->description = _("Name of input raster map");
  190. break;
  191. case G_OPT_R_MAPS:
  192. Opt->key = "map";
  193. Opt->type = TYPE_STRING;
  194. Opt->key_desc = "name";
  195. Opt->required = YES;
  196. Opt->multiple = YES;
  197. Opt->gisprompt = "old,cell,raster";
  198. Opt->description = _("Name of input raster map(s)");
  199. break;
  200. case G_OPT_R_BASE:
  201. Opt->key = "base";
  202. Opt->type = TYPE_STRING;
  203. Opt->key_desc = "name";
  204. Opt->required = YES;
  205. Opt->gisprompt = "old,cell,raster";
  206. Opt->description = _("Name of base raster map");
  207. break;
  208. case G_OPT_R_COVER:
  209. Opt->key = "cover";
  210. Opt->type = TYPE_STRING;
  211. Opt->key_desc = "name";
  212. Opt->required = YES;
  213. Opt->gisprompt = "old,cell,raster";
  214. Opt->description = _("Name of cover raster map");
  215. break;
  216. case G_OPT_R_ELEV:
  217. Opt->key = "elevation";
  218. Opt->type = TYPE_STRING;
  219. Opt->key_desc = "name";
  220. Opt->required = YES;
  221. Opt->gisprompt = "old,cell,raster";
  222. Opt->description = _("Name of elevation raster map");
  223. break;
  224. case G_OPT_R_ELEVS:
  225. Opt->key = "elevation";
  226. Opt->type = TYPE_STRING;
  227. Opt->key_desc = "name";
  228. Opt->required = YES;
  229. Opt->multiple = YES;
  230. Opt->gisprompt = "old,cell,raster";
  231. Opt->description = _("Name of elevation raster map(s)");
  232. break;
  233. /*g3d maps */
  234. case G_OPT_R3_INPUT:
  235. Opt->key = "input";
  236. Opt->type = TYPE_STRING;
  237. Opt->key_desc = "name";
  238. Opt->required = YES;
  239. Opt->gisprompt = "old,grid3,3d-raster";
  240. Opt->description = _("Name of input raster3d map");
  241. break;
  242. case G_OPT_R3_INPUTS:
  243. Opt->key = "input";
  244. Opt->type = TYPE_STRING;
  245. Opt->key_desc = "name";
  246. Opt->required = YES;
  247. Opt->multiple = YES;
  248. Opt->gisprompt = "old,grid3,3d-raster";
  249. Opt->description = _("Name of input raster3d map(s)");
  250. break;
  251. case G_OPT_R3_OUTPUT:
  252. Opt->key = "output";
  253. Opt->type = TYPE_STRING;
  254. Opt->key_desc = "name";
  255. Opt->required = YES;
  256. Opt->gisprompt = "new,grid3,3d-raster";
  257. Opt->description = _("Name for output raster3d map");
  258. break;
  259. case G_OPT_R3_MAP:
  260. Opt->key = "map";
  261. Opt->type = TYPE_STRING;
  262. Opt->key_desc = "name";
  263. Opt->required = YES;
  264. Opt->gisprompt = "old,grid3,3d-raster";
  265. Opt->description = _("Name of input raster3d map");
  266. break;
  267. case G_OPT_R3_MAPS:
  268. Opt->key = "map";
  269. Opt->type = TYPE_STRING;
  270. Opt->key_desc = "name";
  271. Opt->required = YES;
  272. Opt->multiple = YES;
  273. Opt->gisprompt = "old,grid3,3d-raster";
  274. Opt->description = _("Name of input raster3d map(s)");
  275. break;
  276. /*vector maps */
  277. case G_OPT_V_INPUT:
  278. Opt->key = "input";
  279. Opt->type = TYPE_STRING;
  280. Opt->key_desc = "name";
  281. Opt->required = YES;
  282. Opt->gisprompt = "old,vector,vector";
  283. Opt->label = _("Name of input vector map");
  284. Opt->description = _("Data source for OGR access");
  285. break;
  286. case G_OPT_V_INPUTS:
  287. Opt->key = "input";
  288. Opt->type = TYPE_STRING;
  289. Opt->key_desc = "name";
  290. Opt->required = YES;
  291. Opt->multiple = YES;
  292. Opt->gisprompt = "old,vector,vector";
  293. Opt->label = _("Name of input vector map(s)");
  294. Opt->description = _("Data source(s) for OGR access");
  295. break;
  296. case G_OPT_V_OUTPUT:
  297. Opt->key = "output";
  298. Opt->type = TYPE_STRING;
  299. Opt->key_desc = "name";
  300. Opt->required = YES;
  301. Opt->gisprompt = "new,vector,vector";
  302. Opt->description = _("Name for output vector map");
  303. break;
  304. case G_OPT_V_MAP:
  305. Opt->key = "map";
  306. Opt->type = TYPE_STRING;
  307. Opt->key_desc = "name";
  308. Opt->required = YES;
  309. Opt->gisprompt = "old,vector,vector";
  310. Opt->label = _("Name of input vector map");
  311. Opt->description = _("Data source for OGR access");
  312. break;
  313. case G_OPT_V_MAPS:
  314. Opt->key = "map";
  315. Opt->type = TYPE_STRING;
  316. Opt->key_desc = "name";
  317. Opt->required = YES;
  318. Opt->multiple = YES;
  319. Opt->gisprompt = "old,vector,vector";
  320. Opt->description = _("Name of input vector map(s)");
  321. break;
  322. case G_OPT_V_TYPE:
  323. Opt->key = "type";
  324. Opt->type = TYPE_STRING;
  325. Opt->required = NO;
  326. Opt->multiple = YES;
  327. Opt->answer = "point,line,boundary,centroid,area";
  328. Opt->options = "point,line,boundary,centroid,area";
  329. Opt->description = _("Feature type");
  330. break;
  331. case G_OPT_V3_TYPE:
  332. Opt->key = "type";
  333. Opt->type = TYPE_STRING;
  334. Opt->required = NO;
  335. Opt->multiple = YES;
  336. Opt->answer = "point,line,boundary,centroid,area,face,kernel";
  337. Opt->options = "point,line,boundary,centroid,area,face,kernel";
  338. Opt->description = _("Feature type");
  339. break;
  340. case G_OPT_V_FIELD:
  341. Opt->key = "layer";
  342. Opt->type = TYPE_STRING;
  343. Opt->required = NO;
  344. Opt->answer = "1";
  345. Opt->label = _("Layer number or name");
  346. Opt->description =
  347. _("A single vector map can be connected to multiple database "
  348. "tables. This number determines which table to use. "
  349. "Layer name for OGR access.");
  350. Opt->gisprompt = "old_layer,layer,layer";
  351. break;
  352. case G_OPT_V_FIELD_ALL:
  353. Opt->key = "layer";
  354. Opt->type = TYPE_STRING;
  355. Opt->required = NO;
  356. Opt->answer = "1";
  357. Opt->label = _("Layer number or name ('-1' for all layers)");
  358. Opt->description =
  359. _("A single vector map can be connected to multiple database "
  360. "tables. This number determines which table to use. "
  361. "Layer name for OGR access.");
  362. Opt->gisprompt = "old_layer,layer,layer_all";
  363. break;
  364. case G_OPT_V_CAT:
  365. Opt->key = "cat";
  366. Opt->type = TYPE_INTEGER;
  367. Opt->required = NO;
  368. Opt->description = _("Category value");
  369. break;
  370. case G_OPT_V_CATS:
  371. Opt->key = "cats";
  372. Opt->type = TYPE_STRING;
  373. Opt->key_desc = "range";
  374. Opt->required = NO;
  375. Opt->label = _("Category values");
  376. Opt->description = _("Example: 1,3,7-9,13");
  377. break;
  378. case G_OPT_V_ID:
  379. Opt->key = "id";
  380. Opt->type = TYPE_INTEGER;
  381. Opt->required = NO;
  382. Opt->description = _("Feature id");
  383. break;
  384. case G_OPT_V_IDS:
  385. Opt->key = "ids";
  386. Opt->type = TYPE_STRING;
  387. Opt->key_desc = "range";
  388. Opt->required = NO;
  389. Opt->label = _("Feature ids");
  390. Opt->description = _("Example: 1,3,7-9,13");
  391. break;
  392. /* files */
  393. case G_OPT_F_INPUT:
  394. Opt->key = "input";
  395. Opt->type = TYPE_STRING;
  396. Opt->key_desc = "name";
  397. Opt->required = YES;
  398. Opt->gisprompt = "old_file,file,input";
  399. Opt->description = _("Name of input file");
  400. break;
  401. case G_OPT_F_OUTPUT:
  402. Opt->key = "output";
  403. Opt->type = TYPE_STRING;
  404. Opt->key_desc = "name";
  405. Opt->required = YES;
  406. Opt->gisprompt = "new_file,file,output";
  407. Opt->description = _("Name for output file");
  408. break;
  409. case G_OPT_F_SEP:
  410. Opt->key = "fs";
  411. Opt->type = TYPE_STRING;
  412. Opt->key_desc = "character";
  413. Opt->required = NO;
  414. Opt->answer = "|";
  415. Opt->description = _("Field separator");
  416. break;
  417. /* colors */
  418. case G_OPT_C_FG:
  419. Opt->key = "color";
  420. Opt->type = TYPE_STRING;
  421. Opt->key_desc = "name";
  422. Opt->required = NO;
  423. Opt->answer = DEFAULT_FG_COLOR;
  424. Opt->gisprompt = "old_color,color,color";
  425. Opt->label = _("Color");
  426. Opt->description = _("Either a standard color name or R:G:B triplet");
  427. break;
  428. case G_OPT_C_BG:
  429. Opt->key = "bgcolor";
  430. Opt->type = TYPE_STRING;
  431. Opt->key_desc = "name";
  432. Opt->required = NO;
  433. Opt->answer = DEFAULT_BG_COLOR;
  434. Opt->gisprompt = "old_color,color,color_none";
  435. Opt->label = _("Background color");
  436. Opt->description =
  437. _("Either a standard GRASS color, R:G:B triplet, or \"none\"");
  438. break;
  439. }
  440. return (Opt);
  441. }