dpn.c 38 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519
  1. /*
  2. * Copyright 2021
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation, either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. *
  17. * These are the four essential freedoms with GNU GPL software:
  18. * 1: freedom to run the program, for any purpose
  19. * 2: freedom to study how the program works, and change it to make it do what you wish
  20. * 3: freedom to redistribute copies to help your Free Software friends
  21. * 4: freedom to distribute copies of your modified versions to your Free Software friends
  22. * , ,
  23. * / \
  24. * ((__-^^-,-^^-__))
  25. * `-_---' `---_-'
  26. * `--|o` 'o|--'
  27. * \ ` /
  28. * ): :(
  29. * :o_o:
  30. * "-"
  31. */
  32. /* node attributes:
  33. * color colorscheme comment distortion fillcolor fixedsize fontcolor fontname
  34. * fontsize group height id image imagescale label labelloc layer margin nojustify
  35. * orientation penwidth peripheries pin pos rects regular root samplepoints shape
  36. * shapefile showboxes sides skew sortv style target tooltip vertices width z
  37. */
  38. #include "config.h"
  39. #include <stdio.h>
  40. #include <stdlib.h>
  41. #include <string.h>
  42. #include <strings.h>
  43. #include <math.h>
  44. #include <zlib.h>
  45. #include "splay-tree.h"
  46. #include "dp.h"
  47. #include "dpn.h"
  48. #include "dpcolor.h"
  49. #include "dpmisc.h"
  50. #include "dot.tab.h"
  51. #include "lex.yy.h"
  52. #include "dpus.h"
  53. #include "dpmem.h"
  54. /* node[] attribute to check */
  55. void dp_do_nattr(char *l, char *r, int ishtml)
  56. {
  57. int cc = 0;
  58. int tmpi = 0;
  59. struct dpnode *res = NULL;
  60. struct dpnum *num = NULL;
  61. struct dpbool *boolnum = NULL;
  62. struct dpcolor *colornum = NULL;
  63. struct dpstyle *stylenum = NULL;
  64. struct dpmargin *mnum = NULL;
  65. /* safety */
  66. if (l == NULL) {
  67. printf("dot %s(): shouldnothappen nil l\n", __func__);
  68. return;
  69. }
  70. /* safety */
  71. if (r == NULL) {
  72. printf("dot %s(): shouldnothappen nil r\n", __func__);
  73. return;
  74. }
  75. if (dp_cclass == DP_TNODE) {
  76. res = dp_curnode;
  77. } else if (dp_cclass == DP_TNODEDEF) {
  78. res = dp_curgraph->defnode;
  79. } else {
  80. printf("dot %s(): shouldnothappen dp_cclass=%d\n", __func__, dp_cclass);
  81. return;
  82. }
  83. /* switch on first char */
  84. cc = (*l);
  85. switch (cc) {
  86. case 'c':
  87. if (strcmp(l, "color") == 0) {
  88. colornum = dp_getcolor(res->bitflags0.csnumset, res->csnum, r);
  89. if (colornum->pe) {
  90. if (colornum->es) {
  91. /* default black color */
  92. res->color = 0x00000000;
  93. res->bitflags0.colorset = 1;
  94. } else {
  95. memset(dp_errmsg, 0, 256);
  96. snprintf(dp_errmsg, (256 - 1),
  97. "dot %s(): unknown color `%s' at node `%s' line %d\n", __func__, r, res->name, res->yylineno);
  98. }
  99. } else {
  100. /* todo */
  101. if (colornum->islist) {
  102. /* default black color */
  103. res->color = 0x00000000;
  104. printf("dot %s(): color list at node `%s' line %d not supported\n", __func__, res->name, res->yylineno);
  105. } else {
  106. res->color = colornum->color;
  107. }
  108. res->bitflags0.colorset = 1;
  109. }
  110. colornum = (struct dpcolor *)dp_free((void *)colornum);
  111. if (colornum) {
  112. }
  113. } else if (strcmp(l, "colorscheme") == 0) {
  114. tmpi = dp_colorschemecode(r);
  115. if (tmpi == (-1)) {
  116. memset(dp_errmsg, 0, 256);
  117. snprintf(dp_errmsg, (256 - 1),
  118. "dot %s(): syntax error invalid name of colorscheme `%s' near line %d\n", __func__, r, yylineno);
  119. /* continue and error message will soon appear */
  120. } else {
  121. /* number oke for colorscheme */
  122. res->csnum = tmpi;
  123. res->bitflags0.csnumset = 1;
  124. }
  125. } else if (strcmp(l, "comment") == 0) {
  126. /* device dep. string */
  127. if (r) {
  128. if (strlen(r)) {
  129. res->comment = r;
  130. } else {
  131. res->comment = NULL;
  132. }
  133. res->bitflags0.comset = 1;
  134. }
  135. } else {
  136. /* something other */
  137. }
  138. break;
  139. case 'd':
  140. if (strcmp(l, "distortion") == 0) {
  141. /* factor for shape polygon, default 0, min -100 max ? */
  142. num = dp_getnum(r);
  143. if (num->pe) {
  144. if (num->es) {
  145. /* number is "", use default. */
  146. res->distortion = 0;
  147. res->bitflags0.distortionset = 1;
  148. } else {
  149. memset(dp_errmsg, 0, 256);
  150. snprintf(dp_errmsg, (256 - 1),
  151. "dot %s(): cannot parse distortion number `%s' at line %d\n", __func__, r, res->yylineno);
  152. }
  153. } else {
  154. if (num->number > -100) {
  155. res->distortion = num->number;
  156. res->bitflags0.distortionset = 1;
  157. } else {
  158. memset(dp_errmsg, 0, 256);
  159. snprintf(dp_errmsg, (256 - 1),
  160. "dot %s(): distortion number `%s' at line %d is too low\n", __func__, r, res->yylineno);
  161. }
  162. }
  163. num = (struct dpnum *)dp_free((void *)num);
  164. if (num) {
  165. }
  166. }
  167. break;
  168. /* fillcolor fixedsize fontcolor fontname fontsize */
  169. case 'f':
  170. if (strcmp(l, "fillcolor") == 0) {
  171. colornum = dp_getcolor(res->bitflags0.csnumset, res->csnum, r);
  172. if (colornum->pe) {
  173. if (colornum->es) {
  174. /* default white color */
  175. res->fcolor = 0x00ffffff;
  176. res->bitflags0.fcolorset = 1;
  177. } else {
  178. memset(dp_errmsg, 0, 256);
  179. snprintf(dp_errmsg, (256 - 1),
  180. "dot %s(): unknown color `%s' at node `%s' line %d\n", __func__, r, res->name, res->yylineno);
  181. }
  182. } else {
  183. /* todo */
  184. if (colornum->islist) {
  185. /* default white color */
  186. res->fcolor = 0x00ffffff;
  187. printf("dot %s(): color list at node `%s' line %d not supported\n", __func__, res->name, res->yylineno);
  188. } else {
  189. res->fcolor = colornum->color;
  190. }
  191. res->bitflags0.fcolorset = 1;
  192. }
  193. colornum = (struct dpcolor *)dp_free((void *)colornum);
  194. if (colornum) {
  195. }
  196. } else if (strcmp(l, "fixedsize") == 0) {
  197. /* if fixedsize=true, the width parameter is used for node x size */
  198. boolnum = dp_getbool(r);
  199. if (boolnum->pe) {
  200. if (boolnum->es) {
  201. /* default */
  202. res->bitflags0.fixsize = 0;
  203. res->bitflags0.fixsizeset = 1;
  204. } else {
  205. memset(dp_errmsg, 0, 256);
  206. snprintf(dp_errmsg, (256 - 1),
  207. "dot %s(): not a boolean `%s' at fixedsize line %d\n", __func__, r, res->yylineno);
  208. }
  209. } else {
  210. if (boolnum->number) {
  211. res->bitflags0.fixsize = 1;
  212. } else {
  213. res->bitflags0.fixsize = 0;
  214. }
  215. res->bitflags0.fixsizeset = 1;
  216. }
  217. boolnum = (struct dpbool *)dp_free((void *)boolnum);
  218. if (boolnum) {
  219. }
  220. } else if (strcmp(l, "fontcolor") == 0) {
  221. colornum = dp_getcolor(res->bitflags0.csnumset, res->csnum, r);
  222. if (colornum->pe) {
  223. if (colornum->es) {
  224. /* default black color */
  225. res->fontcolor = 0x00000000;
  226. res->bitflags0.fontcolorset = 1;
  227. } else {
  228. memset(dp_errmsg, 0, 256);
  229. snprintf(dp_errmsg, (256 - 1),
  230. "dot %s(): unknown color `%s' at node `%s' line %d\n", __func__, r, res->name, res->yylineno);
  231. }
  232. } else {
  233. /* todo */
  234. if (colornum->islist) {
  235. /* default black color */
  236. res->fontcolor = 0x00000000;
  237. printf("dot %s(): color list at node `%s' line %d not supported\n", __func__, res->name, res->yylineno);
  238. } else {
  239. res->fontcolor = colornum->color;
  240. }
  241. res->bitflags0.fontcolorset = 1;
  242. }
  243. colornum = (struct dpcolor *)dp_free((void *)colornum);
  244. if (colornum) {
  245. }
  246. } else if (strcmp(l, "fontname") == 0) {
  247. if (r) {
  248. if (strlen(r)) {
  249. res->fontname = r;
  250. } else {
  251. res->fontname = NULL;
  252. }
  253. res->bitflags0.fontnameset = 1;
  254. }
  255. } else if (strcmp(l, "fontsize") == 0) {
  256. /* size of font */
  257. num = dp_getnum(r);
  258. if (num->pe) {
  259. if (num->es) {
  260. /* number is "", use default. */
  261. res->fontsize = 14;
  262. res->bitflags0.fontsizeset = 1;
  263. } else {
  264. memset(dp_errmsg, 0, 256);
  265. snprintf(dp_errmsg, (256 - 1),
  266. "dot %s(): cannot parse fontsize number `%s' at line %d\n", __func__, r, res->yylineno);
  267. }
  268. } else {
  269. if (num->number >= 1.0) {
  270. /* round to int in double format */
  271. res->fontsize = rint(num->number);
  272. res->bitflags0.fontsizeset = 1;
  273. } else {
  274. memset(dp_errmsg, 0, 256);
  275. snprintf(dp_errmsg, (256 - 1),
  276. "dot %s(): fontsize number `%s' at line %d is too low\n", __func__, r, res->yylineno);
  277. }
  278. }
  279. num = (struct dpnum *)dp_free((void *)num);
  280. if (num) {
  281. }
  282. } else {
  283. /* something else */
  284. }
  285. break;
  286. /* group */
  287. case 'g':
  288. if (strcmp(l, "group") == 0) {
  289. if (r) {
  290. if (strlen(r)) {
  291. res->group = r;
  292. } else {
  293. res->group = NULL;
  294. }
  295. res->bitflags0.groupset = 1;
  296. }
  297. } else {
  298. /* something else */
  299. }
  300. break;
  301. /* height href */
  302. case 'h':
  303. if (strcmp(l, "height") == 0) {
  304. num = dp_getnum(r);
  305. if (num->pe) {
  306. if (num->es) {
  307. res->height = 0.5;
  308. res->bitflags0.heightset = 1;
  309. } else {
  310. memset(dp_errmsg, 0, 256);
  311. snprintf(dp_errmsg, (256 - 1),
  312. "dot %s(): cannot parse `%s' for height at line %d\n", __func__, r, res->yylineno);
  313. }
  314. } else {
  315. /* allow 0 for gprof2dot */
  316. if (num->number < 0) {
  317. memset(dp_errmsg, 0, 256);
  318. snprintf(dp_errmsg, (256 - 1),
  319. "dot %s(): not allowed negative number `%s' for height at line %d\n", __func__, r, res->yylineno);
  320. } else {
  321. /* min. is 0.02 */
  322. res->height = num->number;
  323. if (res->height < 0.02) {
  324. printf("dot %s(): minimum value for height is 0.02 but specified is %s\n", __func__, r);
  325. res->height = 0.02;
  326. }
  327. res->bitflags0.heightset = 1;
  328. }
  329. }
  330. num = (struct dpnum *)dp_free((void *)num);
  331. if (num) {
  332. }
  333. } else if (strcmp(l, "href") == 0) {
  334. /* url node */
  335. if (r) {
  336. if (strlen(r)) {
  337. res->url = NULL;
  338. } else {
  339. res->url = NULL;
  340. }
  341. res->bitflags1.urlset = 1;
  342. }
  343. } else {
  344. /* something else */
  345. }
  346. break;
  347. /* id image imagescale */
  348. case 'i':
  349. if (strcmp(l, "id") == 0) {
  350. /* imagemap id's */
  351. if (r) {
  352. if (strlen(r)) {
  353. res->id = r;
  354. } else {
  355. res->id = NULL;
  356. }
  357. res->bitflags0.idset = 1;
  358. }
  359. } else if (strcmp(l, "image") == 0) {
  360. /* image for node */
  361. if (r) {
  362. if (strlen(r)) {
  363. res->image = r;
  364. } else {
  365. res->image = NULL;
  366. }
  367. res->bitflags0.imgset = 1;
  368. }
  369. } else if (strcmp(l, "imagescale") == 0) {
  370. /* scale for image */
  371. boolnum = dp_getbool(r);
  372. if (boolnum->pe) {
  373. if (boolnum->es) {
  374. /* default */
  375. res->bitflags0.iscale = 0;
  376. res->bitflags0.iscaleset = 1;
  377. } else {
  378. memset(dp_errmsg, 0, 256);
  379. snprintf(dp_errmsg, (256 - 1),
  380. "dot %s(): not a boolean `%s' for imagescale at line %d\n", __func__, r, res->yylineno);
  381. }
  382. } else {
  383. if (boolnum->number) {
  384. res->bitflags0.iscale = 1;
  385. } else {
  386. res->bitflags0.iscale = 0;
  387. }
  388. res->bitflags0.iscaleset = 1;
  389. }
  390. boolnum = (struct dpbool *)dp_free((void *)boolnum);
  391. if (boolnum) {
  392. }
  393. } else {
  394. /* something else */
  395. }
  396. break;
  397. /* label labelloc layer */
  398. case 'l':
  399. /* node[label=<>] does remove the label texts if no label at node specified */
  400. /* node[label=""] does remove the label texts if no label at node specified */
  401. /* label can have html entity chars as &#x20; or &#231; or &#amp; */
  402. /* \N set node name */
  403. if (strcmp(l, "label") == 0) {
  404. if (r) {
  405. if (strlen(r)) {
  406. res->label = r;
  407. res->htmllabel = ishtml;
  408. } else {
  409. /* label="" does empty the label text */
  410. /* dot sets few spaces at "" to get ellipse default shape */
  411. res->label = dp_uniqstr((char *)" ");
  412. res->htmllabel = 0;
  413. }
  414. res->bitflags0.labelset = 1;
  415. /* at \N de-select */
  416. /* todo, this must be done more complicated. */
  417. if (strcmp(r, "\\N") == 0) {
  418. res->label = NULL;
  419. res->htmllabel = 0;
  420. res->bitflags0.labelset = 0;
  421. }
  422. if (yydebug || 0) {
  423. printf("%s(): node label \"%s\" type html-label=%d\n", __func__, res->label, res->htmllabel);
  424. }
  425. }
  426. } else if (strcmp(l, "labelloc") == 0) {
  427. /* location of label */
  428. tmpi = dp_islabelloc(r);
  429. if (r == 0) {
  430. memset(dp_errmsg, 0, 256);
  431. snprintf(dp_errmsg, (256 - 1),
  432. "dot %s(): not a location `%s' for labelloc at line %d\n", __func__, r, res->yylineno);
  433. } else {
  434. res->labelloc = tmpi;
  435. res->bitflags0.labellset = 1;
  436. }
  437. } else if (strcmp(l, "layer") == 0) {
  438. /* layer control string */
  439. if (r) {
  440. if (strlen(r)) {
  441. res->layer = r;
  442. } else {
  443. res->layer = NULL;
  444. }
  445. res->bitflags0.layerset = 1;
  446. }
  447. } else {
  448. /* something else */
  449. }
  450. break;
  451. /* margin */
  452. case 'm':
  453. if (strcmp(l, "margin") == 0) {
  454. if (r) {
  455. if (dp_chknum(r)) {
  456. memset(dp_errmsg, 0, 256);
  457. snprintf(dp_errmsg, (256 - 1),
  458. "dot %s(): not a number `%s' for margin at line %d\n", __func__, r, res->yylineno);
  459. } else {
  460. res->margin = r;
  461. mnum = dp_getmargin(r);
  462. if (mnum->pe) {
  463. if (mnum->es) {
  464. res->margin = NULL;
  465. res->marginx = 0; /* todo default values */
  466. res->marginy = 0;
  467. } else {
  468. memset(dp_errmsg, 0, 256);
  469. snprintf(dp_errmsg, (256 - 1),
  470. "dot %s(): cannot parse `%s' for margin at line %d\n", __func__, r, res->yylineno);
  471. }
  472. } else {
  473. if (mnum->x < 0 || mnum->y < 0) {
  474. memset(dp_errmsg, 0, 256);
  475. snprintf(dp_errmsg, (256 - 1),
  476. "dot %s(): not allowed negative number `%s' for margin at line %d\n",
  477. __func__, r, res->yylineno);
  478. } else {
  479. res->marginx = mnum->x;
  480. res->marginy = mnum->y;
  481. }
  482. }
  483. mnum = (struct dpmargin *)dp_free((void *)mnum);
  484. if (mnum) {
  485. }
  486. res->bitflags0.marginset = 1;
  487. }
  488. }
  489. } else {
  490. /* something else */
  491. }
  492. break;
  493. /* nojustify */
  494. case 'n':
  495. if (strcmp(l, "nojustify") == 0) {
  496. /* */
  497. boolnum = dp_getbool(r);
  498. if (boolnum->pe) {
  499. if (boolnum->es) {
  500. /* default */
  501. res->bitflags0.nojust = 0;
  502. res->bitflags0.nojustset = 1;
  503. } else {
  504. memset(dp_errmsg, 0, 256);
  505. snprintf(dp_errmsg, (256 - 1),
  506. "dot %s(): not a boolean `%s' for nojustify at line %d\n", __func__, r, res->yylineno);
  507. }
  508. } else {
  509. if (boolnum->number) {
  510. res->bitflags0.nojust = 1;
  511. } else {
  512. res->bitflags0.nojust = 0;
  513. }
  514. res->bitflags0.nojustset = 1;
  515. }
  516. boolnum = (struct dpbool *)dp_free((void *)boolnum);
  517. if (boolnum) {
  518. }
  519. } else {
  520. /* something else */
  521. }
  522. break;
  523. /* orientation */
  524. case 'o':
  525. if (strcmp(l, "orientation") == 0) {
  526. /* rotate polygon shape, 0..360 */
  527. num = dp_getnum(r);
  528. if (num->pe) {
  529. if (num->es) {
  530. res->orientation = 0;
  531. res->bitflags0.oriset = 1;
  532. } else {
  533. memset(dp_errmsg, 0, 256);
  534. snprintf(dp_errmsg, (256 - 1),
  535. "dot %s(): unknown number `%s' for orientation at line %d\n", __func__, r, res->yylineno);
  536. }
  537. } else {
  538. if (num->number < 0 || num->number > 360) {
  539. memset(dp_errmsg, 0, 256);
  540. snprintf(dp_errmsg, (256 - 1),
  541. "dot %s(): not allowed negative number or too large number `%s' for orientation at line %d\n",
  542. __func__, r, res->yylineno);
  543. } else {
  544. res->orientation = rint(num->number);
  545. res->bitflags0.oriset = 1;
  546. }
  547. }
  548. num = (struct dpnum *)dp_free((void *)num);
  549. if (num) {
  550. }
  551. } else {
  552. /* something else */
  553. }
  554. break;
  555. /* penwidth peripheries pin pos */
  556. case 'p':
  557. if (strcmp(l, "penwidth") == 0) {
  558. num = dp_getnum(r);
  559. if (num->pe) {
  560. if (num->es) {
  561. res->penwidth = 1;
  562. res->bitflags0.penwidthset = 1;
  563. } else {
  564. memset(dp_errmsg, 0, 256);
  565. snprintf(dp_errmsg, (256 - 1),
  566. "dot %s(): unknown number `%s' for penwidth at line %d\n", __func__, r, res->yylineno);
  567. }
  568. } else {
  569. if (num->number < 0) {
  570. memset(dp_errmsg, 0, 256);
  571. snprintf(dp_errmsg, (256 - 1),
  572. "dot %s(): not allowed negative number `%s' for penwidth at line %d\n", __func__, r, res->yylineno);
  573. } else {
  574. /* allow 0.25, 1.25 etc */
  575. res->penwidth = num->number;
  576. res->bitflags0.penwidthset = 1;
  577. }
  578. }
  579. num = (struct dpnum *)dp_free((void *)num);
  580. if (num) {
  581. }
  582. } else if (strcmp(l, "peripheries") == 0) {
  583. /* for polygonal shapes */
  584. num = dp_getnum(r);
  585. if (num->pe) {
  586. if (num->es) {
  587. res->peripheries = 1;
  588. res->bitflags0.periset = 1;
  589. } else {
  590. memset(dp_errmsg, 0, 256);
  591. snprintf(dp_errmsg, (256 - 1),
  592. "dot %s(): unknown number `%s' for peripheries at line %d\n", __func__, r, res->yylineno);
  593. }
  594. } else {
  595. if (num->number < 0) {
  596. memset(dp_errmsg, 0, 256);
  597. snprintf(dp_errmsg, (256 - 1),
  598. "dot %s(): not allowed negative number `%s' for peripheries at line %d\n", __func__, r, res->yylineno);
  599. } else {
  600. /* is a int number */
  601. res->peripheries = rint(num->number);
  602. res->bitflags0.periset = 1;
  603. }
  604. }
  605. num = (struct dpnum *)dp_free((void *)num);
  606. if (num) {
  607. }
  608. } else if (strcmp(l, "pin") == 0) {
  609. /* fixed pos of node if pos specified */
  610. boolnum = dp_getbool(r);
  611. if (boolnum->pe) {
  612. if (boolnum->es) {
  613. /* default */
  614. res->bitflags0.pin = 0;
  615. res->bitflags0.pinset = 1;
  616. } else {
  617. memset(dp_errmsg, 0, 256);
  618. snprintf(dp_errmsg, (256 - 1), "dot %s(): not a boolean `%s' for pin at line %d\n", __func__, r, res->yylineno);
  619. }
  620. } else {
  621. if (boolnum->number) {
  622. res->bitflags0.pin = 1;
  623. } else {
  624. res->bitflags0.pin = 0;
  625. }
  626. res->bitflags0.pinset = 1;
  627. }
  628. boolnum = (struct dpbool *)dp_free((void *)boolnum);
  629. if (boolnum) {
  630. }
  631. } else if (strcmp(l, "pos") == 0) {
  632. /* position of node %f,%f as string */
  633. if (r) {
  634. if (dp_chknum(r)) {
  635. memset(dp_errmsg, 0, 256);
  636. snprintf(dp_errmsg, (256 - 1),
  637. "dot %s(): not a number `%s' for position at line %d\n", __func__, r, res->yylineno);
  638. } else {
  639. if (strlen(r)) {
  640. res->pos = r;
  641. } else {
  642. res->pos = NULL;
  643. }
  644. res->bitflags1.posset = 1;
  645. /* todo parse the numbers */
  646. }
  647. }
  648. } else {
  649. /* something else */
  650. }
  651. break;
  652. /* rects regular root */
  653. case 'r':
  654. if (strcmp(l, "rects") == 0) {
  655. /* record rects as %f,%f,%f,%f as string */
  656. if (r) {
  657. if (dp_chknum(r)) {
  658. memset(dp_errmsg, 0, 256);
  659. snprintf(dp_errmsg, (256 - 1),
  660. "dot %s(): not a number `%s' for rects at line %d\n", __func__, r, res->yylineno);
  661. } else {
  662. if (strlen(r)) {
  663. res->rects = r;
  664. } else {
  665. res->rects = NULL;
  666. }
  667. res->bitflags1.rectsset = 1;
  668. /* todo parse the numbers */
  669. }
  670. }
  671. } else if (strcmp(l, "regular") == 0) {
  672. /* polygon regular bool */
  673. boolnum = dp_getbool(r);
  674. if (boolnum->pe) {
  675. if (boolnum->es) {
  676. /* default */
  677. res->bitflags1.regular = 0;
  678. res->bitflags1.reguset = 1;
  679. } else {
  680. memset(dp_errmsg, 0, 256);
  681. snprintf(dp_errmsg, (256 - 1),
  682. "dot %s(): not a boolean `%s' for regular at line %d\n", __func__, r, res->yylineno);
  683. }
  684. } else {
  685. if (boolnum->number) {
  686. res->bitflags1.regular = 1;
  687. } else {
  688. res->bitflags1.regular = 0;
  689. }
  690. res->bitflags1.reguset = 1;
  691. }
  692. boolnum = (struct dpbool *)dp_free((void *)boolnum);
  693. if (boolnum) {
  694. }
  695. } else if (strcmp(l, "root") == 0) {
  696. /* this is not a dot but twopi keyword */
  697. } else {
  698. /* something else */
  699. }
  700. break;
  701. /* samplepoints shape shapefile showboxes sides skew sortv style */
  702. case 's':
  703. if (strcmp(l, "samplepoints") == 0) {
  704. /* int number of point for shape */
  705. num = dp_getnum(r);
  706. if (num->pe) {
  707. if (num->es) {
  708. res->samplepoints = 20;
  709. res->bitflags1.spset = 1;
  710. } else {
  711. memset(dp_errmsg, 0, 256);
  712. snprintf(dp_errmsg, (256 - 1),
  713. "dot %s(): unknown number `%s' for samplepoints at line %d\n", __func__, r, res->yylineno);
  714. }
  715. } else {
  716. if (num->number < 0) {
  717. memset(dp_errmsg, 0, 256);
  718. snprintf(dp_errmsg, (256 - 1),
  719. "dot %s(): not allowed negative number `%s' for samplepoints at line %d\n",
  720. __func__, r, res->yylineno);
  721. } else {
  722. /* is a int number */
  723. res->samplepoints = rint(num->number);
  724. res->bitflags1.spset = 1;
  725. }
  726. }
  727. num = (struct dpnum *)dp_free((void *)num);
  728. if (num) {
  729. }
  730. } else if (strcmp(l, "shape") == 0) {
  731. tmpi = dp_isdotshape(r);
  732. if (tmpi == (-1)) {
  733. /* todo, make into parse error */
  734. printf("dot %s(): unknown shape `%s' for node `%s' at line %d\n", __func__, r, res->name, res->yylineno);
  735. } else {
  736. res->shape = tmpi;
  737. res->bitflags0.shapeset = 1;
  738. }
  739. } else if (strcmp(l, "shapefile") == 0) {
  740. /* external node shape */
  741. if (r) {
  742. if (strlen(r)) {
  743. res->shapefile = r;
  744. } else {
  745. res->shapefile = NULL;
  746. }
  747. res->bitflags1.shapefset = 1;
  748. }
  749. } else if (strcmp(l, "showboxes") == 0) {
  750. /* boxes in postscript, (int) 0,1,2 */
  751. /* int number of point for shape */
  752. num = dp_getnum(r);
  753. if (num->pe) {
  754. if (num->es) {
  755. res->showboxes = 0;
  756. res->bitflags1.showbset = 1;
  757. } else {
  758. memset(dp_errmsg, 0, 256);
  759. snprintf(dp_errmsg, (256 - 1),
  760. "dot %s(): unknown number `%s' for showboxes at line %d\n", __func__, r, res->yylineno);
  761. }
  762. } else {
  763. if (num->number < 0 || num->number > 2) {
  764. memset(dp_errmsg, 0, 256);
  765. snprintf(dp_errmsg, (256 - 1),
  766. "dot %s(): not allowed negative number or too high number `%s' for showboxes at line %d\n",
  767. __func__, r, res->yylineno);
  768. } else {
  769. /* is a int number */
  770. res->showboxes = rint(num->number);
  771. res->bitflags1.showbset = 1;
  772. }
  773. }
  774. num = (struct dpnum *)dp_free((void *)num);
  775. if (num) {
  776. }
  777. } else if (strcmp(l, "sides") == 0) {
  778. /* number of sides in a polygon shape */
  779. num = dp_getnum(r);
  780. if (num->pe) {
  781. if (num->es) {
  782. /* dot defaults to 4, not 3 */
  783. res->sides = 4;
  784. res->bitflags0.sidesset = 1;
  785. } else {
  786. memset(dp_errmsg, 0, 256);
  787. snprintf(dp_errmsg, (256 - 1),
  788. "dot %s(): unknown number `%s' for sides at line %d\n", __func__, r, res->yylineno);
  789. }
  790. } else {
  791. /* todo: dot allows sides=0 without warning */
  792. if (num->number < 0) {
  793. memset(dp_errmsg, 0, 256);
  794. snprintf(dp_errmsg, (256 - 1),
  795. "dot %s(): not allowed negative number `%s' for sides at line %d\n", __func__, r, res->yylineno);
  796. } else {
  797. if (num->number < 3) {
  798. printf("dot %s(): sides number `%s' is too low, minimum is 3 and using now default 4\n", __func__, r);
  799. res->sides = 4;
  800. } else {
  801. res->sides = num->number;
  802. }
  803. res->bitflags0.sidesset = 1;
  804. }
  805. }
  806. num = (struct dpnum *)dp_free((void *)num);
  807. if (num) {
  808. }
  809. } else if (strcmp(l, "skew") == 0) {
  810. /* +/- skew factor polygon shape */
  811. num = dp_getnum(r);
  812. if (num->pe) {
  813. if (num->es) {
  814. res->skew = 0;
  815. res->bitflags1.skewset = 1;
  816. } else {
  817. memset(dp_errmsg, 0, 256);
  818. snprintf(dp_errmsg, (256 - 1),
  819. "dot %s(): unknown number `%s' for skew at line %d\n", __func__, r, res->yylineno);
  820. }
  821. } else {
  822. if (num->number < -100) {
  823. memset(dp_errmsg, 0, 256);
  824. snprintf(dp_errmsg, (256 - 1),
  825. "dot %s(): too low number `%s' for skew at line %d\n", __func__, r, res->yylineno);
  826. } else {
  827. res->skew = num->number;
  828. res->bitflags1.skewset = 1;
  829. }
  830. }
  831. num = (struct dpnum *)dp_free((void *)num);
  832. if (num) {
  833. }
  834. } else if (strcmp(l, "sortv") == 0) {
  835. /* packing modus */
  836. num = dp_getnum(r);
  837. if (num->pe) {
  838. if (num->es) {
  839. res->sortv = 0;
  840. res->bitflags1.sortvset = 1;
  841. } else {
  842. memset(dp_errmsg, 0, 256);
  843. snprintf(dp_errmsg, (256 - 1),
  844. "dot %s(): unknown number `%s' for sortv at line %d\n", __func__, r, res->yylineno);
  845. }
  846. } else {
  847. if (num->number < 0) {
  848. memset(dp_errmsg, 0, 256);
  849. snprintf(dp_errmsg, (256 - 1),
  850. "dot %s(): negative number `%s' for sortv at line %d\n", __func__, r, res->yylineno);
  851. } else {
  852. res->sortv = rint(num->number);
  853. res->bitflags1.sortvset = 1;
  854. }
  855. }
  856. num = (struct dpnum *)dp_free((void *)num);
  857. if (num) {
  858. }
  859. } else if (strcmp(l, "style") == 0) {
  860. stylenum = dp_getstyle(r);
  861. if (stylenum->pe) {
  862. if (stylenum->es) {
  863. /* at "" clear all */
  864. res->bitflags1.dashed = 0;
  865. res->bitflags1.dashedset = 1;
  866. res->bitflags1.dotted = 0;
  867. res->bitflags1.dottedset = 1;
  868. res->bitflags1.solid = 0;
  869. res->bitflags1.solidset = 1;
  870. res->bitflags1.invis = 0;
  871. res->bitflags1.invisset = 1;
  872. res->bitflags1.bold = 0;
  873. res->bitflags1.boldset = 1;
  874. res->bitflags1.filled = 0;
  875. res->bitflags1.filledset = 1;
  876. res->bitflags1.striped = 0;
  877. res->bitflags1.stripedset = 1;
  878. res->bitflags1.wedged = 0;
  879. res->bitflags1.wedgedset = 1;
  880. res->bitflags1.dia = 0;
  881. res->bitflags1.diaset = 1;
  882. res->bitflags1.rounded = 0;
  883. res->bitflags1.roundedset = 1;
  884. res->bitflags1.radial = 0;
  885. res->bitflags0.radialset = 1;
  886. res->penwidth = 1;
  887. res->bitflags0.penwidthset = 1;
  888. } else {
  889. if (stylenum->pe_unk) {
  890. /* parse error at unknown token */
  891. memset(dp_errmsg, 0, 256);
  892. snprintf(dp_errmsg, (256 - 1),
  893. "dot %s(): unknown token `%s' in `%s' for style at line %d\n",
  894. __func__, stylenum->unknown, r, res->yylineno);
  895. } else if (stylenum->pe_slw) {
  896. /* parse error at setlinewidth number */
  897. memset(dp_errmsg, 0, 256);
  898. snprintf(dp_errmsg, (256 - 1),
  899. "dot %s(): wrong number or negative number `%s' for setlinewidth in style at line %d\nuse penwidth instead of setlinewidth.\n",
  900. __func__, r, res->yylineno);
  901. } else if (stylenum->pe_exp) {
  902. /* missing number at setlinewidth */
  903. memset(dp_errmsg, 0, 256);
  904. snprintf(dp_errmsg, (256 - 1),
  905. "dot %s(): missing number `%s' for setlinewidth in style at line %d\nuse penwidth instead of setlinewidth.\n",
  906. __func__, r, res->yylineno);
  907. } else {
  908. /* other parse error */
  909. memset(dp_errmsg, 0, 256);
  910. snprintf(dp_errmsg, (256 - 1),
  911. "dot %s(): unknown error in `%s' for style at line %d\n", __func__, r, res->yylineno);
  912. }
  913. }
  914. } else {
  915. /* no parse errors if here, the N marked are for a node: */
  916. /* int slwset; set if setlinewidth N */
  917. /* double slw; setlinewidth number */
  918. /* int dashed; "dashed" parsed N+E */
  919. /* int dotted; "dotted" parsed N+E */
  920. /* int solid; "solid" parsed N+E */
  921. /* int invis; "invis" parsed N+E */
  922. /* int bold; "bold" parsed N+E */
  923. /* int tapered; "tapered" parsed E */
  924. /* int filled; "filled" parsed N+c */
  925. /* int striped; "striped" parsed N+c */
  926. /* int wedged; "wedged" parsed N */
  927. /* int diagonals; "diagonals" parsed N */
  928. /* int rounded; "rounded" parsed N+C */
  929. /* int radial; "radial" parsed N+C+G */
  930. if (stylenum->tapered) {
  931. if (0) { /* as error */
  932. memset(dp_errmsg, 0, 256);
  933. snprintf(dp_errmsg, (256 - 1),
  934. "dot %s(): tapered does not apply to node in `%s' for style at line %d\n",
  935. __func__, r, res->yylineno);
  936. } else {
  937. printf("dot %s(): tapered does not apply to node in `%s' for style at line %d\n",
  938. __func__, r, res->yylineno);
  939. }
  940. } else {
  941. if (stylenum->slwset) {
  942. /* allow 0.25, 1.25 etc */
  943. res->penwidth = stylenum->slw;
  944. res->bitflags0.penwidthset = 1;
  945. }
  946. if (stylenum->dashed) {
  947. res->bitflags1.dashed = 1;
  948. res->bitflags1.dashedset = 1;
  949. }
  950. if (stylenum->dotted) {
  951. res->bitflags1.dotted = 1;
  952. res->bitflags1.dottedset = 1;
  953. }
  954. if (stylenum->solid) {
  955. res->bitflags1.solid = 1;
  956. res->bitflags1.solidset = 1;
  957. }
  958. if (stylenum->invis) {
  959. res->bitflags1.invis = 1;
  960. res->bitflags1.invisset = 1;
  961. }
  962. if (stylenum->bold) {
  963. res->bitflags1.bold = 1;
  964. res->bitflags1.boldset = 1;
  965. }
  966. if (stylenum->filled) {
  967. res->bitflags1.filled = 1;
  968. res->bitflags1.filledset = 1;
  969. }
  970. if (stylenum->striped) {
  971. res->bitflags1.striped = 1;
  972. res->bitflags1.stripedset = 1;
  973. }
  974. if (stylenum->wedged) {
  975. res->bitflags1.wedged = 1;
  976. res->bitflags1.wedgedset = 1;
  977. }
  978. if (stylenum->diagonals) {
  979. res->bitflags1.dia = 1;
  980. res->bitflags1.diaset = 1;
  981. }
  982. if (stylenum->rounded) {
  983. res->bitflags1.rounded = 1;
  984. res->bitflags1.roundedset = 1;
  985. }
  986. if (stylenum->radial) {
  987. res->bitflags1.radial = 1;
  988. res->bitflags0.radialset = 1;
  989. }
  990. }
  991. }
  992. stylenum = (struct dpstyle *)dp_free((void *)stylenum);
  993. if (stylenum) {
  994. }
  995. } else {
  996. /* something else */
  997. }
  998. break;
  999. /* target tooltip */
  1000. case 't':
  1001. if (strcmp(l, "target") == 0) {
  1002. /* map only */
  1003. } else if (strcmp(l, "tooltip") == 0) {
  1004. /* cmap only */
  1005. } else {
  1006. /* something else */
  1007. }
  1008. break;
  1009. /* vertices */
  1010. case 'v':
  1011. if (strcmp(l, "vertices") == 0) {
  1012. /* coords of node polygon */
  1013. if (r) {
  1014. if (strlen(r)) {
  1015. res->vertices = r;
  1016. } else {
  1017. res->vertices = NULL;
  1018. }
  1019. res->bitflags1.vertset = 1;
  1020. }
  1021. } else {
  1022. /* something else */
  1023. }
  1024. break;
  1025. /* width */
  1026. case 'w':
  1027. if (strcmp(l, "width") == 0) {
  1028. num = dp_getnum(r);
  1029. if (num->pe) {
  1030. if (num->es) {
  1031. /* default */
  1032. res->width = 0.75;
  1033. res->bitflags0.widthset = 1;
  1034. } else {
  1035. memset(dp_errmsg, 0, 256);
  1036. snprintf(dp_errmsg, (256 - 1),
  1037. "dot %s(): unknown number `%s' for width at line %d\n", __func__, r, res->yylineno);
  1038. }
  1039. } else {
  1040. /* allow 0 for prof2dot */
  1041. if (num->number < 0) {
  1042. memset(dp_errmsg, 0, 256);
  1043. snprintf(dp_errmsg, (256 - 1),
  1044. "dot %s(): not allowed negative numbe `%s' for width at line %d\n", __func__, r, res->yylineno);
  1045. } else {
  1046. res->width = num->number;
  1047. /* min is 0.01 */
  1048. if (res->width < 0.01) {
  1049. printf("dot %s(): minimum value for width is 0.01 but specified is %s\n", __func__, r);
  1050. res->width = 0.01;
  1051. }
  1052. res->bitflags0.widthset = 1;
  1053. }
  1054. }
  1055. num = (struct dpnum *)dp_free((void *)num);
  1056. if (num) {
  1057. }
  1058. } else {
  1059. /* something else */
  1060. }
  1061. break;
  1062. /* z */
  1063. case 'z':
  1064. if (strcmp(l, "z") == 0) {
  1065. /* neato keyword */
  1066. } else {
  1067. /* something else */
  1068. }
  1069. break;
  1070. /* URL */
  1071. case 'U':
  1072. if (strcmp(l, "URL") == 0) {
  1073. /* url node */
  1074. if (r) {
  1075. if (strlen(r)) {
  1076. res->url = NULL;
  1077. } else {
  1078. res->url = NULL;
  1079. }
  1080. res->bitflags1.urlset = 1;
  1081. }
  1082. } else {
  1083. /* something else */
  1084. }
  1085. break;
  1086. default:
  1087. /* something else */
  1088. break;
  1089. }
  1090. /* dot supports html label in record shapes.
  1091. * todo in gml4gtk not yet supported.
  1092. */
  1093. if (res->shape == DPSHAPE_RECORD || res->shape == DPSHAPE_MRECORD) {
  1094. if (res->bitflags0.labelset) {
  1095. if (res->htmllabel) {
  1096. printf("%s(): html label in record node shape not yet supported in node \"%s\"\n", __func__, dp_curnode->name);
  1097. /* turn it off */
  1098. res->shape = 0;
  1099. res->bitflags0.shapeset = 0;
  1100. res->label = dp_curnode->name;
  1101. res->bitflags0.labelset = 1;
  1102. res->htmllabel = 0;
  1103. }
  1104. }
  1105. }
  1106. fflush(stdout);
  1107. return;
  1108. }
  1109. /* set factory default */
  1110. void dp_nodefdef(struct dpnode *n)
  1111. {
  1112. /* no style=filled */
  1113. /* fillcolor is white rgb #00ffffff */
  1114. /* bordercolor is black rgb #00000000 */
  1115. /* fontcolor is black rgb #00000000 */
  1116. n->penwidth = 1;
  1117. n->bitflags0.penwidthset = 1;
  1118. /* width of node, min. 0.01 */
  1119. n->width = 0.75;
  1120. n->bitflags0.widthset = 1;
  1121. /* height of node, min. 0.02 */
  1122. n->height = 0.5;
  1123. n->bitflags0.heightset = 1;
  1124. /* group is (char *)0 */
  1125. /* comment is (char *)0 */
  1126. /* distortion for polygon is 0.0 */
  1127. /* fontname = (char *)0 */
  1128. /* fontsize is 14 */
  1129. n->fontsize = 14.0;
  1130. n->bitflags0.fontsizeset = 1;
  1131. /* imagemap id is (char *)0 */
  1132. /* label is default node name if not specified or \N
  1133. * n->label = n->name;
  1134. * n->bitflags0.labelset = 1;
  1135. */
  1136. /* image is (char *)0 */
  1137. /* imagescale is false */
  1138. /* label location is center */
  1139. n->labelloc = DP_LLC;
  1140. n->bitflags0.labellset = 1;
  1141. /* layer is (char *)0 */
  1142. /* margin is (char *)0, has 2 fp numbers */
  1143. /* nojustify is 0 false */
  1144. /* orientation is 0 */
  1145. /* for polygon shapes */
  1146. n->peripheries = 1;
  1147. n->bitflags0.periset = 1;
  1148. /* pin is bool false 0 */
  1149. /* pos is 0,0 as (char *)0 */
  1150. /* rects is %f,%f,%f,%f (char *)0 as string */
  1151. /* regular is false */
  1152. /* number of points for shape */
  1153. n->samplepoints = 20;
  1154. n->bitflags1.spset = 1;
  1155. /* number of sides in polygon, 4 is a rectangle */
  1156. n->sides = 4;
  1157. n->bitflags0.sidesset = 1;
  1158. /* shape is ellipse */
  1159. /* shapefile is (char *)0 */
  1160. /* showboxes is (int)0 */
  1161. /* skew is 0.0 */
  1162. /* sortv is 0 */
  1163. /* vertices = (char *)0 */
  1164. /* url is (char *)0 */
  1165. return;
  1166. }
  1167. /* set graph default */
  1168. void dp_nodegdef(struct dpnode *from, struct dpnode *n)
  1169. {
  1170. /* optional colorscheme */
  1171. if (from->bitflags0.csnumset) {
  1172. n->csnum = from->csnum;
  1173. n->bitflags0.csnumset = 1;
  1174. }
  1175. /* fillcolor */
  1176. if (from->bitflags0.fcolorset) {
  1177. n->fcolor = from->fcolor;
  1178. n->bitflags0.fcolorset = 1;
  1179. }
  1180. /* fontcolor */
  1181. if (from->bitflags0.fontcolorset) {
  1182. n->fontcolor = from->fontcolor;
  1183. n->bitflags0.fontcolorset = 1;
  1184. }
  1185. /* color */
  1186. if (from->bitflags0.colorset) {
  1187. n->color = from->color;
  1188. n->bitflags0.colorset = 1;
  1189. }
  1190. /* node shape */
  1191. if (from->bitflags0.shapeset) {
  1192. n->shape = from->shape;
  1193. n->bitflags0.shapeset = 1;
  1194. }
  1195. /* node style */
  1196. if (from->bitflags1.dashedset) {
  1197. n->bitflags1.dashed = from->bitflags1.dashed;
  1198. n->bitflags1.dashedset = 1;
  1199. }
  1200. if (from->bitflags1.dottedset) {
  1201. n->bitflags1.dotted = from->bitflags1.dotted;
  1202. n->bitflags1.dottedset = 1;
  1203. }
  1204. if (from->bitflags1.solidset) {
  1205. n->bitflags1.solid = from->bitflags1.solid;
  1206. n->bitflags1.solidset = 1;
  1207. }
  1208. if (from->bitflags1.invisset) {
  1209. n->bitflags1.invis = from->bitflags1.invis;
  1210. n->bitflags1.invisset = 1;
  1211. }
  1212. if (from->bitflags1.boldset) {
  1213. n->bitflags1.bold = from->bitflags1.bold;
  1214. n->bitflags1.boldset = 1;
  1215. }
  1216. if (from->bitflags1.filledset) {
  1217. n->bitflags1.filled = from->bitflags1.filled;
  1218. n->bitflags1.filledset = 1;
  1219. }
  1220. if (from->bitflags1.stripedset) {
  1221. n->bitflags1.striped = from->bitflags1.striped;
  1222. n->bitflags1.stripedset = 1;
  1223. }
  1224. if (from->bitflags1.wedgedset) {
  1225. n->bitflags1.wedged = from->bitflags1.wedged;
  1226. n->bitflags1.wedgedset = 1;
  1227. }
  1228. if (from->bitflags1.diaset) {
  1229. n->bitflags1.dia = from->bitflags1.dia;
  1230. n->bitflags1.diaset = 1;
  1231. }
  1232. if (from->bitflags1.roundedset) {
  1233. n->bitflags1.rounded = from->bitflags1.rounded;
  1234. n->bitflags1.roundedset = 1;
  1235. }
  1236. if (from->bitflags0.radialset) {
  1237. n->bitflags1.radial = from->bitflags1.radial;
  1238. n->bitflags0.radialset = 1;
  1239. }
  1240. /* border line thickness */
  1241. if (from->bitflags0.penwidthset) {
  1242. n->penwidth = from->penwidth;
  1243. n->bitflags0.penwidthset = 1;
  1244. }
  1245. /* number of sides in polygon */
  1246. if (from->bitflags0.sidesset) {
  1247. n->sides = from->sides;
  1248. n->bitflags0.sidesset = 1;
  1249. }
  1250. /* width of node */
  1251. if (from->bitflags0.widthset) {
  1252. n->width = from->width;
  1253. n->bitflags0.widthset = 1;
  1254. }
  1255. /* height of node */
  1256. if (from->bitflags0.heightset) {
  1257. n->height = from->height;
  1258. n->bitflags0.heightset = 1;
  1259. }
  1260. /* bool use node width fixedsize in width param */
  1261. if (from->bitflags0.fixsizeset) {
  1262. n->bitflags0.fixsize = from->bitflags0.fixsize;
  1263. n->bitflags0.fixsizeset = 1;
  1264. }
  1265. /* group */
  1266. if (from->bitflags0.groupset) {
  1267. n->group = from->group;
  1268. n->bitflags0.groupset = 1;
  1269. }
  1270. /* comment */
  1271. if (from->bitflags0.comset) {
  1272. n->comment = from->comment;
  1273. n->bitflags0.comset = 1;
  1274. }
  1275. /* distortion for shape polygon */
  1276. if (from->bitflags0.distortionset) {
  1277. n->distortion = from->distortion;
  1278. n->bitflags0.distortionset = 1;
  1279. }
  1280. /* char * fontname */
  1281. if (from->bitflags0.fontnameset) {
  1282. n->fontname = from->fontname;
  1283. n->bitflags0.fontnameset = 1;
  1284. }
  1285. /* fontsize */
  1286. if (from->bitflags0.fontsizeset) {
  1287. n->fontsize = from->fontsize;
  1288. n->bitflags0.fontsizeset = 1;
  1289. }
  1290. /* imagemap id */
  1291. if (from->bitflags0.idset) {
  1292. n->id = from->id;
  1293. n->bitflags0.idset = 1;
  1294. }
  1295. /* node label */
  1296. if (from->bitflags0.labelset) {
  1297. n->label = from->label;
  1298. n->bitflags0.labelset = 1;
  1299. }
  1300. /* image for node */
  1301. if (from->bitflags0.imgset) {
  1302. n->image = from->image;
  1303. n->bitflags0.imgset = 1;
  1304. }
  1305. /* bool imagescale */
  1306. if (from->bitflags0.iscaleset) {
  1307. n->bitflags0.iscale = from->bitflags0.iscale;
  1308. n->bitflags0.iscaleset = 1;
  1309. }
  1310. /* label location */
  1311. if (from->bitflags0.labellset) {
  1312. n->labelloc = from->labelloc;
  1313. n->bitflags0.labellset = 1;
  1314. }
  1315. /* layer control string */
  1316. if (from->bitflags0.layerset) {
  1317. n->layer = from->layer;
  1318. n->bitflags0.layerset = 1;
  1319. }
  1320. /* margin string, 2 fp numbers */
  1321. if (from->bitflags0.marginset) {
  1322. n->margin = from->margin;
  1323. n->marginx = from->marginx;
  1324. n->marginy = from->marginy;
  1325. n->bitflags0.marginset = 1;
  1326. }
  1327. /* nojustify bool */
  1328. if (from->bitflags0.nojustset) {
  1329. n->bitflags0.nojust = from->bitflags0.nojust;
  1330. n->bitflags0.nojustset = 1;
  1331. }
  1332. /* rotate polygon shape, 0..360 */
  1333. if (from->bitflags0.oriset) {
  1334. n->orientation = from->orientation;
  1335. n->bitflags0.oriset = 1;
  1336. }
  1337. /* for polygon shapes */
  1338. if (from->bitflags0.periset) {
  1339. n->peripheries = from->peripheries;
  1340. n->bitflags0.periset = 1;
  1341. }
  1342. /* fixed pos of node */
  1343. if (from->bitflags0.pinset) {
  1344. n->bitflags0.pin = from->bitflags0.pin;
  1345. n->bitflags0.pinset = 1;
  1346. }
  1347. /* pos of node %f,%f as string */
  1348. if (from->bitflags1.posset) {
  1349. n->pos = from->pos;
  1350. n->bitflags1.posset = 1;
  1351. }
  1352. /* rect */
  1353. if (from->bitflags1.rectsset) {
  1354. n->rects = from->rects;
  1355. n->bitflags1.rectsset = 1;
  1356. }
  1357. /* regular polygon bool */
  1358. if (from->bitflags1.reguset) {
  1359. n->bitflags1.regular = from->bitflags1.regular;
  1360. n->bitflags1.reguset = 1;
  1361. }
  1362. /* number of points for shape */
  1363. if (from->bitflags1.spset) {
  1364. from->samplepoints = from->samplepoints;
  1365. n->bitflags1.spset = 1;
  1366. }
  1367. /* external node shape */
  1368. if (from->bitflags1.shapefset) {
  1369. n->shapefile = from->shapefile;
  1370. n->bitflags1.shapefset = 1;
  1371. }
  1372. /* postscript showboxes, 0,1,2 */
  1373. if (from->bitflags1.showbset) {
  1374. n->showboxes = from->showboxes;
  1375. n->bitflags1.showbset = 1;
  1376. }
  1377. /* polygon skew factor */
  1378. if (from->bitflags1.skewset) {
  1379. n->skew = from->skew;
  1380. n->bitflags1.skewset = 1;
  1381. }
  1382. /* packing modus */
  1383. if (from->bitflags1.sortvset) {
  1384. n->sortv = from->sortv;
  1385. n->bitflags1.sortvset = 1;
  1386. }
  1387. /* coord of polygon string */
  1388. if (from->bitflags1.vertset) {
  1389. n->vertices = from->vertices;
  1390. n->bitflags1.vertset = 1;
  1391. }
  1392. /* url */
  1393. if (from->bitflags1.urlset) {
  1394. n->url = from->url;
  1395. n->bitflags1.urlset = 1;
  1396. }
  1397. return;
  1398. }
  1399. /* end */