parser_standard_options.c 14 KB

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