parser_standard_options.c 16 KB

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