parser_standard_options.c 14 KB

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