args.c 41 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124
  1. /*!
  2. \file args.c
  3. \brief Parse command
  4. (C) 2008, 2010-2011 by the GRASS Development Team
  5. This program is free software under the GNU General Public
  6. License (>=v2). Read the file COPYING that comes with GRASS
  7. for details.
  8. \author Martin Landa <landa.martin gmail.com> (Google SoC 2008/2010)
  9. */
  10. #include <stdlib.h>
  11. #include <string.h>
  12. #include <grass/gis.h>
  13. #include <grass/glocale.h>
  14. #include "local_proto.h"
  15. static void print_error(int, int, int,
  16. const char *, const char *,
  17. const char *, const char *);
  18. static void args_surface(struct GParams *);
  19. static void args_vline(struct GParams *);
  20. static void args_vpoint(struct GParams *);
  21. static void args_viewpoint(struct GParams *);
  22. static void args_volume(struct GParams *);
  23. static void args_lighting(struct GParams *);
  24. static void args_fringe(struct GParams *);
  25. static void args_cplane(struct GParams *);
  26. static void args_arrow(struct GParams *);
  27. /*!
  28. \brief Parse command
  29. \param argc number of arguments
  30. \param argv arguments array
  31. \param params GRASS parameters
  32. \return 1
  33. */
  34. void parse_command(int argc, char *argv[], struct GParams *params)
  35. {
  36. params->mode_all = G_define_flag();
  37. params->mode_all->key = 'a';
  38. params->mode_all->description =
  39. _("Use draw mode for all loaded surfaces");
  40. params->mode_all->guisection = _("Surfaces");
  41. /*** surface attributes ***/
  42. args_surface(params);
  43. /*** vector lines ***/
  44. args_vline(params);
  45. /*** vector points ***/
  46. args_vpoint(params);
  47. /*** volumes ***/
  48. args_volume(params);
  49. /*** misc ***/
  50. /* background color */
  51. params->bgcolor = G_define_standard_option(G_OPT_C_BG);
  52. /*** viewpoint ***/
  53. args_viewpoint(params);
  54. /*** lighting ***/
  55. args_lighting(params);
  56. /*** fringe ***/
  57. args_fringe(params);
  58. /*** cutting plane ***/
  59. args_cplane(params);
  60. /*** north arrow ***/
  61. args_arrow(params);
  62. /*** output image ***/
  63. /* output */
  64. params->output = G_define_standard_option(G_OPT_F_OUTPUT);
  65. params->output->description =
  66. _("Name for output image file (without extension)");
  67. params->output->guisection = _("Image");
  68. /* format */
  69. params->format = G_define_option();
  70. params->format->key = "format";
  71. params->format->type = TYPE_STRING;
  72. #ifdef HAVE_TIFFIO_H
  73. params->format->options = "ppm,tif"; /* TODO: png */
  74. #else
  75. params->format->options = "ppm";
  76. #endif
  77. params->format->answer = "ppm";
  78. params->format->description = _("Graphics file format");
  79. params->format->required = YES;
  80. params->format->guisection = _("Image");
  81. /* size */
  82. params->size = G_define_option();
  83. params->size->key = "size";
  84. params->size->type = TYPE_INTEGER;
  85. params->size->key_desc = "width,height";
  86. params->size->answer = "640,480";
  87. params->size->description = _("Size (width, height) of output image");
  88. params->size->required = YES;
  89. params->size->guisection = _("Image");
  90. if (G_parser(argc, argv))
  91. exit(EXIT_FAILURE);
  92. return;
  93. }
  94. void args_surface(struct GParams *params)
  95. {
  96. /* topography */
  97. params->elev_map = G_define_standard_option(G_OPT_R_ELEV);
  98. params->elev_map->key = "elevation_map";
  99. params->elev_map->required = NO;
  100. params->elev_map->multiple = YES;
  101. params->elev_map->description = _("Name of raster map(s) for elevation");
  102. params->elev_map->guisection = _("Surfaces");
  103. params->elev_const = G_define_option();
  104. params->elev_const->key = "elevation_value";
  105. params->elev_const->key_desc = "value";
  106. params->elev_const->type = TYPE_INTEGER;
  107. params->elev_const->required = NO;
  108. params->elev_const->multiple = YES;
  109. params->elev_const->description = _("Elevation value(s)");
  110. params->elev_const->guisection = _("Surfaces");
  111. /* color */
  112. params->color_map = G_define_standard_option(G_OPT_R_MAP);
  113. params->color_map->multiple = YES;
  114. params->color_map->required = NO;
  115. params->color_map->description = _("Name of raster map(s) for color");
  116. params->color_map->guisection = _("Surfaces");
  117. params->color_map->key = "color_map";
  118. params->color_const = G_define_standard_option(G_OPT_C_FG);
  119. params->color_const->multiple = YES;
  120. params->color_const->label = _("Color value(s)");
  121. params->color_const->guisection = _("Surfaces");
  122. params->color_const->answer = NULL;
  123. /* mask */
  124. params->mask_map = G_define_standard_option(G_OPT_R_MAP);
  125. params->mask_map->multiple = YES;
  126. params->mask_map->required = NO;
  127. params->mask_map->description = _("Name of raster map(s) for mask");
  128. params->mask_map->guisection = _("Surfaces");
  129. params->mask_map->key = "mask_map";
  130. /* transparency */
  131. params->transp_map = G_define_standard_option(G_OPT_R_MAP);
  132. params->transp_map->multiple = YES;
  133. params->transp_map->required = NO;
  134. params->transp_map->description =
  135. _("Name of raster map(s) for transparency");
  136. params->transp_map->guisection = _("Surfaces");
  137. params->transp_map->key = "transparency_map";
  138. params->transp_const = G_define_option();
  139. params->transp_const->key = "transparency_value";
  140. params->transp_const->key_desc = "value";
  141. params->transp_const->type = TYPE_INTEGER;
  142. params->transp_const->required = NO;
  143. params->transp_const->multiple = YES;
  144. params->transp_const->description = _("Transparency value(s)");
  145. params->transp_const->guisection = _("Surfaces");
  146. params->transp_const->options = "0-255";
  147. /* shininess */
  148. params->shine_map = G_define_standard_option(G_OPT_R_MAP);
  149. params->shine_map->multiple = YES;
  150. params->shine_map->required = NO;
  151. params->shine_map->description = _("Name of raster map(s) for shininess");
  152. params->shine_map->guisection = _("Surfaces");
  153. params->shine_map->key = "shininess_map";
  154. params->shine_const = G_define_option();
  155. params->shine_const->key = "shininess_value";
  156. params->shine_const->key_desc = "value";
  157. params->shine_const->type = TYPE_INTEGER;
  158. params->shine_const->required = NO;
  159. params->shine_const->multiple = YES;
  160. params->shine_const->description = _("Shininess value(s)");
  161. params->shine_const->guisection = _("Surfaces");
  162. params->shine_const->options = "0-255";
  163. /* emission */
  164. params->emit_map = G_define_standard_option(G_OPT_R_MAP);
  165. params->emit_map->multiple = YES;
  166. params->emit_map->required = NO;
  167. params->emit_map->description = _("Name of raster map(s) for emission");
  168. params->emit_map->guisection = _("Surfaces");
  169. params->emit_map->key = "emission_map";
  170. params->emit_const = G_define_option();
  171. params->emit_const->key = "emission_value";
  172. params->emit_const->key_desc = "value";
  173. params->emit_const->type = TYPE_INTEGER;
  174. params->emit_const->required = NO;
  175. params->emit_const->multiple = YES;
  176. params->emit_const->description = _("Emission value(s)");
  177. params->emit_const->guisection = _("Surfaces");
  178. params->emit_const->options = "0-255";
  179. /*
  180. draw
  181. */
  182. /* mode */
  183. params->mode = G_define_option();
  184. params->mode->key = "mode";
  185. params->mode->key_desc = "string";
  186. params->mode->type = TYPE_STRING;
  187. params->mode->required = NO;
  188. params->mode->multiple = YES;
  189. params->mode->description = _("Draw mode");
  190. params->mode->options = "coarse,fine,both";
  191. params->mode->answer = "fine";
  192. params->mode->guisection = _("Draw");
  193. /* resolution fine */
  194. params->res_fine = G_define_option();
  195. params->res_fine->key = "resolution_fine";
  196. params->res_fine->key_desc = "value";
  197. params->res_fine->type = TYPE_INTEGER;
  198. params->res_fine->required = NO;
  199. params->res_fine->multiple = YES;
  200. params->res_fine->description = _("Fine resolution");
  201. params->res_fine->answer = "6";
  202. params->res_fine->guisection = _("Draw");
  203. /* resolution coarse */
  204. params->res_coarse = G_define_option();
  205. params->res_coarse->key = "resolution_coarse";
  206. params->res_coarse->key_desc = "value";
  207. params->res_coarse->type = TYPE_INTEGER;
  208. params->res_coarse->required = NO;
  209. params->res_coarse->multiple = YES;
  210. params->res_coarse->description = _("Coarse resolution");
  211. params->res_coarse->answer = "9";
  212. params->res_coarse->guisection = _("Draw");
  213. /* style */
  214. params->style = G_define_option();
  215. params->style->key = "style";
  216. params->style->key_desc = "string";
  217. params->style->type = TYPE_STRING;
  218. params->style->required = NO;
  219. params->style->multiple = YES;
  220. params->style->description = _("Draw style");
  221. params->style->options = "wire,surface";
  222. params->style->answer = "surface";
  223. params->style->guisection = _("Draw");
  224. /* shading */
  225. params->shade = G_define_option();
  226. params->shade->key = "shading";
  227. params->shade->key_desc = "string";
  228. params->shade->type = TYPE_STRING;
  229. params->shade->required = NO;
  230. params->shade->multiple = YES;
  231. params->shade->description = _("Shading");
  232. params->shade->options = "flat,gouraud";
  233. params->shade->answer = "gouraud";
  234. params->shade->guisection = _("Draw");
  235. /* wire color */
  236. params->wire_color = G_define_standard_option(G_OPT_C_FG);
  237. params->wire_color->multiple = YES;
  238. params->wire_color->required = NO;
  239. params->wire_color->label = _("Wire color");
  240. params->wire_color->key = "wire_color";
  241. params->wire_color->answer = "136:136:136";
  242. params->wire_color->guisection = _("Draw");
  243. /* position */
  244. params->surface_pos = G_define_option();
  245. params->surface_pos->key = "surface_position";
  246. params->surface_pos->key_desc = "x,y,z";
  247. params->surface_pos->type = TYPE_INTEGER;
  248. params->surface_pos->required = NO;
  249. params->surface_pos->multiple = YES;
  250. params->surface_pos->description = _("Surface position");
  251. params->surface_pos->guisection = _("Draw");
  252. params->surface_pos->answer = "0,0,0";
  253. return;
  254. }
  255. void args_vline(struct GParams *params)
  256. {
  257. params->vlines = G_define_standard_option(G_OPT_V_MAP);
  258. params->vlines->multiple = YES;
  259. params->vlines->required = NO;
  260. params->vlines->description = _("Name of line vector overlay map(s)");
  261. params->vlines->guisection = _("Vector lines");
  262. params->vlines->key = "vline";
  263. params->vline_layer = G_define_standard_option(G_OPT_V_FIELD);
  264. params->vline_layer->multiple = YES;
  265. params->vline_layer->required = NO;
  266. params->vline_layer->description = _("Layer number or name for thematic mapping");
  267. params->vline_layer->guisection = _("Vector lines");
  268. params->vline_layer->key = "vline_layer";
  269. params->vline_layer->answer = "1";
  270. /* line width */
  271. params->vline_width = G_define_option();
  272. params->vline_width->key = "vline_width";
  273. params->vline_width->key_desc = "value";
  274. params->vline_width->type = TYPE_INTEGER;
  275. params->vline_width->required = NO;
  276. params->vline_width->multiple = YES;
  277. params->vline_width->description = _("Vector line width");
  278. params->vline_width->guisection = _("Vector lines");
  279. params->vline_width->options = "1-100";
  280. params->vline_width->answer = "2";
  281. params->vline_width_column = G_define_standard_option(G_OPT_DB_COLUMN);
  282. params->vline_width_column->multiple = YES;
  283. params->vline_width_column->required = NO;
  284. params->vline_width_column->label = _("Name of width definition column");
  285. params->vline_width_column->key = "vline_width_column";
  286. params->vline_width_column->guisection = _("Vector lines");
  287. /* line color */
  288. params->vline_color = G_define_standard_option(G_OPT_C_FG);
  289. params->vline_color->multiple = YES;
  290. params->vline_color->required = NO;
  291. params->vline_color->label = _("Vector line color");
  292. params->vline_color->key = "vline_color";
  293. params->vline_color->answer = "blue";
  294. params->vline_color->guisection = _("Vector lines");
  295. params->vline_color_column = G_define_standard_option(G_OPT_DB_COLUMN);
  296. params->vline_color_column->multiple = YES;
  297. params->vline_color_column->required = NO;
  298. params->vline_color_column->label = _("Name of color definition column");
  299. params->vline_color_column->key = "vline_color_column";
  300. params->vline_color_column->guisection = _("Vector lines");
  301. /* line mode */
  302. params->vline_mode = G_define_option();
  303. params->vline_mode->key = "vline_mode";
  304. params->vline_mode->key_desc = "string";
  305. params->vline_mode->type = TYPE_STRING;
  306. params->vline_mode->required = NO;
  307. params->vline_mode->multiple = YES;
  308. params->vline_mode->description = _("Vector line display mode");
  309. params->vline_mode->options = "surface,flat";
  310. params->vline_mode->answer = "surface";
  311. params->vline_mode->guisection = _("Vector lines");
  312. /* line height */
  313. params->vline_height = G_define_option();
  314. params->vline_height->key = "vline_height";
  315. params->vline_height->key_desc = "value";
  316. params->vline_height->type = TYPE_INTEGER;
  317. params->vline_height->required = NO;
  318. params->vline_height->multiple = YES;
  319. params->vline_height->description = _("Vector line height");
  320. params->vline_height->guisection = _("Vector lines");
  321. params->vline_height->options = "0-1000";
  322. params->vline_height->answer = "0";
  323. /* position */
  324. params->vline_pos = G_define_option();
  325. params->vline_pos->key = "vline_position";
  326. params->vline_pos->key_desc = "x,y,z";
  327. params->vline_pos->type = TYPE_INTEGER;
  328. params->vline_pos->required = NO;
  329. params->vline_pos->multiple = YES;
  330. params->vline_pos->description = _("Vector lines position");
  331. params->vline_pos->guisection = _("Vector lines");
  332. params->vline_pos->answer = "0,0,0";
  333. return;
  334. }
  335. void args_vpoint(struct GParams *params)
  336. {
  337. params->vpoints = G_define_standard_option(G_OPT_V_MAP);
  338. params->vpoints->multiple = YES;
  339. params->vpoints->required = NO;
  340. params->vpoints->description = _("Name of point vector overlay map(s)");
  341. params->vpoints->guisection = _("Vector points");
  342. params->vpoints->key = "vpoint";
  343. params->vpoint_layer = G_define_standard_option(G_OPT_V_FIELD);
  344. params->vpoint_layer->multiple = YES;
  345. params->vpoint_layer->required = NO;
  346. params->vpoint_layer->description = _("Layer number or name for thematic mapping");
  347. params->vpoint_layer->guisection = _("Vector points");
  348. params->vpoint_layer->key = "vpoint_layer";
  349. params->vpoint_layer->answer = "1";
  350. /* point width */
  351. params->vpoint_size = G_define_option();
  352. params->vpoint_size->key = "vpoint_size";
  353. params->vpoint_size->key_desc = "value";
  354. params->vpoint_size->type = TYPE_INTEGER;
  355. params->vpoint_size->required = NO;
  356. params->vpoint_size->multiple = YES;
  357. params->vpoint_size->description = _("Icon size");
  358. params->vpoint_size->guisection = _("Vector points");
  359. params->vpoint_size->options = "1-1000";
  360. params->vpoint_size->answer = "100";
  361. params->vpoint_size_column = G_define_standard_option(G_OPT_DB_COLUMN);
  362. params->vpoint_size_column->multiple = YES;
  363. params->vpoint_size_column->required = NO;
  364. params->vpoint_size_column->label = _("Name of size definition column");
  365. params->vpoint_size_column->key = "vpoint_size_column";
  366. params->vpoint_size_column->guisection = _("Vector points");
  367. /* point width */
  368. params->vpoint_width = G_define_option();
  369. params->vpoint_width->key = "vpoint_width";
  370. params->vpoint_width->key_desc = "value";
  371. params->vpoint_width->type = TYPE_INTEGER;
  372. params->vpoint_width->required = NO;
  373. params->vpoint_width->multiple = YES;
  374. params->vpoint_width->description = _("Icon width");
  375. params->vpoint_width->guisection = _("Vector points");
  376. params->vpoint_width->options = "1-1000";
  377. params->vpoint_width->answer = "2";
  378. params->vpoint_width_column = G_define_standard_option(G_OPT_DB_COLUMN);
  379. params->vpoint_width_column->multiple = YES;
  380. params->vpoint_width_column->required = NO;
  381. params->vpoint_width_column->label = _("Name of width definition column");
  382. params->vpoint_width_column->key = "vpoint_width_column";
  383. params->vpoint_width_column->guisection = _("Vector points");
  384. /* point color */
  385. params->vpoint_color = G_define_standard_option(G_OPT_C_FG);
  386. params->vpoint_color->multiple = YES;
  387. params->vpoint_color->required = NO;
  388. params->vpoint_color->label = _("Icon color");
  389. params->vpoint_color->key = "vpoint_color";
  390. params->vpoint_color->answer = "blue";
  391. params->vpoint_color->guisection = _("Vector points");
  392. params->vpoint_color_column = G_define_standard_option(G_OPT_DB_COLUMN);
  393. params->vpoint_color_column->multiple = YES;
  394. params->vpoint_color_column->required = NO;
  395. params->vpoint_color_column->label = _("Name of color definition column");
  396. params->vpoint_color_column->key = "vpoint_color_column";
  397. params->vpoint_color_column->guisection = _("Vector points");
  398. /* point mode */
  399. params->vpoint_marker = G_define_option();
  400. params->vpoint_marker->key = "vpoint_marker";
  401. params->vpoint_marker->key_desc = "string";
  402. params->vpoint_marker->type = TYPE_STRING;
  403. params->vpoint_marker->required = NO;
  404. params->vpoint_marker->multiple = YES;
  405. params->vpoint_marker->description = _("Icon marker");
  406. params->vpoint_marker->options =
  407. "x,box,sphere,cube,diamond,dec_tree,con_tree,aster,gyro,histogram";
  408. params->vpoint_marker->answer = "sphere";
  409. params->vpoint_marker->guisection = _("Vector points");
  410. params->vpoint_marker_column = G_define_standard_option(G_OPT_DB_COLUMN);
  411. params->vpoint_marker_column->multiple = YES;
  412. params->vpoint_marker_column->required = NO;
  413. params->vpoint_marker_column->label = _("Name of marker definition column");
  414. params->vpoint_marker_column->key = "vpoint_marker_column";
  415. params->vpoint_marker_column->guisection = _("Vector points");
  416. /* position */
  417. params->vpoint_pos = G_define_option();
  418. params->vpoint_pos->key = "vpoint_position";
  419. params->vpoint_pos->key_desc = "x,y,z";
  420. params->vpoint_pos->type = TYPE_INTEGER;
  421. params->vpoint_pos->required = NO;
  422. params->vpoint_pos->multiple = YES;
  423. params->vpoint_pos->description = _("Vector points position");
  424. params->vpoint_pos->guisection = _("Vector points");
  425. params->vpoint_pos->answer = "0,0,0";
  426. return;
  427. }
  428. void args_viewpoint(struct GParams *params)
  429. {
  430. /* position */
  431. params->pos = G_define_option();
  432. params->pos->key = "position";
  433. params->pos->key_desc = "x,y";
  434. params->pos->type = TYPE_DOUBLE;
  435. params->pos->required = NO;
  436. params->pos->multiple = NO;
  437. params->pos->description =
  438. _("Viewpoint position (x,y model coordinates)");
  439. params->pos->guisection = _("Viewpoint");
  440. params->pos->answer = "0.84,0.16";
  441. /* height */
  442. params->height = G_define_option();
  443. params->height->key = "height";
  444. params->height->key_desc = "value";
  445. params->height->type = TYPE_INTEGER;
  446. params->height->required = NO;
  447. params->height->multiple = NO;
  448. params->height->description = _("Viewpoint height (in map units)");
  449. params->height->guisection = _("Viewpoint");
  450. /* perspective */
  451. params->persp = G_define_option();
  452. params->persp->key = "perspective";
  453. params->persp->key_desc = "value";
  454. params->persp->type = TYPE_INTEGER;
  455. params->persp->required = NO;
  456. params->persp->multiple = NO;
  457. params->persp->description = _("Viewpoint field of view (in degrees)");
  458. params->persp->guisection = _("Viewpoint");
  459. params->persp->answer = "40";
  460. params->persp->options = "1-100";
  461. /* twist */
  462. params->twist = G_define_option();
  463. params->twist->key = "twist";
  464. params->twist->key_desc = "value";
  465. params->twist->type = TYPE_INTEGER;
  466. params->twist->required = NO;
  467. params->twist->multiple = NO;
  468. params->twist->description = _("Viewpoint twist angle (in degrees)");
  469. params->twist->guisection = _("Viewpoint");
  470. params->twist->answer = "0";
  471. params->twist->options = "-180-180";
  472. /* z-exag */
  473. params->exag = G_define_option();
  474. params->exag->key = "zexag";
  475. params->exag->key_desc = "value";
  476. params->exag->type = TYPE_DOUBLE;
  477. params->exag->required = NO;
  478. params->exag->multiple = NO;
  479. params->exag->description = _("Vertical exaggeration");
  480. /* focus */
  481. params->focus = G_define_option();
  482. params->focus->key = "focus";
  483. params->focus->key_desc = "x,y,z";
  484. params->focus->type = TYPE_DOUBLE;
  485. params->focus->required = NO;
  486. params->focus->multiple = NO;
  487. params->focus->description = _("Focus to point on surface (from SW corner in map units)");
  488. params->focus->guisection = _("Viewpoint");
  489. return;
  490. }
  491. void args_volume(struct GParams *params)
  492. {
  493. params->volume = G_define_standard_option(G_OPT_R3_MAPS);
  494. params->volume->required = NO;
  495. params->volume->guisection = _("Volumes");
  496. params->volume->key = "volume";
  497. /* mode */
  498. params->volume_mode = G_define_option();
  499. params->volume_mode->key = "volume_mode";
  500. params->volume_mode->key_desc = "string";
  501. params->volume_mode->type = TYPE_STRING;
  502. params->volume_mode->required = NO;
  503. params->volume_mode->multiple = YES;
  504. params->volume_mode->description = _("Volume draw mode");
  505. params->volume_mode->options = "isosurface,slice";
  506. params->volume_mode->answer = "isosurface";
  507. params->volume_mode->guisection = _("Draw");
  508. /* shading */
  509. params->volume_shade = G_define_option();
  510. params->volume_shade->key = "volume_shading";
  511. params->volume_shade->key_desc = "string";
  512. params->volume_shade->type = TYPE_STRING;
  513. params->volume_shade->required = NO;
  514. params->volume_shade->multiple = YES;
  515. params->volume_shade->description = _("Volume shading");
  516. params->volume_shade->options = "flat,gouraud";
  517. params->volume_shade->answer = "gouraud";
  518. params->volume_shade->guisection = _("Draw");
  519. /* position */
  520. params->volume_pos = G_define_option();
  521. params->volume_pos->key = "volume_position";
  522. params->volume_pos->key_desc = "x,y,z";
  523. params->volume_pos->type = TYPE_INTEGER;
  524. params->volume_pos->required = NO;
  525. params->volume_pos->multiple = YES;
  526. params->volume_pos->description = _("Volume position");
  527. params->volume_pos->guisection = _("Volumes");
  528. params->volume_pos->answer = "0,0,0";
  529. /* resolution */
  530. params->volume_res = G_define_option();
  531. params->volume_res->key = "volume_resolution";
  532. params->volume_res->key_desc = "value";
  533. params->volume_res->type = TYPE_INTEGER;
  534. params->volume_res->required = NO;
  535. params->volume_res->multiple = YES;
  536. params->volume_res->description = _("Volume resolution");
  537. params->volume_res->answer = "3";
  538. params->volume_res->guisection = _("Volumes");
  539. /* isosurface level */
  540. params->isosurf_level = G_define_option();
  541. params->isosurf_level->key = "isosurf_level";
  542. params->isosurf_level->key_desc = "volume:value";
  543. params->isosurf_level->type = TYPE_STRING;
  544. params->isosurf_level->required = NO;
  545. params->isosurf_level->multiple = YES;
  546. params->isosurf_level->description = _("Isosurface level");
  547. params->isosurf_level->guisection = _("Volumes");
  548. /* isosurface color map */
  549. params->isosurf_color_map = G_define_standard_option(G_OPT_R3_MAPS);
  550. params->isosurf_color_map->key = "isosurf_color_map";
  551. params->isosurf_color_map->required = NO;
  552. params->isosurf_color_map->multiple = YES;
  553. params->isosurf_color_map->description = _("Name of volume for isosurface color");
  554. params->isosurf_color_map->guisection = _("Volumes");
  555. /* isosurface color value */
  556. params->isosurf_color_const = G_define_standard_option(G_OPT_C_FG);
  557. params->isosurf_color_const->key = "isosurf_color_value";
  558. params->isosurf_color_const->required = NO;
  559. params->isosurf_color_const->multiple = YES;
  560. params->isosurf_color_const->label = _("Isosurface color");
  561. params->isosurf_color_const->guisection = _("Volumes");
  562. params->isosurf_color_const->answer = NULL;
  563. /* isosurface transparency */
  564. params->isosurf_transp_map = G_define_standard_option(G_OPT_R3_MAP);
  565. params->isosurf_transp_map->multiple = YES;
  566. params->isosurf_transp_map->required = NO;
  567. params->isosurf_transp_map->description =
  568. _("Name of 3D raster map(s) for isosurface transparency");
  569. params->isosurf_transp_map->guisection = _("Volumes");
  570. params->isosurf_transp_map->key = "isosurf_transparency_map";
  571. params->isosurf_transp_const = G_define_option();
  572. params->isosurf_transp_const->key = "isosurf_transparency_value";
  573. params->isosurf_transp_const->key_desc = "value";
  574. params->isosurf_transp_const->type = TYPE_INTEGER;
  575. params->isosurf_transp_const->required = NO;
  576. params->isosurf_transp_const->multiple = YES;
  577. params->isosurf_transp_const->description = _("Transparency value(s)for isosurfaces");
  578. params->isosurf_transp_const->guisection = _("Volumes");
  579. params->isosurf_transp_const->options = "0-255";
  580. /* isosurface shininess */
  581. params->isosurf_shine_map = G_define_standard_option(G_OPT_R3_MAP);
  582. params->isosurf_shine_map->multiple = YES;
  583. params->isosurf_shine_map->required = NO;
  584. params->isosurf_shine_map->description = _("Name of 3D raster map(s) for shininess");
  585. params->isosurf_shine_map->guisection = _("Volumes");
  586. params->isosurf_shine_map->key = "isosurf_shininess_map";
  587. params->isosurf_shine_const = G_define_option();
  588. params->isosurf_shine_const->key = "isosurf_shininess_value";
  589. params->isosurf_shine_const->key_desc = "value";
  590. params->isosurf_shine_const->type = TYPE_INTEGER;
  591. params->isosurf_shine_const->required = NO;
  592. params->isosurf_shine_const->multiple = YES;
  593. params->isosurf_shine_const->description = _("Shininess value(s) for isosurfaces");
  594. params->isosurf_shine_const->guisection = _("Volumes");
  595. params->isosurf_shine_const->options = "0-255";
  596. /* slices */
  597. /* slice axis */
  598. params->slice = G_define_option();
  599. params->slice->key = "slice";
  600. params->slice->key_desc = "volume:axis";
  601. params->slice->type = TYPE_STRING;
  602. params->slice->required = NO;
  603. params->slice->multiple = YES;
  604. params->slice->description = _("Volume slice parallel to given axis (x, y, z)");
  605. params->slice->guisection = _("Volumes");
  606. /* slice position */
  607. params->slice_pos = G_define_option();
  608. params->slice_pos->key = "slice_position";
  609. params->slice_pos->key_desc = "x1,x2,y1,y2,z1,z2";
  610. params->slice_pos->type = TYPE_DOUBLE;
  611. params->slice_pos->required = NO;
  612. params->slice_pos->multiple = YES;
  613. params->slice_pos->description = _("Volume slice position");
  614. params->slice_pos->guisection = _("Volumes");
  615. params->slice_pos->answer = "0,1,0,1,0,1";
  616. /* slice transparency */
  617. params->slice_transp = G_define_option();
  618. params->slice_transp->key = "slice_transparency";
  619. params->slice_transp->key_desc = "value";
  620. params->slice_transp->type = TYPE_INTEGER;
  621. params->slice_transp->required = NO;
  622. params->slice_transp->multiple = YES;
  623. params->slice_transp->description = _("Volume slice transparency");
  624. params->slice_transp->guisection = _("Volumes");
  625. params->slice_transp->answer = "0";
  626. params->slice_transp->options = "0-255";
  627. return;
  628. }
  629. void args_lighting(struct GParams *params)
  630. {
  631. params->light_pos = G_define_option();
  632. params->light_pos->key = "light_position";
  633. params->light_pos->key_desc = "x,y,z";
  634. params->light_pos->type = TYPE_DOUBLE;
  635. params->light_pos->required = NO;
  636. params->light_pos->multiple = NO;
  637. params->light_pos->description =
  638. _("Light position (x,y,z model coordinates)");
  639. params->light_pos->guisection = _("Lighting");
  640. params->light_pos->answer = "0.68,-0.68,0.80";
  641. params->light_color = G_define_standard_option(G_OPT_C_FG);
  642. params->light_color->key = "light_color";
  643. params->light_color->label = _("Light color");
  644. params->light_color->guisection = _("Lighting");
  645. params->light_color->answer = "white";
  646. params->light_bright = G_define_option();
  647. params->light_bright->key = "light_brightness";
  648. params->light_bright->type = TYPE_INTEGER;
  649. params->light_bright->required = NO;
  650. params->light_bright->multiple = NO;
  651. params->light_bright->description = _("Light brightness");
  652. params->light_bright->guisection = _("Lighting");
  653. params->light_bright->answer = "80";
  654. params->light_bright->options="0-100";
  655. params->light_ambient = G_define_option();
  656. params->light_ambient->key = "light_ambient";
  657. params->light_ambient->type = TYPE_INTEGER;
  658. params->light_ambient->required = NO;
  659. params->light_ambient->multiple = NO;
  660. params->light_ambient->description = _("Light ambient");
  661. params->light_ambient->guisection = _("Lighting");
  662. params->light_ambient->answer = "20";
  663. params->light_ambient->options="0-100";
  664. }
  665. void args_cplane(struct GParams *params)
  666. {
  667. params->cplane = G_define_option();
  668. params->cplane->key = "cplane";
  669. params->cplane->key_desc = "value";
  670. params->cplane->type = TYPE_INTEGER;
  671. params->cplane->required = NO;
  672. params->cplane->multiple = YES;
  673. params->cplane->description = _("Cutting plane index (0-5)");
  674. params->cplane->guisection = _("Cutting planes");
  675. params->cplane_pos = G_define_option();
  676. params->cplane_pos->key = "cplane_position";
  677. params->cplane_pos->key_desc = "x,y,z";
  678. params->cplane_pos->type = TYPE_DOUBLE;
  679. params->cplane_pos->required = NO;
  680. params->cplane_pos->multiple = YES;
  681. params->cplane_pos->description = _("Cutting plane x,y,z coordinates");
  682. params->cplane_pos->guisection = _("Cutting planes");
  683. params->cplane_pos->answer = "0,0,0";
  684. params->cplane_rot = G_define_option();
  685. params->cplane_rot->key = "cplane_rotation";
  686. params->cplane_rot->key_desc = "value";
  687. params->cplane_rot->type = TYPE_DOUBLE;
  688. params->cplane_rot->multiple = YES;
  689. params->cplane_rot->required = NO;
  690. params->cplane_rot->guisection = _("Cutting planes");
  691. params->cplane_rot->description = _("Cutting plane rotation along the vertical axis");
  692. params->cplane_rot->answer = "0";
  693. params->cplane_rot->options="0-360";
  694. params->cplane_tilt = G_define_option();
  695. params->cplane_tilt->key = "cplane_tilt";
  696. params->cplane_tilt->key_desc = "value";
  697. params->cplane_tilt->type = TYPE_DOUBLE;
  698. params->cplane_tilt->multiple = YES;
  699. params->cplane_tilt->required = NO;
  700. params->cplane_tilt->guisection = _("Cutting planes");
  701. params->cplane_tilt->description = _("Cutting plane tilt");
  702. params->cplane_tilt->answer = "0";
  703. params->cplane_tilt->options="0-360";
  704. params->cplane_shading = G_define_option();
  705. params->cplane_shading->key = "cplane_shading";
  706. params->cplane_shading->key_desc = "string";
  707. params->cplane_shading->type = TYPE_STRING;
  708. params->cplane_shading->multiple = NO;
  709. params->cplane_shading->required = NO;
  710. params->cplane_shading->guisection = _("Cutting planes");
  711. params->cplane_shading->description = _("Cutting plane color (between two surfaces)");
  712. params->cplane_shading->answer = "clear";
  713. params->cplane_shading->options= "clear,top,bottom,blend,shaded";
  714. }
  715. void args_fringe(struct GParams *params)
  716. {
  717. char *desc;
  718. params->fringe = G_define_option();
  719. params->fringe->key = "fringe";
  720. params->fringe->type = TYPE_STRING;
  721. params->fringe->options = "nw,ne,sw,se";
  722. desc = NULL;
  723. G_asprintf(&desc,
  724. "nw;%s;ne;%s;sw;%s;se;%s",
  725. _("North-West edge"),
  726. _("North-East edge"),
  727. _("South-West edge"),
  728. _("South-East edge"));
  729. params->fringe->descriptions = desc;
  730. params->fringe->description = _("Fringe edges");
  731. params->fringe->guisection = _("Fringe");
  732. params->fringe->multiple = YES;
  733. params->fringe_color = G_define_standard_option(G_OPT_C_FG);
  734. params->fringe_color->key = "fringe_color";
  735. params->fringe_color->label = _("Fringe color");
  736. params->fringe_color->guisection = _("Fringe");
  737. params->fringe_color->answer = "grey";
  738. params->fringe_elev = G_define_option();
  739. params->fringe_elev->key = "fringe_elevation";
  740. params->fringe_elev->type = TYPE_INTEGER;
  741. params->fringe_elev->required = NO;
  742. params->fringe_elev->multiple = NO;
  743. params->fringe_elev->description = _("Fringe elevation");
  744. params->fringe_elev->guisection = _("Fringe");
  745. params->fringe_elev->answer = "55";
  746. }
  747. void args_arrow(struct GParams *params)
  748. {
  749. params->north_arrow = G_define_option();
  750. params->north_arrow->key = "arrow_position";
  751. params->north_arrow->key_desc = "x,y";
  752. params->north_arrow->type = TYPE_INTEGER;
  753. params->north_arrow->required = NO;
  754. params->north_arrow->multiple = NO;
  755. params->north_arrow->description = _("Place north arrow at given position \
  756. (in screen coordinates from bottom left corner)");
  757. params->north_arrow->guisection = _("Decoration");
  758. params->north_arrow_size = G_define_option();
  759. params->north_arrow_size->key = "arrow_size";
  760. params->north_arrow_size->key_desc = "value";
  761. params->north_arrow_size->type = TYPE_DOUBLE;
  762. params->north_arrow_size->required = NO;
  763. params->north_arrow_size->multiple = NO;
  764. params->north_arrow_size->description = _("North arrow size (in map units)");
  765. params->north_arrow_size->guisection = _("Decoration");
  766. params->north_arrow_color = G_define_standard_option(G_OPT_C_FG);
  767. params->north_arrow_color->key = "arrow_color";
  768. params->north_arrow_color->required = NO;
  769. params->north_arrow_color->multiple = NO;
  770. params->north_arrow_color->label = _("North arrow color");
  771. params->north_arrow_color->guisection = _("Decoration");
  772. params->north_arrow_color->answer = "black";
  773. }
  774. /*!
  775. \brief Get number of answers of given option
  776. \param pointer to option
  777. \return number of arguments
  778. */
  779. int opt_get_num_answers(const struct Option *opt)
  780. {
  781. int i;
  782. i = 0;
  783. if (opt->answer) {
  784. while (opt->answers[i]) {
  785. i++;
  786. }
  787. }
  788. G_debug(3, "opt_get_num_answers(): opt=%s num=%d", opt->key, i);
  789. return i;
  790. }
  791. /*!
  792. \brief Check parameters consistency
  793. \param params module parameters
  794. */
  795. void check_parameters(const struct GParams *params)
  796. {
  797. int nelev_map, nelev_const, nelevs;
  798. int nmaps, nconsts, ncoords, ncplanes;
  799. int nvlines;
  800. int nvpoints;
  801. int nvolumes, nisosurf, nslices;
  802. /* topography */
  803. nelev_map = opt_get_num_answers(params->elev_map);
  804. nelev_const = opt_get_num_answers(params->elev_const);
  805. nelevs = nelev_map + nelev_const;
  806. if (nelevs < 1)
  807. G_fatal_error(_("At least one <%s> or <%s> required"),
  808. params->elev_map->key, params->elev_const->key);
  809. /* color */
  810. nmaps = opt_get_num_answers(params->color_map);
  811. nconsts = opt_get_num_answers(params->color_const);
  812. print_error(nmaps, nconsts, nelevs,
  813. params->elev_map->key, params->elev_const->key,
  814. params->color_map->key, params->color_const->key);
  815. /* mask */
  816. nmaps = opt_get_num_answers(params->mask_map);
  817. if (nmaps > 0 && nelevs != nmaps)
  818. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  819. params->elev_map->key, params->elev_const->key, nelevs,
  820. params->mask_map->key, nmaps);
  821. /* transparency */
  822. nmaps = opt_get_num_answers(params->transp_map);
  823. nconsts = opt_get_num_answers(params->transp_const);
  824. print_error(nmaps, nconsts, nelevs,
  825. params->elev_map->key, params->elev_const->key,
  826. params->transp_map->key, params->transp_const->key);
  827. /* shininess */
  828. nmaps = opt_get_num_answers(params->shine_map);
  829. nconsts = opt_get_num_answers(params->shine_const);
  830. print_error(nmaps, nconsts, nelevs,
  831. params->elev_map->key, params->elev_const->key,
  832. params->shine_map->key, params->shine_const->key);
  833. /* emit */
  834. nmaps = opt_get_num_answers(params->emit_map);
  835. nconsts = opt_get_num_answers(params->emit_const);
  836. print_error(nmaps, nconsts, nelevs,
  837. params->elev_map->key, params->elev_const->key,
  838. params->emit_map->key, params->emit_const->key);
  839. /* draw mode */
  840. if (!params->mode_all->answer) { /* use one mode for all surfaces */
  841. nconsts = opt_get_num_answers(params->mode);
  842. if (nconsts > 0 && nconsts != nelevs)
  843. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  844. params->elev_map->key, params->elev_const->key,
  845. nelevs, params->mode->key, nconsts);
  846. nconsts = opt_get_num_answers(params->res_fine);
  847. if (nconsts > 0 && nconsts != nelevs)
  848. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  849. params->elev_map->key, params->elev_const->key,
  850. nelevs, params->res_fine->key, nconsts);
  851. nconsts = opt_get_num_answers(params->res_coarse);
  852. if (nconsts > 0 && nconsts != nelevs)
  853. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  854. params->elev_map->key, params->elev_const->key,
  855. nelevs, params->res_coarse->key, nconsts);
  856. nconsts = opt_get_num_answers(params->style);
  857. if (nconsts > 0 && nconsts != nelevs)
  858. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  859. params->elev_map->key, params->elev_const->key,
  860. nelevs, params->style->key, nconsts);
  861. nconsts = opt_get_num_answers(params->shade);
  862. if (nconsts > 0 && nconsts != nelevs)
  863. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  864. params->elev_map->key, params->elev_const->key,
  865. nelevs, params->shade->key, nconsts);
  866. nconsts = opt_get_num_answers(params->wire_color);
  867. if (nconsts > 0 && nconsts != nelevs)
  868. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d)"),
  869. params->elev_map->key, params->elev_const->key,
  870. nelevs, params->wire_color->key, nconsts);
  871. }
  872. /*
  873. * Cutting planes
  874. */
  875. ncplanes = opt_get_num_answers(params->cplane);
  876. ncoords = opt_get_num_answers(params->cplane_pos);
  877. if (ncplanes > 0 && ncplanes * 3 != ncoords)
  878. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d x 3)"),
  879. params->cplane->key, ncplanes, params->cplane_pos->key, ncoords/3);
  880. nconsts = opt_get_num_answers(params->cplane_rot);
  881. if (ncplanes > 0 && ncplanes != nconsts)
  882. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  883. params->cplane->key, ncplanes, params->cplane_rot->key, nconsts);
  884. nconsts = opt_get_num_answers(params->cplane_tilt);
  885. if (ncplanes > 0 && ncplanes != nconsts)
  886. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  887. params->cplane->key, ncplanes, params->cplane_tilt->key, nconsts);
  888. /*
  889. * vector lines
  890. */
  891. nvlines = opt_get_num_answers(params->vlines);
  892. /* width */
  893. nconsts = opt_get_num_answers(params->vline_width);
  894. if (nvlines > 0 && nconsts != nvlines)
  895. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  896. params->vlines->key, nvlines, params->vline_width->key,
  897. nconsts);
  898. /* color */
  899. nconsts = opt_get_num_answers(params->vline_color);
  900. if (nvlines > 0 && nconsts != nvlines)
  901. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  902. params->vlines->key, nvlines, params->vline_color->key,
  903. nconsts);
  904. /* mode */
  905. nconsts = opt_get_num_answers(params->vline_mode);
  906. if (nvlines > 0 && nconsts != nvlines)
  907. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  908. params->vlines->key, nvlines, params->vline_mode->key,
  909. nconsts);
  910. /* height */
  911. nconsts = opt_get_num_answers(params->vline_height);
  912. if (nvlines > 0 && nconsts != nvlines)
  913. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  914. params->vlines->key, nvlines, params->vline_height->key,
  915. nconsts);
  916. /* position */
  917. nconsts = opt_get_num_answers(params->vline_pos);
  918. if (nvlines > 0 && nconsts != 3 * nvlines)
  919. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  920. params->vlines->key, nvlines, params->vline_pos->key,
  921. nconsts);
  922. /*
  923. * vector points
  924. */
  925. nvpoints = opt_get_num_answers(params->vpoints);
  926. /* TODO */
  927. /*
  928. * volumes
  929. */
  930. nvolumes = opt_get_num_answers(params->volume);
  931. nisosurf = opt_get_num_answers(params->isosurf_level);
  932. nslices = opt_get_num_answers(params->slice);
  933. /* isosurface transparency */
  934. nmaps = opt_get_num_answers(params->isosurf_transp_map);
  935. nconsts = opt_get_num_answers(params->isosurf_transp_const);
  936. if ((nmaps + nconsts > 0) && (nisosurf != nmaps + nconsts))
  937. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d, <%s> %d)"),
  938. params->isosurf_level->key, nisosurf, params->isosurf_transp_map->key, nmaps,
  939. params->isosurf_transp_const->key, nconsts);
  940. /* isosurface shininess */
  941. nmaps = opt_get_num_answers(params->isosurf_shine_map);
  942. nconsts = opt_get_num_answers(params->isosurf_shine_const);
  943. if ((nmaps + nconsts > 0) && (nisosurf != nmaps + nconsts))
  944. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d, <%s> %d)"),
  945. params->isosurf_level->key, nisosurf, params->isosurf_shine_map->key, nmaps,
  946. params->isosurf_shine_const->key, nconsts);
  947. /* slice transparency */
  948. nconsts = opt_get_num_answers(params->slice_transp);
  949. if (nslices > 0 && nslices != nconsts)
  950. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d)"),
  951. params->slice->key, nslices, params->slice_transp->key, nconsts);
  952. /* slice position */
  953. ncoords = opt_get_num_answers(params->slice_pos);
  954. if (nslices > 0 && ncoords != 6 * nslices)
  955. G_fatal_error(_("Inconsistent number of attributes (<%s> %d: <%s> %d x 6)"),
  956. params->slice->key, nslices, params->slice_pos->key, ncoords/6);
  957. return;
  958. }
  959. void print_error(int nmaps, int nconsts, int nelevs,
  960. const char *elev_map, const char *elev_const,
  961. const char *map_name, const char *const_name)
  962. {
  963. if ((nmaps + nconsts > 0) && (nelevs != nmaps + nconsts))
  964. G_fatal_error(_("Inconsistent number of attributes (<%s/%s> %d: <%s> %d, <%s> %d)"),
  965. elev_map, elev_const, nelevs, map_name, nmaps,
  966. const_name, nconsts);
  967. return;
  968. }