| | @@ -373,10 +373,15 @@ |
| 373 | 373 | /* Error contexts */ |
| 374 | 374 | unsigned int nCtx; /* Number of error contexts */ |
| 375 | 375 | PToken aCtx[10]; /* Nested error contexts */ |
| 376 | 376 | }; |
| 377 | 377 | |
| 378 | +/* Include PIKCHR_PLAINTEXT_ERRORS among the bits of mFlags on the 3rd |
| 379 | +** argument to pikchr() in order to cause error message text to come out |
| 380 | +** as text/plain instead of as text/html |
| 381 | +*/ |
| 382 | +#define PIKCHR_PLAINTEXT_ERRORS 0x0001 |
| 378 | 383 | |
| 379 | 384 | /* |
| 380 | 385 | ** The behavior of an object class is defined by an instance of |
| 381 | 386 | ** this structure. This is the "virtual method" table. |
| 382 | 387 | */ |
| | @@ -463,11 +468,11 @@ |
| 463 | 468 | static PObj *pik_position_assert(Pik*,PPoint*,PToken*,PPoint*); |
| 464 | 469 | static PNum pik_dist(PPoint*,PPoint*); |
| 465 | 470 | static void pik_add_macro(Pik*,PToken *pId,PToken *pCode); |
| 466 | 471 | |
| 467 | 472 | |
| 468 | | -#line 494 "pikchr.c" |
| 473 | +#line 499 "pikchr.c" |
| 469 | 474 | /**************** End of %include directives **********************************/ |
| 470 | 475 | /* These constants specify the various numeric values for terminal symbols. |
| 471 | 476 | ***************** Begin token definitions *************************************/ |
| 472 | 477 | #ifndef T_ID |
| 473 | 478 | #define T_ID 1 |
| | @@ -1680,22 +1685,22 @@ |
| 1680 | 1685 | ** inside the C code. |
| 1681 | 1686 | */ |
| 1682 | 1687 | /********* Begin destructor definitions ***************************************/ |
| 1683 | 1688 | case 98: /* statement_list */ |
| 1684 | 1689 | { |
| 1685 | | -#line 483 "pikchr.y" |
| 1690 | +#line 488 "pikchr.y" |
| 1686 | 1691 | pik_elist_free(p,(yypminor->yy119)); |
| 1687 | | -#line 1712 "pikchr.c" |
| 1692 | +#line 1717 "pikchr.c" |
| 1688 | 1693 | } |
| 1689 | 1694 | break; |
| 1690 | 1695 | case 99: /* statement */ |
| 1691 | 1696 | case 100: /* unnamed_statement */ |
| 1692 | 1697 | case 101: /* basetype */ |
| 1693 | 1698 | { |
| 1694 | | -#line 485 "pikchr.y" |
| 1699 | +#line 490 "pikchr.y" |
| 1695 | 1700 | pik_elem_free(p,(yypminor->yy38)); |
| 1696 | | -#line 1721 "pikchr.c" |
| 1701 | +#line 1726 "pikchr.c" |
| 1697 | 1702 | } |
| 1698 | 1703 | break; |
| 1699 | 1704 | /********* End destructor definitions *****************************************/ |
| 1700 | 1705 | default: break; /* If no destructor action specified: do nothing */ |
| 1701 | 1706 | } |
| | @@ -1909,14 +1914,14 @@ |
| 1909 | 1914 | #endif |
| 1910 | 1915 | while( yypParser->yytos>yypParser->yystack ) yy_pop_parser_stack(yypParser); |
| 1911 | 1916 | /* Here code is inserted which will execute if the parser |
| 1912 | 1917 | ** stack every overflows */ |
| 1913 | 1918 | /******** Begin %stack_overflow code ******************************************/ |
| 1914 | | -#line 517 "pikchr.y" |
| 1919 | +#line 522 "pikchr.y" |
| 1915 | 1920 | |
| 1916 | 1921 | pik_error(p, 0, "parser stack overflow"); |
| 1917 | | -#line 1942 "pikchr.c" |
| 1922 | +#line 1947 "pikchr.c" |
| 1918 | 1923 | /******** End %stack_overflow code ********************************************/ |
| 1919 | 1924 | pik_parserARG_STORE /* Suppress warning about unused %extra_argument var */ |
| 1920 | 1925 | pik_parserCTX_STORE |
| 1921 | 1926 | } |
| 1922 | 1927 | |
| | @@ -2390,614 +2395,614 @@ |
| 2390 | 2395 | ** break; |
| 2391 | 2396 | */ |
| 2392 | 2397 | /********** Begin reduce actions **********************************************/ |
| 2393 | 2398 | YYMINORTYPE yylhsminor; |
| 2394 | 2399 | case 0: /* document ::= statement_list */ |
| 2395 | | -#line 521 "pikchr.y" |
| 2400 | +#line 526 "pikchr.y" |
| 2396 | 2401 | {pik_render(p,yymsp[0].minor.yy119);} |
| 2397 | | -#line 2422 "pikchr.c" |
| 2402 | +#line 2427 "pikchr.c" |
| 2398 | 2403 | break; |
| 2399 | 2404 | case 1: /* statement_list ::= statement */ |
| 2400 | | -#line 524 "pikchr.y" |
| 2405 | +#line 529 "pikchr.y" |
| 2401 | 2406 | { yylhsminor.yy119 = pik_elist_append(p,0,yymsp[0].minor.yy38); } |
| 2402 | | -#line 2427 "pikchr.c" |
| 2407 | +#line 2432 "pikchr.c" |
| 2403 | 2408 | yymsp[0].minor.yy119 = yylhsminor.yy119; |
| 2404 | 2409 | break; |
| 2405 | 2410 | case 2: /* statement_list ::= statement_list EOL statement */ |
| 2406 | | -#line 526 "pikchr.y" |
| 2411 | +#line 531 "pikchr.y" |
| 2407 | 2412 | { yylhsminor.yy119 = pik_elist_append(p,yymsp[-2].minor.yy119,yymsp[0].minor.yy38); } |
| 2408 | | -#line 2433 "pikchr.c" |
| 2413 | +#line 2438 "pikchr.c" |
| 2409 | 2414 | yymsp[-2].minor.yy119 = yylhsminor.yy119; |
| 2410 | 2415 | break; |
| 2411 | 2416 | case 3: /* statement ::= */ |
| 2412 | | -#line 529 "pikchr.y" |
| 2417 | +#line 534 "pikchr.y" |
| 2413 | 2418 | { yymsp[1].minor.yy38 = 0; } |
| 2414 | | -#line 2439 "pikchr.c" |
| 2419 | +#line 2444 "pikchr.c" |
| 2415 | 2420 | break; |
| 2416 | 2421 | case 4: /* statement ::= direction */ |
| 2417 | | -#line 530 "pikchr.y" |
| 2422 | +#line 535 "pikchr.y" |
| 2418 | 2423 | { pik_set_direction(p,yymsp[0].minor.yy0.eCode); yylhsminor.yy38=0; } |
| 2419 | | -#line 2444 "pikchr.c" |
| 2424 | +#line 2449 "pikchr.c" |
| 2420 | 2425 | yymsp[0].minor.yy38 = yylhsminor.yy38; |
| 2421 | 2426 | break; |
| 2422 | 2427 | case 5: /* statement ::= lvalue ASSIGN rvalue */ |
| 2423 | | -#line 531 "pikchr.y" |
| 2428 | +#line 536 "pikchr.y" |
| 2424 | 2429 | {pik_set_var(p,&yymsp[-2].minor.yy0,yymsp[0].minor.yy265,&yymsp[-1].minor.yy0); yylhsminor.yy38=0;} |
| 2425 | | -#line 2450 "pikchr.c" |
| 2430 | +#line 2455 "pikchr.c" |
| 2426 | 2431 | yymsp[-2].minor.yy38 = yylhsminor.yy38; |
| 2427 | 2432 | break; |
| 2428 | 2433 | case 6: /* statement ::= PLACENAME COLON unnamed_statement */ |
| 2429 | | -#line 533 "pikchr.y" |
| 2434 | +#line 538 "pikchr.y" |
| 2430 | 2435 | { yylhsminor.yy38 = yymsp[0].minor.yy38; pik_elem_setname(p,yymsp[0].minor.yy38,&yymsp[-2].minor.yy0); } |
| 2431 | | -#line 2456 "pikchr.c" |
| 2436 | +#line 2461 "pikchr.c" |
| 2432 | 2437 | yymsp[-2].minor.yy38 = yylhsminor.yy38; |
| 2433 | 2438 | break; |
| 2434 | 2439 | case 7: /* statement ::= PLACENAME COLON position */ |
| 2435 | | -#line 535 "pikchr.y" |
| 2440 | +#line 540 "pikchr.y" |
| 2436 | 2441 | { yylhsminor.yy38 = pik_elem_new(p,0,0,0); |
| 2437 | 2442 | if(yylhsminor.yy38){ yylhsminor.yy38->ptAt = yymsp[0].minor.yy43; pik_elem_setname(p,yylhsminor.yy38,&yymsp[-2].minor.yy0); }} |
| 2438 | | -#line 2463 "pikchr.c" |
| 2443 | +#line 2468 "pikchr.c" |
| 2439 | 2444 | yymsp[-2].minor.yy38 = yylhsminor.yy38; |
| 2440 | 2445 | break; |
| 2441 | 2446 | case 8: /* statement ::= unnamed_statement */ |
| 2442 | | -#line 537 "pikchr.y" |
| 2447 | +#line 542 "pikchr.y" |
| 2443 | 2448 | {yylhsminor.yy38 = yymsp[0].minor.yy38;} |
| 2444 | | -#line 2469 "pikchr.c" |
| 2449 | +#line 2474 "pikchr.c" |
| 2445 | 2450 | yymsp[0].minor.yy38 = yylhsminor.yy38; |
| 2446 | 2451 | break; |
| 2447 | 2452 | case 9: /* statement ::= print prlist */ |
| 2448 | | -#line 538 "pikchr.y" |
| 2453 | +#line 543 "pikchr.y" |
| 2449 | 2454 | {pik_append(p,"<br>\n",5); yymsp[-1].minor.yy38=0;} |
| 2450 | | -#line 2475 "pikchr.c" |
| 2455 | +#line 2480 "pikchr.c" |
| 2451 | 2456 | break; |
| 2452 | 2457 | case 10: /* statement ::= ASSERT LP expr EQ expr RP */ |
| 2453 | | -#line 543 "pikchr.y" |
| 2458 | +#line 548 "pikchr.y" |
| 2454 | 2459 | {yymsp[-5].minor.yy38=pik_assert(p,yymsp[-3].minor.yy265,&yymsp[-2].minor.yy0,yymsp[-1].minor.yy265);} |
| 2455 | | -#line 2480 "pikchr.c" |
| 2460 | +#line 2485 "pikchr.c" |
| 2456 | 2461 | break; |
| 2457 | 2462 | case 11: /* statement ::= ASSERT LP position EQ position RP */ |
| 2458 | | -#line 545 "pikchr.y" |
| 2463 | +#line 550 "pikchr.y" |
| 2459 | 2464 | {yymsp[-5].minor.yy38=pik_position_assert(p,&yymsp[-3].minor.yy43,&yymsp[-2].minor.yy0,&yymsp[-1].minor.yy43);} |
| 2460 | | -#line 2485 "pikchr.c" |
| 2465 | +#line 2490 "pikchr.c" |
| 2461 | 2466 | break; |
| 2462 | 2467 | case 12: /* statement ::= DEFINE ID CODEBLOCK */ |
| 2463 | | -#line 546 "pikchr.y" |
| 2468 | +#line 551 "pikchr.y" |
| 2464 | 2469 | {yymsp[-2].minor.yy38=0; pik_add_macro(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy0);} |
| 2465 | | -#line 2490 "pikchr.c" |
| 2470 | +#line 2495 "pikchr.c" |
| 2466 | 2471 | break; |
| 2467 | 2472 | case 13: /* rvalue ::= PLACENAME */ |
| 2468 | | -#line 557 "pikchr.y" |
| 2473 | +#line 562 "pikchr.y" |
| 2469 | 2474 | {yylhsminor.yy265 = pik_lookup_color(p,&yymsp[0].minor.yy0);} |
| 2470 | | -#line 2495 "pikchr.c" |
| 2475 | +#line 2500 "pikchr.c" |
| 2471 | 2476 | yymsp[0].minor.yy265 = yylhsminor.yy265; |
| 2472 | 2477 | break; |
| 2473 | 2478 | case 14: /* pritem ::= FILL */ |
| 2474 | 2479 | case 15: /* pritem ::= COLOR */ yytestcase(yyruleno==15); |
| 2475 | 2480 | case 16: /* pritem ::= THICKNESS */ yytestcase(yyruleno==16); |
| 2476 | | -#line 562 "pikchr.y" |
| 2481 | +#line 567 "pikchr.y" |
| 2477 | 2482 | {pik_append_num(p,"",pik_value(p,yymsp[0].minor.yy0.z,yymsp[0].minor.yy0.n,0));} |
| 2478 | | -#line 2503 "pikchr.c" |
| 2483 | +#line 2508 "pikchr.c" |
| 2479 | 2484 | break; |
| 2480 | 2485 | case 17: /* pritem ::= rvalue */ |
| 2481 | | -#line 565 "pikchr.y" |
| 2486 | +#line 570 "pikchr.y" |
| 2482 | 2487 | {pik_append_num(p,"",yymsp[0].minor.yy265);} |
| 2483 | | -#line 2508 "pikchr.c" |
| 2488 | +#line 2513 "pikchr.c" |
| 2484 | 2489 | break; |
| 2485 | 2490 | case 18: /* pritem ::= STRING */ |
| 2486 | | -#line 566 "pikchr.y" |
| 2491 | +#line 571 "pikchr.y" |
| 2487 | 2492 | {pik_append_text(p,yymsp[0].minor.yy0.z+1,yymsp[0].minor.yy0.n-2,0);} |
| 2488 | | -#line 2513 "pikchr.c" |
| 2493 | +#line 2518 "pikchr.c" |
| 2489 | 2494 | break; |
| 2490 | 2495 | case 19: /* prsep ::= COMMA */ |
| 2491 | | -#line 567 "pikchr.y" |
| 2496 | +#line 572 "pikchr.y" |
| 2492 | 2497 | {pik_append(p, " ", 1);} |
| 2493 | | -#line 2518 "pikchr.c" |
| 2498 | +#line 2523 "pikchr.c" |
| 2494 | 2499 | break; |
| 2495 | 2500 | case 20: /* unnamed_statement ::= basetype attribute_list */ |
| 2496 | | -#line 570 "pikchr.y" |
| 2501 | +#line 575 "pikchr.y" |
| 2497 | 2502 | {yylhsminor.yy38 = yymsp[-1].minor.yy38; pik_after_adding_attributes(p,yylhsminor.yy38);} |
| 2498 | | -#line 2523 "pikchr.c" |
| 2503 | +#line 2528 "pikchr.c" |
| 2499 | 2504 | yymsp[-1].minor.yy38 = yylhsminor.yy38; |
| 2500 | 2505 | break; |
| 2501 | 2506 | case 21: /* basetype ::= CLASSNAME */ |
| 2502 | | -#line 572 "pikchr.y" |
| 2507 | +#line 577 "pikchr.y" |
| 2503 | 2508 | {yylhsminor.yy38 = pik_elem_new(p,&yymsp[0].minor.yy0,0,0); } |
| 2504 | | -#line 2529 "pikchr.c" |
| 2509 | +#line 2534 "pikchr.c" |
| 2505 | 2510 | yymsp[0].minor.yy38 = yylhsminor.yy38; |
| 2506 | 2511 | break; |
| 2507 | 2512 | case 22: /* basetype ::= STRING textposition */ |
| 2508 | | -#line 574 "pikchr.y" |
| 2513 | +#line 579 "pikchr.y" |
| 2509 | 2514 | {yymsp[-1].minor.yy0.eCode = yymsp[0].minor.yy196; yylhsminor.yy38 = pik_elem_new(p,0,&yymsp[-1].minor.yy0,0); } |
| 2510 | | -#line 2535 "pikchr.c" |
| 2515 | +#line 2540 "pikchr.c" |
| 2511 | 2516 | yymsp[-1].minor.yy38 = yylhsminor.yy38; |
| 2512 | 2517 | break; |
| 2513 | 2518 | case 23: /* basetype ::= LB savelist statement_list RB */ |
| 2514 | | -#line 576 "pikchr.y" |
| 2519 | +#line 581 "pikchr.y" |
| 2515 | 2520 | { p->list = yymsp[-2].minor.yy119; yymsp[-3].minor.yy38 = pik_elem_new(p,0,0,yymsp[-1].minor.yy119); if(yymsp[-3].minor.yy38) yymsp[-3].minor.yy38->errTok = yymsp[0].minor.yy0; } |
| 2516 | | -#line 2541 "pikchr.c" |
| 2521 | +#line 2546 "pikchr.c" |
| 2517 | 2522 | break; |
| 2518 | 2523 | case 24: /* savelist ::= */ |
| 2519 | | -#line 581 "pikchr.y" |
| 2524 | +#line 586 "pikchr.y" |
| 2520 | 2525 | {yymsp[1].minor.yy119 = p->list; p->list = 0;} |
| 2521 | | -#line 2546 "pikchr.c" |
| 2526 | +#line 2551 "pikchr.c" |
| 2522 | 2527 | break; |
| 2523 | 2528 | case 25: /* relexpr ::= expr */ |
| 2524 | | -#line 588 "pikchr.y" |
| 2529 | +#line 593 "pikchr.y" |
| 2525 | 2530 | {yylhsminor.yy200.rAbs = yymsp[0].minor.yy265; yylhsminor.yy200.rRel = 0;} |
| 2526 | | -#line 2551 "pikchr.c" |
| 2531 | +#line 2556 "pikchr.c" |
| 2527 | 2532 | yymsp[0].minor.yy200 = yylhsminor.yy200; |
| 2528 | 2533 | break; |
| 2529 | 2534 | case 26: /* relexpr ::= expr PERCENT */ |
| 2530 | | -#line 589 "pikchr.y" |
| 2535 | +#line 594 "pikchr.y" |
| 2531 | 2536 | {yylhsminor.yy200.rAbs = 0; yylhsminor.yy200.rRel = yymsp[-1].minor.yy265/100;} |
| 2532 | | -#line 2557 "pikchr.c" |
| 2537 | +#line 2562 "pikchr.c" |
| 2533 | 2538 | yymsp[-1].minor.yy200 = yylhsminor.yy200; |
| 2534 | 2539 | break; |
| 2535 | 2540 | case 27: /* optrelexpr ::= */ |
| 2536 | | -#line 591 "pikchr.y" |
| 2541 | +#line 596 "pikchr.y" |
| 2537 | 2542 | {yymsp[1].minor.yy200.rAbs = 0; yymsp[1].minor.yy200.rRel = 1.0;} |
| 2538 | | -#line 2563 "pikchr.c" |
| 2543 | +#line 2568 "pikchr.c" |
| 2539 | 2544 | break; |
| 2540 | 2545 | case 28: /* attribute_list ::= relexpr alist */ |
| 2541 | | -#line 593 "pikchr.y" |
| 2546 | +#line 598 "pikchr.y" |
| 2542 | 2547 | {pik_add_direction(p,0,&yymsp[-1].minor.yy200);} |
| 2543 | | -#line 2568 "pikchr.c" |
| 2548 | +#line 2573 "pikchr.c" |
| 2544 | 2549 | break; |
| 2545 | 2550 | case 29: /* attribute ::= numproperty relexpr */ |
| 2546 | | -#line 597 "pikchr.y" |
| 2551 | +#line 602 "pikchr.y" |
| 2547 | 2552 | { pik_set_numprop(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy200); } |
| 2548 | | -#line 2573 "pikchr.c" |
| 2553 | +#line 2578 "pikchr.c" |
| 2549 | 2554 | break; |
| 2550 | 2555 | case 30: /* attribute ::= dashproperty expr */ |
| 2551 | | -#line 598 "pikchr.y" |
| 2556 | +#line 603 "pikchr.y" |
| 2552 | 2557 | { pik_set_dashed(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy265); } |
| 2553 | | -#line 2578 "pikchr.c" |
| 2558 | +#line 2583 "pikchr.c" |
| 2554 | 2559 | break; |
| 2555 | 2560 | case 31: /* attribute ::= dashproperty */ |
| 2556 | | -#line 599 "pikchr.y" |
| 2561 | +#line 604 "pikchr.y" |
| 2557 | 2562 | { pik_set_dashed(p,&yymsp[0].minor.yy0,0); } |
| 2558 | | -#line 2583 "pikchr.c" |
| 2563 | +#line 2588 "pikchr.c" |
| 2559 | 2564 | break; |
| 2560 | 2565 | case 32: /* attribute ::= colorproperty rvalue */ |
| 2561 | | -#line 600 "pikchr.y" |
| 2566 | +#line 605 "pikchr.y" |
| 2562 | 2567 | { pik_set_clrprop(p,&yymsp[-1].minor.yy0,yymsp[0].minor.yy265); } |
| 2563 | | -#line 2588 "pikchr.c" |
| 2568 | +#line 2593 "pikchr.c" |
| 2564 | 2569 | break; |
| 2565 | 2570 | case 33: /* attribute ::= go direction optrelexpr */ |
| 2566 | | -#line 601 "pikchr.y" |
| 2571 | +#line 606 "pikchr.y" |
| 2567 | 2572 | { pik_add_direction(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy200);} |
| 2568 | | -#line 2593 "pikchr.c" |
| 2573 | +#line 2598 "pikchr.c" |
| 2569 | 2574 | break; |
| 2570 | 2575 | case 34: /* attribute ::= go direction even position */ |
| 2571 | | -#line 602 "pikchr.y" |
| 2576 | +#line 607 "pikchr.y" |
| 2572 | 2577 | {pik_evenwith(p,&yymsp[-2].minor.yy0,&yymsp[0].minor.yy43);} |
| 2573 | | -#line 2598 "pikchr.c" |
| 2578 | +#line 2603 "pikchr.c" |
| 2574 | 2579 | break; |
| 2575 | 2580 | case 35: /* attribute ::= CLOSE */ |
| 2576 | | -#line 603 "pikchr.y" |
| 2581 | +#line 608 "pikchr.y" |
| 2577 | 2582 | { pik_close_path(p,&yymsp[0].minor.yy0); } |
| 2578 | | -#line 2603 "pikchr.c" |
| 2583 | +#line 2608 "pikchr.c" |
| 2579 | 2584 | break; |
| 2580 | 2585 | case 36: /* attribute ::= CHOP */ |
| 2581 | | -#line 604 "pikchr.y" |
| 2586 | +#line 609 "pikchr.y" |
| 2582 | 2587 | { p->cur->bChop = 1; } |
| 2583 | | -#line 2608 "pikchr.c" |
| 2588 | +#line 2613 "pikchr.c" |
| 2584 | 2589 | break; |
| 2585 | 2590 | case 37: /* attribute ::= FROM position */ |
| 2586 | | -#line 605 "pikchr.y" |
| 2591 | +#line 610 "pikchr.y" |
| 2587 | 2592 | { pik_set_from(p,p->cur,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy43); } |
| 2588 | | -#line 2613 "pikchr.c" |
| 2593 | +#line 2618 "pikchr.c" |
| 2589 | 2594 | break; |
| 2590 | 2595 | case 38: /* attribute ::= TO position */ |
| 2591 | | -#line 606 "pikchr.y" |
| 2596 | +#line 611 "pikchr.y" |
| 2592 | 2597 | { pik_add_to(p,p->cur,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy43); } |
| 2593 | | -#line 2618 "pikchr.c" |
| 2598 | +#line 2623 "pikchr.c" |
| 2594 | 2599 | break; |
| 2595 | 2600 | case 39: /* attribute ::= THEN */ |
| 2596 | | -#line 607 "pikchr.y" |
| 2601 | +#line 612 "pikchr.y" |
| 2597 | 2602 | { pik_then(p, &yymsp[0].minor.yy0, p->cur); } |
| 2598 | | -#line 2623 "pikchr.c" |
| 2603 | +#line 2628 "pikchr.c" |
| 2599 | 2604 | break; |
| 2600 | 2605 | case 40: /* attribute ::= THEN optrelexpr HEADING expr */ |
| 2601 | 2606 | case 42: /* attribute ::= GO optrelexpr HEADING expr */ yytestcase(yyruleno==42); |
| 2602 | | -#line 609 "pikchr.y" |
| 2607 | +#line 614 "pikchr.y" |
| 2603 | 2608 | {pik_move_hdg(p,&yymsp[-2].minor.yy200,&yymsp[-1].minor.yy0,yymsp[0].minor.yy265,0,&yymsp[-3].minor.yy0);} |
| 2604 | | -#line 2629 "pikchr.c" |
| 2609 | +#line 2634 "pikchr.c" |
| 2605 | 2610 | break; |
| 2606 | 2611 | case 41: /* attribute ::= THEN optrelexpr EDGEPT */ |
| 2607 | 2612 | case 43: /* attribute ::= GO optrelexpr EDGEPT */ yytestcase(yyruleno==43); |
| 2608 | | -#line 610 "pikchr.y" |
| 2613 | +#line 615 "pikchr.y" |
| 2609 | 2614 | {pik_move_hdg(p,&yymsp[-1].minor.yy200,0,0,&yymsp[0].minor.yy0,&yymsp[-2].minor.yy0);} |
| 2610 | | -#line 2635 "pikchr.c" |
| 2615 | +#line 2640 "pikchr.c" |
| 2611 | 2616 | break; |
| 2612 | 2617 | case 44: /* attribute ::= AT position */ |
| 2613 | | -#line 615 "pikchr.y" |
| 2618 | +#line 620 "pikchr.y" |
| 2614 | 2619 | { pik_set_at(p,0,&yymsp[0].minor.yy43,&yymsp[-1].minor.yy0); } |
| 2615 | | -#line 2640 "pikchr.c" |
| 2620 | +#line 2645 "pikchr.c" |
| 2616 | 2621 | break; |
| 2617 | 2622 | case 45: /* attribute ::= SAME */ |
| 2618 | | -#line 617 "pikchr.y" |
| 2623 | +#line 622 "pikchr.y" |
| 2619 | 2624 | {pik_same(p,0,&yymsp[0].minor.yy0);} |
| 2620 | | -#line 2645 "pikchr.c" |
| 2625 | +#line 2650 "pikchr.c" |
| 2621 | 2626 | break; |
| 2622 | 2627 | case 46: /* attribute ::= SAME AS object */ |
| 2623 | | -#line 618 "pikchr.y" |
| 2628 | +#line 623 "pikchr.y" |
| 2624 | 2629 | {pik_same(p,yymsp[0].minor.yy38,&yymsp[-2].minor.yy0);} |
| 2625 | | -#line 2650 "pikchr.c" |
| 2630 | +#line 2655 "pikchr.c" |
| 2626 | 2631 | break; |
| 2627 | 2632 | case 47: /* attribute ::= STRING textposition */ |
| 2628 | | -#line 619 "pikchr.y" |
| 2633 | +#line 624 "pikchr.y" |
| 2629 | 2634 | {pik_add_txt(p,&yymsp[-1].minor.yy0,yymsp[0].minor.yy196);} |
| 2630 | | -#line 2655 "pikchr.c" |
| 2635 | +#line 2660 "pikchr.c" |
| 2631 | 2636 | break; |
| 2632 | 2637 | case 48: /* attribute ::= FIT */ |
| 2633 | | -#line 620 "pikchr.y" |
| 2638 | +#line 625 "pikchr.y" |
| 2634 | 2639 | {pik_size_to_fit(p,&yymsp[0].minor.yy0,3); } |
| 2635 | | -#line 2660 "pikchr.c" |
| 2640 | +#line 2665 "pikchr.c" |
| 2636 | 2641 | break; |
| 2637 | 2642 | case 49: /* attribute ::= BEHIND object */ |
| 2638 | | -#line 621 "pikchr.y" |
| 2643 | +#line 626 "pikchr.y" |
| 2639 | 2644 | {pik_behind(p,yymsp[0].minor.yy38);} |
| 2640 | | -#line 2665 "pikchr.c" |
| 2645 | +#line 2670 "pikchr.c" |
| 2641 | 2646 | break; |
| 2642 | 2647 | case 50: /* withclause ::= DOT_E edge AT position */ |
| 2643 | 2648 | case 51: /* withclause ::= edge AT position */ yytestcase(yyruleno==51); |
| 2644 | | -#line 629 "pikchr.y" |
| 2649 | +#line 634 "pikchr.y" |
| 2645 | 2650 | { pik_set_at(p,&yymsp[-2].minor.yy0,&yymsp[0].minor.yy43,&yymsp[-1].minor.yy0); } |
| 2646 | | -#line 2671 "pikchr.c" |
| 2651 | +#line 2676 "pikchr.c" |
| 2647 | 2652 | break; |
| 2648 | 2653 | case 52: /* numproperty ::= HEIGHT|WIDTH|RADIUS|DIAMETER|THICKNESS */ |
| 2649 | | -#line 633 "pikchr.y" |
| 2654 | +#line 638 "pikchr.y" |
| 2650 | 2655 | {yylhsminor.yy0 = yymsp[0].minor.yy0;} |
| 2651 | | -#line 2676 "pikchr.c" |
| 2656 | +#line 2681 "pikchr.c" |
| 2652 | 2657 | yymsp[0].minor.yy0 = yylhsminor.yy0; |
| 2653 | 2658 | break; |
| 2654 | 2659 | case 53: /* boolproperty ::= CW */ |
| 2655 | | -#line 644 "pikchr.y" |
| 2660 | +#line 649 "pikchr.y" |
| 2656 | 2661 | {p->cur->cw = 1;} |
| 2657 | | -#line 2682 "pikchr.c" |
| 2662 | +#line 2687 "pikchr.c" |
| 2658 | 2663 | break; |
| 2659 | 2664 | case 54: /* boolproperty ::= CCW */ |
| 2660 | | -#line 645 "pikchr.y" |
| 2665 | +#line 650 "pikchr.y" |
| 2661 | 2666 | {p->cur->cw = 0;} |
| 2662 | | -#line 2687 "pikchr.c" |
| 2667 | +#line 2692 "pikchr.c" |
| 2663 | 2668 | break; |
| 2664 | 2669 | case 55: /* boolproperty ::= LARROW */ |
| 2665 | | -#line 646 "pikchr.y" |
| 2670 | +#line 651 "pikchr.y" |
| 2666 | 2671 | {p->cur->larrow=1; p->cur->rarrow=0; } |
| 2667 | | -#line 2692 "pikchr.c" |
| 2672 | +#line 2697 "pikchr.c" |
| 2668 | 2673 | break; |
| 2669 | 2674 | case 56: /* boolproperty ::= RARROW */ |
| 2670 | | -#line 647 "pikchr.y" |
| 2675 | +#line 652 "pikchr.y" |
| 2671 | 2676 | {p->cur->larrow=0; p->cur->rarrow=1; } |
| 2672 | | -#line 2697 "pikchr.c" |
| 2677 | +#line 2702 "pikchr.c" |
| 2673 | 2678 | break; |
| 2674 | 2679 | case 57: /* boolproperty ::= LRARROW */ |
| 2675 | | -#line 648 "pikchr.y" |
| 2680 | +#line 653 "pikchr.y" |
| 2676 | 2681 | {p->cur->larrow=1; p->cur->rarrow=1; } |
| 2677 | | -#line 2702 "pikchr.c" |
| 2682 | +#line 2707 "pikchr.c" |
| 2678 | 2683 | break; |
| 2679 | 2684 | case 58: /* boolproperty ::= INVIS */ |
| 2680 | | -#line 649 "pikchr.y" |
| 2685 | +#line 654 "pikchr.y" |
| 2681 | 2686 | {p->cur->sw = 0.0;} |
| 2682 | | -#line 2707 "pikchr.c" |
| 2687 | +#line 2712 "pikchr.c" |
| 2683 | 2688 | break; |
| 2684 | 2689 | case 59: /* boolproperty ::= THICK */ |
| 2685 | | -#line 650 "pikchr.y" |
| 2690 | +#line 655 "pikchr.y" |
| 2686 | 2691 | {p->cur->sw *= 1.5;} |
| 2687 | | -#line 2712 "pikchr.c" |
| 2692 | +#line 2717 "pikchr.c" |
| 2688 | 2693 | break; |
| 2689 | 2694 | case 60: /* boolproperty ::= THIN */ |
| 2690 | | -#line 651 "pikchr.y" |
| 2695 | +#line 656 "pikchr.y" |
| 2691 | 2696 | {p->cur->sw *= 0.67;} |
| 2692 | | -#line 2717 "pikchr.c" |
| 2697 | +#line 2722 "pikchr.c" |
| 2693 | 2698 | break; |
| 2694 | 2699 | case 61: /* boolproperty ::= SOLID */ |
| 2695 | | -#line 652 "pikchr.y" |
| 2700 | +#line 657 "pikchr.y" |
| 2696 | 2701 | {p->cur->sw = pik_value(p,"thickness",9,0); |
| 2697 | 2702 | p->cur->dotted = p->cur->dashed = 0.0;} |
| 2698 | | -#line 2723 "pikchr.c" |
| 2703 | +#line 2728 "pikchr.c" |
| 2699 | 2704 | break; |
| 2700 | 2705 | case 62: /* textposition ::= */ |
| 2701 | | -#line 655 "pikchr.y" |
| 2706 | +#line 660 "pikchr.y" |
| 2702 | 2707 | {yymsp[1].minor.yy196 = 0;} |
| 2703 | | -#line 2728 "pikchr.c" |
| 2708 | +#line 2733 "pikchr.c" |
| 2704 | 2709 | break; |
| 2705 | 2710 | case 63: /* textposition ::= textposition CENTER|LJUST|RJUST|ABOVE|BELOW|ITALIC|BOLD|ALIGNED|BIG|SMALL */ |
| 2706 | | -#line 658 "pikchr.y" |
| 2711 | +#line 663 "pikchr.y" |
| 2707 | 2712 | {yylhsminor.yy196 = pik_text_position(yymsp[-1].minor.yy196,&yymsp[0].minor.yy0);} |
| 2708 | | -#line 2733 "pikchr.c" |
| 2713 | +#line 2738 "pikchr.c" |
| 2709 | 2714 | yymsp[-1].minor.yy196 = yylhsminor.yy196; |
| 2710 | 2715 | break; |
| 2711 | 2716 | case 64: /* position ::= expr COMMA expr */ |
| 2712 | | -#line 661 "pikchr.y" |
| 2717 | +#line 666 "pikchr.y" |
| 2713 | 2718 | {yylhsminor.yy43.x=yymsp[-2].minor.yy265; yylhsminor.yy43.y=yymsp[0].minor.yy265;} |
| 2714 | | -#line 2739 "pikchr.c" |
| 2719 | +#line 2744 "pikchr.c" |
| 2715 | 2720 | yymsp[-2].minor.yy43 = yylhsminor.yy43; |
| 2716 | 2721 | break; |
| 2717 | 2722 | case 65: /* position ::= place PLUS expr COMMA expr */ |
| 2718 | | -#line 663 "pikchr.y" |
| 2723 | +#line 668 "pikchr.y" |
| 2719 | 2724 | {yylhsminor.yy43.x=yymsp[-4].minor.yy43.x+yymsp[-2].minor.yy265; yylhsminor.yy43.y=yymsp[-4].minor.yy43.y+yymsp[0].minor.yy265;} |
| 2720 | | -#line 2745 "pikchr.c" |
| 2725 | +#line 2750 "pikchr.c" |
| 2721 | 2726 | yymsp[-4].minor.yy43 = yylhsminor.yy43; |
| 2722 | 2727 | break; |
| 2723 | 2728 | case 66: /* position ::= place MINUS expr COMMA expr */ |
| 2724 | | -#line 664 "pikchr.y" |
| 2729 | +#line 669 "pikchr.y" |
| 2725 | 2730 | {yylhsminor.yy43.x=yymsp[-4].minor.yy43.x-yymsp[-2].minor.yy265; yylhsminor.yy43.y=yymsp[-4].minor.yy43.y-yymsp[0].minor.yy265;} |
| 2726 | | -#line 2751 "pikchr.c" |
| 2731 | +#line 2756 "pikchr.c" |
| 2727 | 2732 | yymsp[-4].minor.yy43 = yylhsminor.yy43; |
| 2728 | 2733 | break; |
| 2729 | 2734 | case 67: /* position ::= place PLUS LP expr COMMA expr RP */ |
| 2730 | | -#line 666 "pikchr.y" |
| 2735 | +#line 671 "pikchr.y" |
| 2731 | 2736 | {yylhsminor.yy43.x=yymsp[-6].minor.yy43.x+yymsp[-3].minor.yy265; yylhsminor.yy43.y=yymsp[-6].minor.yy43.y+yymsp[-1].minor.yy265;} |
| 2732 | | -#line 2757 "pikchr.c" |
| 2737 | +#line 2762 "pikchr.c" |
| 2733 | 2738 | yymsp[-6].minor.yy43 = yylhsminor.yy43; |
| 2734 | 2739 | break; |
| 2735 | 2740 | case 68: /* position ::= place MINUS LP expr COMMA expr RP */ |
| 2736 | | -#line 668 "pikchr.y" |
| 2741 | +#line 673 "pikchr.y" |
| 2737 | 2742 | {yylhsminor.yy43.x=yymsp[-6].minor.yy43.x-yymsp[-3].minor.yy265; yylhsminor.yy43.y=yymsp[-6].minor.yy43.y-yymsp[-1].minor.yy265;} |
| 2738 | | -#line 2763 "pikchr.c" |
| 2743 | +#line 2768 "pikchr.c" |
| 2739 | 2744 | yymsp[-6].minor.yy43 = yylhsminor.yy43; |
| 2740 | 2745 | break; |
| 2741 | 2746 | case 69: /* position ::= LP position COMMA position RP */ |
| 2742 | | -#line 669 "pikchr.y" |
| 2747 | +#line 674 "pikchr.y" |
| 2743 | 2748 | {yymsp[-4].minor.yy43.x=yymsp[-3].minor.yy43.x; yymsp[-4].minor.yy43.y=yymsp[-1].minor.yy43.y;} |
| 2744 | | -#line 2769 "pikchr.c" |
| 2749 | +#line 2774 "pikchr.c" |
| 2745 | 2750 | break; |
| 2746 | 2751 | case 70: /* position ::= LP position RP */ |
| 2747 | | -#line 670 "pikchr.y" |
| 2752 | +#line 675 "pikchr.y" |
| 2748 | 2753 | {yymsp[-2].minor.yy43=yymsp[-1].minor.yy43;} |
| 2749 | | -#line 2774 "pikchr.c" |
| 2754 | +#line 2779 "pikchr.c" |
| 2750 | 2755 | break; |
| 2751 | 2756 | case 71: /* position ::= expr between position AND position */ |
| 2752 | | -#line 672 "pikchr.y" |
| 2757 | +#line 677 "pikchr.y" |
| 2753 | 2758 | {yylhsminor.yy43 = pik_position_between(yymsp[-4].minor.yy265,yymsp[-2].minor.yy43,yymsp[0].minor.yy43);} |
| 2754 | | -#line 2779 "pikchr.c" |
| 2759 | +#line 2784 "pikchr.c" |
| 2755 | 2760 | yymsp[-4].minor.yy43 = yylhsminor.yy43; |
| 2756 | 2761 | break; |
| 2757 | 2762 | case 72: /* position ::= expr LT position COMMA position GT */ |
| 2758 | | -#line 674 "pikchr.y" |
| 2763 | +#line 679 "pikchr.y" |
| 2759 | 2764 | {yylhsminor.yy43 = pik_position_between(yymsp[-5].minor.yy265,yymsp[-3].minor.yy43,yymsp[-1].minor.yy43);} |
| 2760 | | -#line 2785 "pikchr.c" |
| 2765 | +#line 2790 "pikchr.c" |
| 2761 | 2766 | yymsp[-5].minor.yy43 = yylhsminor.yy43; |
| 2762 | 2767 | break; |
| 2763 | 2768 | case 73: /* position ::= expr ABOVE position */ |
| 2764 | | -#line 675 "pikchr.y" |
| 2769 | +#line 680 "pikchr.y" |
| 2765 | 2770 | {yylhsminor.yy43=yymsp[0].minor.yy43; yylhsminor.yy43.y += yymsp[-2].minor.yy265;} |
| 2766 | | -#line 2791 "pikchr.c" |
| 2771 | +#line 2796 "pikchr.c" |
| 2767 | 2772 | yymsp[-2].minor.yy43 = yylhsminor.yy43; |
| 2768 | 2773 | break; |
| 2769 | 2774 | case 74: /* position ::= expr BELOW position */ |
| 2770 | | -#line 676 "pikchr.y" |
| 2775 | +#line 681 "pikchr.y" |
| 2771 | 2776 | {yylhsminor.yy43=yymsp[0].minor.yy43; yylhsminor.yy43.y -= yymsp[-2].minor.yy265;} |
| 2772 | | -#line 2797 "pikchr.c" |
| 2777 | +#line 2802 "pikchr.c" |
| 2773 | 2778 | yymsp[-2].minor.yy43 = yylhsminor.yy43; |
| 2774 | 2779 | break; |
| 2775 | 2780 | case 75: /* position ::= expr LEFT OF position */ |
| 2776 | | -#line 677 "pikchr.y" |
| 2781 | +#line 682 "pikchr.y" |
| 2777 | 2782 | {yylhsminor.yy43=yymsp[0].minor.yy43; yylhsminor.yy43.x -= yymsp[-3].minor.yy265;} |
| 2778 | | -#line 2803 "pikchr.c" |
| 2783 | +#line 2808 "pikchr.c" |
| 2779 | 2784 | yymsp[-3].minor.yy43 = yylhsminor.yy43; |
| 2780 | 2785 | break; |
| 2781 | 2786 | case 76: /* position ::= expr RIGHT OF position */ |
| 2782 | | -#line 678 "pikchr.y" |
| 2787 | +#line 683 "pikchr.y" |
| 2783 | 2788 | {yylhsminor.yy43=yymsp[0].minor.yy43; yylhsminor.yy43.x += yymsp[-3].minor.yy265;} |
| 2784 | | -#line 2809 "pikchr.c" |
| 2789 | +#line 2814 "pikchr.c" |
| 2785 | 2790 | yymsp[-3].minor.yy43 = yylhsminor.yy43; |
| 2786 | 2791 | break; |
| 2787 | 2792 | case 77: /* position ::= expr ON HEADING EDGEPT OF position */ |
| 2788 | | -#line 680 "pikchr.y" |
| 2793 | +#line 685 "pikchr.y" |
| 2789 | 2794 | {yylhsminor.yy43 = pik_position_at_hdg(yymsp[-5].minor.yy265,&yymsp[-2].minor.yy0,yymsp[0].minor.yy43);} |
| 2790 | | -#line 2815 "pikchr.c" |
| 2795 | +#line 2820 "pikchr.c" |
| 2791 | 2796 | yymsp[-5].minor.yy43 = yylhsminor.yy43; |
| 2792 | 2797 | break; |
| 2793 | 2798 | case 78: /* position ::= expr HEADING EDGEPT OF position */ |
| 2794 | | -#line 682 "pikchr.y" |
| 2799 | +#line 687 "pikchr.y" |
| 2795 | 2800 | {yylhsminor.yy43 = pik_position_at_hdg(yymsp[-4].minor.yy265,&yymsp[-2].minor.yy0,yymsp[0].minor.yy43);} |
| 2796 | | -#line 2821 "pikchr.c" |
| 2801 | +#line 2826 "pikchr.c" |
| 2797 | 2802 | yymsp[-4].minor.yy43 = yylhsminor.yy43; |
| 2798 | 2803 | break; |
| 2799 | 2804 | case 79: /* position ::= expr EDGEPT OF position */ |
| 2800 | | -#line 684 "pikchr.y" |
| 2805 | +#line 689 "pikchr.y" |
| 2801 | 2806 | {yylhsminor.yy43 = pik_position_at_hdg(yymsp[-3].minor.yy265,&yymsp[-2].minor.yy0,yymsp[0].minor.yy43);} |
| 2802 | | -#line 2827 "pikchr.c" |
| 2807 | +#line 2832 "pikchr.c" |
| 2803 | 2808 | yymsp[-3].minor.yy43 = yylhsminor.yy43; |
| 2804 | 2809 | break; |
| 2805 | 2810 | case 80: /* position ::= expr ON HEADING expr FROM position */ |
| 2806 | | -#line 686 "pikchr.y" |
| 2811 | +#line 691 "pikchr.y" |
| 2807 | 2812 | {yylhsminor.yy43 = pik_position_at_angle(yymsp[-5].minor.yy265,yymsp[-2].minor.yy265,yymsp[0].minor.yy43);} |
| 2808 | | -#line 2833 "pikchr.c" |
| 2813 | +#line 2838 "pikchr.c" |
| 2809 | 2814 | yymsp[-5].minor.yy43 = yylhsminor.yy43; |
| 2810 | 2815 | break; |
| 2811 | 2816 | case 81: /* position ::= expr HEADING expr FROM position */ |
| 2812 | | -#line 688 "pikchr.y" |
| 2817 | +#line 693 "pikchr.y" |
| 2813 | 2818 | {yylhsminor.yy43 = pik_position_at_angle(yymsp[-4].minor.yy265,yymsp[-2].minor.yy265,yymsp[0].minor.yy43);} |
| 2814 | | -#line 2839 "pikchr.c" |
| 2819 | +#line 2844 "pikchr.c" |
| 2815 | 2820 | yymsp[-4].minor.yy43 = yylhsminor.yy43; |
| 2816 | 2821 | break; |
| 2817 | 2822 | case 82: /* place ::= edge OF object */ |
| 2818 | | -#line 700 "pikchr.y" |
| 2823 | +#line 705 "pikchr.y" |
| 2819 | 2824 | {yylhsminor.yy43 = pik_place_of_elem(p,yymsp[0].minor.yy38,&yymsp[-2].minor.yy0);} |
| 2820 | | -#line 2845 "pikchr.c" |
| 2825 | +#line 2850 "pikchr.c" |
| 2821 | 2826 | yymsp[-2].minor.yy43 = yylhsminor.yy43; |
| 2822 | 2827 | break; |
| 2823 | 2828 | case 83: /* place2 ::= object */ |
| 2824 | | -#line 701 "pikchr.y" |
| 2829 | +#line 706 "pikchr.y" |
| 2825 | 2830 | {yylhsminor.yy43 = pik_place_of_elem(p,yymsp[0].minor.yy38,0);} |
| 2826 | | -#line 2851 "pikchr.c" |
| 2831 | +#line 2856 "pikchr.c" |
| 2827 | 2832 | yymsp[0].minor.yy43 = yylhsminor.yy43; |
| 2828 | 2833 | break; |
| 2829 | 2834 | case 84: /* place2 ::= object DOT_E edge */ |
| 2830 | | -#line 702 "pikchr.y" |
| 2835 | +#line 707 "pikchr.y" |
| 2831 | 2836 | {yylhsminor.yy43 = pik_place_of_elem(p,yymsp[-2].minor.yy38,&yymsp[0].minor.yy0);} |
| 2832 | | -#line 2857 "pikchr.c" |
| 2837 | +#line 2862 "pikchr.c" |
| 2833 | 2838 | yymsp[-2].minor.yy43 = yylhsminor.yy43; |
| 2834 | 2839 | break; |
| 2835 | 2840 | case 85: /* place2 ::= NTH VERTEX OF object */ |
| 2836 | | -#line 703 "pikchr.y" |
| 2841 | +#line 708 "pikchr.y" |
| 2837 | 2842 | {yylhsminor.yy43 = pik_nth_vertex(p,&yymsp[-3].minor.yy0,&yymsp[-2].minor.yy0,yymsp[0].minor.yy38);} |
| 2838 | | -#line 2863 "pikchr.c" |
| 2843 | +#line 2868 "pikchr.c" |
| 2839 | 2844 | yymsp[-3].minor.yy43 = yylhsminor.yy43; |
| 2840 | 2845 | break; |
| 2841 | 2846 | case 86: /* object ::= nth */ |
| 2842 | | -#line 715 "pikchr.y" |
| 2847 | +#line 720 "pikchr.y" |
| 2843 | 2848 | {yylhsminor.yy38 = pik_find_nth(p,0,&yymsp[0].minor.yy0);} |
| 2844 | | -#line 2869 "pikchr.c" |
| 2849 | +#line 2874 "pikchr.c" |
| 2845 | 2850 | yymsp[0].minor.yy38 = yylhsminor.yy38; |
| 2846 | 2851 | break; |
| 2847 | 2852 | case 87: /* object ::= nth OF|IN object */ |
| 2848 | | -#line 716 "pikchr.y" |
| 2853 | +#line 721 "pikchr.y" |
| 2849 | 2854 | {yylhsminor.yy38 = pik_find_nth(p,yymsp[0].minor.yy38,&yymsp[-2].minor.yy0);} |
| 2850 | | -#line 2875 "pikchr.c" |
| 2855 | +#line 2880 "pikchr.c" |
| 2851 | 2856 | yymsp[-2].minor.yy38 = yylhsminor.yy38; |
| 2852 | 2857 | break; |
| 2853 | 2858 | case 88: /* objectname ::= PLACENAME */ |
| 2854 | | -#line 718 "pikchr.y" |
| 2859 | +#line 723 "pikchr.y" |
| 2855 | 2860 | {yylhsminor.yy38 = pik_find_byname(p,0,&yymsp[0].minor.yy0);} |
| 2856 | | -#line 2881 "pikchr.c" |
| 2861 | +#line 2886 "pikchr.c" |
| 2857 | 2862 | yymsp[0].minor.yy38 = yylhsminor.yy38; |
| 2858 | 2863 | break; |
| 2859 | 2864 | case 89: /* objectname ::= objectname DOT_U PLACENAME */ |
| 2860 | | -#line 720 "pikchr.y" |
| 2865 | +#line 725 "pikchr.y" |
| 2861 | 2866 | {yylhsminor.yy38 = pik_find_byname(p,yymsp[-2].minor.yy38,&yymsp[0].minor.yy0);} |
| 2862 | | -#line 2887 "pikchr.c" |
| 2867 | +#line 2892 "pikchr.c" |
| 2863 | 2868 | yymsp[-2].minor.yy38 = yylhsminor.yy38; |
| 2864 | 2869 | break; |
| 2865 | 2870 | case 90: /* nth ::= NTH CLASSNAME */ |
| 2866 | | -#line 722 "pikchr.y" |
| 2871 | +#line 727 "pikchr.y" |
| 2867 | 2872 | {yylhsminor.yy0=yymsp[0].minor.yy0; yylhsminor.yy0.eCode = pik_nth_value(p,&yymsp[-1].minor.yy0); } |
| 2868 | | -#line 2893 "pikchr.c" |
| 2873 | +#line 2898 "pikchr.c" |
| 2869 | 2874 | yymsp[-1].minor.yy0 = yylhsminor.yy0; |
| 2870 | 2875 | break; |
| 2871 | 2876 | case 91: /* nth ::= NTH LAST CLASSNAME */ |
| 2872 | | -#line 723 "pikchr.y" |
| 2877 | +#line 728 "pikchr.y" |
| 2873 | 2878 | {yylhsminor.yy0=yymsp[0].minor.yy0; yylhsminor.yy0.eCode = -pik_nth_value(p,&yymsp[-2].minor.yy0); } |
| 2874 | | -#line 2899 "pikchr.c" |
| 2879 | +#line 2904 "pikchr.c" |
| 2875 | 2880 | yymsp[-2].minor.yy0 = yylhsminor.yy0; |
| 2876 | 2881 | break; |
| 2877 | 2882 | case 92: /* nth ::= LAST CLASSNAME */ |
| 2878 | | -#line 724 "pikchr.y" |
| 2883 | +#line 729 "pikchr.y" |
| 2879 | 2884 | {yymsp[-1].minor.yy0=yymsp[0].minor.yy0; yymsp[-1].minor.yy0.eCode = -1;} |
| 2880 | | -#line 2905 "pikchr.c" |
| 2885 | +#line 2910 "pikchr.c" |
| 2881 | 2886 | break; |
| 2882 | 2887 | case 93: /* nth ::= LAST */ |
| 2883 | | -#line 725 "pikchr.y" |
| 2888 | +#line 730 "pikchr.y" |
| 2884 | 2889 | {yylhsminor.yy0=yymsp[0].minor.yy0; yylhsminor.yy0.eCode = -1;} |
| 2885 | | -#line 2910 "pikchr.c" |
| 2890 | +#line 2915 "pikchr.c" |
| 2886 | 2891 | yymsp[0].minor.yy0 = yylhsminor.yy0; |
| 2887 | 2892 | break; |
| 2888 | 2893 | case 94: /* nth ::= NTH LB RB */ |
| 2889 | | -#line 726 "pikchr.y" |
| 2894 | +#line 731 "pikchr.y" |
| 2890 | 2895 | {yylhsminor.yy0=yymsp[-1].minor.yy0; yylhsminor.yy0.eCode = pik_nth_value(p,&yymsp[-2].minor.yy0);} |
| 2891 | | -#line 2916 "pikchr.c" |
| 2896 | +#line 2921 "pikchr.c" |
| 2892 | 2897 | yymsp[-2].minor.yy0 = yylhsminor.yy0; |
| 2893 | 2898 | break; |
| 2894 | 2899 | case 95: /* nth ::= NTH LAST LB RB */ |
| 2895 | | -#line 727 "pikchr.y" |
| 2900 | +#line 732 "pikchr.y" |
| 2896 | 2901 | {yylhsminor.yy0=yymsp[-1].minor.yy0; yylhsminor.yy0.eCode = -pik_nth_value(p,&yymsp[-3].minor.yy0);} |
| 2897 | | -#line 2922 "pikchr.c" |
| 2902 | +#line 2927 "pikchr.c" |
| 2898 | 2903 | yymsp[-3].minor.yy0 = yylhsminor.yy0; |
| 2899 | 2904 | break; |
| 2900 | 2905 | case 96: /* nth ::= LAST LB RB */ |
| 2901 | | -#line 728 "pikchr.y" |
| 2906 | +#line 733 "pikchr.y" |
| 2902 | 2907 | {yymsp[-2].minor.yy0=yymsp[-1].minor.yy0; yymsp[-2].minor.yy0.eCode = -1; } |
| 2903 | | -#line 2928 "pikchr.c" |
| 2908 | +#line 2933 "pikchr.c" |
| 2904 | 2909 | break; |
| 2905 | 2910 | case 97: /* expr ::= expr PLUS expr */ |
| 2906 | | -#line 730 "pikchr.y" |
| 2911 | +#line 735 "pikchr.y" |
| 2907 | 2912 | {yylhsminor.yy265=yymsp[-2].minor.yy265+yymsp[0].minor.yy265;} |
| 2908 | | -#line 2933 "pikchr.c" |
| 2913 | +#line 2938 "pikchr.c" |
| 2909 | 2914 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 2910 | 2915 | break; |
| 2911 | 2916 | case 98: /* expr ::= expr MINUS expr */ |
| 2912 | | -#line 731 "pikchr.y" |
| 2917 | +#line 736 "pikchr.y" |
| 2913 | 2918 | {yylhsminor.yy265=yymsp[-2].minor.yy265-yymsp[0].minor.yy265;} |
| 2914 | | -#line 2939 "pikchr.c" |
| 2919 | +#line 2944 "pikchr.c" |
| 2915 | 2920 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 2916 | 2921 | break; |
| 2917 | 2922 | case 99: /* expr ::= expr STAR expr */ |
| 2918 | | -#line 732 "pikchr.y" |
| 2923 | +#line 737 "pikchr.y" |
| 2919 | 2924 | {yylhsminor.yy265=yymsp[-2].minor.yy265*yymsp[0].minor.yy265;} |
| 2920 | | -#line 2945 "pikchr.c" |
| 2925 | +#line 2950 "pikchr.c" |
| 2921 | 2926 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 2922 | 2927 | break; |
| 2923 | 2928 | case 100: /* expr ::= expr SLASH expr */ |
| 2924 | | -#line 733 "pikchr.y" |
| 2929 | +#line 738 "pikchr.y" |
| 2925 | 2930 | { |
| 2926 | 2931 | if( yymsp[0].minor.yy265==0.0 ){ pik_error(p, &yymsp[-1].minor.yy0, "division by zero"); yylhsminor.yy265 = 0.0; } |
| 2927 | 2932 | else{ yylhsminor.yy265 = yymsp[-2].minor.yy265/yymsp[0].minor.yy265; } |
| 2928 | 2933 | } |
| 2929 | | -#line 2954 "pikchr.c" |
| 2934 | +#line 2959 "pikchr.c" |
| 2930 | 2935 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 2931 | 2936 | break; |
| 2932 | 2937 | case 101: /* expr ::= MINUS expr */ |
| 2933 | | -#line 737 "pikchr.y" |
| 2938 | +#line 742 "pikchr.y" |
| 2934 | 2939 | {yymsp[-1].minor.yy265=-yymsp[0].minor.yy265;} |
| 2935 | | -#line 2960 "pikchr.c" |
| 2940 | +#line 2965 "pikchr.c" |
| 2936 | 2941 | break; |
| 2937 | 2942 | case 102: /* expr ::= PLUS expr */ |
| 2938 | | -#line 738 "pikchr.y" |
| 2943 | +#line 743 "pikchr.y" |
| 2939 | 2944 | {yymsp[-1].minor.yy265=yymsp[0].minor.yy265;} |
| 2940 | | -#line 2965 "pikchr.c" |
| 2945 | +#line 2970 "pikchr.c" |
| 2941 | 2946 | break; |
| 2942 | 2947 | case 103: /* expr ::= LP expr RP */ |
| 2943 | | -#line 739 "pikchr.y" |
| 2948 | +#line 744 "pikchr.y" |
| 2944 | 2949 | {yymsp[-2].minor.yy265=yymsp[-1].minor.yy265;} |
| 2945 | | -#line 2970 "pikchr.c" |
| 2950 | +#line 2975 "pikchr.c" |
| 2946 | 2951 | break; |
| 2947 | 2952 | case 104: /* expr ::= LP FILL|COLOR|THICKNESS RP */ |
| 2948 | | -#line 740 "pikchr.y" |
| 2953 | +#line 745 "pikchr.y" |
| 2949 | 2954 | {yymsp[-2].minor.yy265=pik_get_var(p,&yymsp[-1].minor.yy0);} |
| 2950 | | -#line 2975 "pikchr.c" |
| 2955 | +#line 2980 "pikchr.c" |
| 2951 | 2956 | break; |
| 2952 | 2957 | case 105: /* expr ::= NUMBER */ |
| 2953 | | -#line 741 "pikchr.y" |
| 2958 | +#line 746 "pikchr.y" |
| 2954 | 2959 | {yylhsminor.yy265=pik_atof(&yymsp[0].minor.yy0);} |
| 2955 | | -#line 2980 "pikchr.c" |
| 2960 | +#line 2985 "pikchr.c" |
| 2956 | 2961 | yymsp[0].minor.yy265 = yylhsminor.yy265; |
| 2957 | 2962 | break; |
| 2958 | 2963 | case 106: /* expr ::= ID */ |
| 2959 | | -#line 742 "pikchr.y" |
| 2964 | +#line 747 "pikchr.y" |
| 2960 | 2965 | {yylhsminor.yy265=pik_get_var(p,&yymsp[0].minor.yy0);} |
| 2961 | | -#line 2986 "pikchr.c" |
| 2966 | +#line 2991 "pikchr.c" |
| 2962 | 2967 | yymsp[0].minor.yy265 = yylhsminor.yy265; |
| 2963 | 2968 | break; |
| 2964 | 2969 | case 107: /* expr ::= FUNC1 LP expr RP */ |
| 2965 | | -#line 743 "pikchr.y" |
| 2970 | +#line 748 "pikchr.y" |
| 2966 | 2971 | {yylhsminor.yy265 = pik_func(p,&yymsp[-3].minor.yy0,yymsp[-1].minor.yy265,0.0);} |
| 2967 | | -#line 2992 "pikchr.c" |
| 2972 | +#line 2997 "pikchr.c" |
| 2968 | 2973 | yymsp[-3].minor.yy265 = yylhsminor.yy265; |
| 2969 | 2974 | break; |
| 2970 | 2975 | case 108: /* expr ::= FUNC2 LP expr COMMA expr RP */ |
| 2971 | | -#line 744 "pikchr.y" |
| 2976 | +#line 749 "pikchr.y" |
| 2972 | 2977 | {yylhsminor.yy265 = pik_func(p,&yymsp[-5].minor.yy0,yymsp[-3].minor.yy265,yymsp[-1].minor.yy265);} |
| 2973 | | -#line 2998 "pikchr.c" |
| 2978 | +#line 3003 "pikchr.c" |
| 2974 | 2979 | yymsp[-5].minor.yy265 = yylhsminor.yy265; |
| 2975 | 2980 | break; |
| 2976 | 2981 | case 109: /* expr ::= DIST LP position COMMA position RP */ |
| 2977 | | -#line 745 "pikchr.y" |
| 2982 | +#line 750 "pikchr.y" |
| 2978 | 2983 | {yymsp[-5].minor.yy265 = pik_dist(&yymsp[-3].minor.yy43,&yymsp[-1].minor.yy43);} |
| 2979 | | -#line 3004 "pikchr.c" |
| 2984 | +#line 3009 "pikchr.c" |
| 2980 | 2985 | break; |
| 2981 | 2986 | case 110: /* expr ::= place2 DOT_XY X */ |
| 2982 | | -#line 746 "pikchr.y" |
| 2987 | +#line 751 "pikchr.y" |
| 2983 | 2988 | {yylhsminor.yy265 = yymsp[-2].minor.yy43.x;} |
| 2984 | | -#line 3009 "pikchr.c" |
| 2989 | +#line 3014 "pikchr.c" |
| 2985 | 2990 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 2986 | 2991 | break; |
| 2987 | 2992 | case 111: /* expr ::= place2 DOT_XY Y */ |
| 2988 | | -#line 747 "pikchr.y" |
| 2993 | +#line 752 "pikchr.y" |
| 2989 | 2994 | {yylhsminor.yy265 = yymsp[-2].minor.yy43.y;} |
| 2990 | | -#line 3015 "pikchr.c" |
| 2995 | +#line 3020 "pikchr.c" |
| 2991 | 2996 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 2992 | 2997 | break; |
| 2993 | 2998 | case 112: /* expr ::= object DOT_L numproperty */ |
| 2994 | 2999 | case 113: /* expr ::= object DOT_L dashproperty */ yytestcase(yyruleno==113); |
| 2995 | 3000 | case 114: /* expr ::= object DOT_L colorproperty */ yytestcase(yyruleno==114); |
| 2996 | | -#line 748 "pikchr.y" |
| 3001 | +#line 753 "pikchr.y" |
| 2997 | 3002 | {yylhsminor.yy265=pik_property_of(yymsp[-2].minor.yy38,&yymsp[0].minor.yy0);} |
| 2998 | | -#line 3023 "pikchr.c" |
| 3003 | +#line 3028 "pikchr.c" |
| 2999 | 3004 | yymsp[-2].minor.yy265 = yylhsminor.yy265; |
| 3000 | 3005 | break; |
| 3001 | 3006 | default: |
| 3002 | 3007 | /* (115) lvalue ::= ID */ yytestcase(yyruleno==115); |
| 3003 | 3008 | /* (116) lvalue ::= FILL */ yytestcase(yyruleno==116); |
| | @@ -3096,19 +3101,19 @@ |
| 3096 | 3101 | ){ |
| 3097 | 3102 | pik_parserARG_FETCH |
| 3098 | 3103 | pik_parserCTX_FETCH |
| 3099 | 3104 | #define TOKEN yyminor |
| 3100 | 3105 | /************ Begin %syntax_error code ****************************************/ |
| 3101 | | -#line 509 "pikchr.y" |
| 3106 | +#line 514 "pikchr.y" |
| 3102 | 3107 | |
| 3103 | 3108 | if( TOKEN.z && TOKEN.z[0] ){ |
| 3104 | 3109 | pik_error(p, &TOKEN, "syntax error"); |
| 3105 | 3110 | }else{ |
| 3106 | 3111 | pik_error(p, 0, "syntax error"); |
| 3107 | 3112 | } |
| 3108 | 3113 | UNUSED_PARAMETER(yymajor); |
| 3109 | | -#line 3134 "pikchr.c" |
| 3114 | +#line 3139 "pikchr.c" |
| 3110 | 3115 | /************ End %syntax_error code ******************************************/ |
| 3111 | 3116 | pik_parserARG_STORE /* Suppress warning about unused %extra_argument variable */ |
| 3112 | 3117 | pik_parserCTX_STORE |
| 3113 | 3118 | } |
| 3114 | 3119 | |
| | @@ -3337,11 +3342,11 @@ |
| 3337 | 3342 | #else |
| 3338 | 3343 | (void)iToken; |
| 3339 | 3344 | return 0; |
| 3340 | 3345 | #endif |
| 3341 | 3346 | } |
| 3342 | | -#line 753 "pikchr.y" |
| 3347 | +#line 758 "pikchr.y" |
| 3343 | 3348 | |
| 3344 | 3349 | |
| 3345 | 3350 | |
| 3346 | 3351 | /* Chart of the 140 official HTML color names with their |
| 3347 | 3352 | ** corresponding RGB value. |
| | @@ -4508,10 +4513,23 @@ |
| 4508 | 4513 | n -= i; |
| 4509 | 4514 | zText += i; |
| 4510 | 4515 | i = 0; |
| 4511 | 4516 | } |
| 4512 | 4517 | } |
| 4518 | + |
| 4519 | +/* |
| 4520 | +** Append error message text. This is either a raw append, or an append |
| 4521 | +** with HTML escapes, depending on whether the PIKCHR_PLAINTEXT_ERRORS flag |
| 4522 | +** is set. |
| 4523 | +*/ |
| 4524 | +static void pik_append_errtxt(Pik *p, const char *zText, int n){ |
| 4525 | + if( p->mFlags & PIKCHR_PLAINTEXT_ERRORS ){ |
| 4526 | + pik_append(p, zText, n); |
| 4527 | + }else{ |
| 4528 | + pik_append_text(p, zText, n, 0); |
| 4529 | + } |
| 4530 | +} |
| 4513 | 4531 | |
| 4514 | 4532 | /* Append a PNum value |
| 4515 | 4533 | */ |
| 4516 | 4534 | static void pik_append_num(Pik *p, const char *z,PNum v){ |
| 4517 | 4535 | char buf[100]; |
| | @@ -4894,11 +4912,11 @@ |
| 4894 | 4912 | while( iFirstLineno<=iLineno ){ |
| 4895 | 4913 | snprintf(zLineno,sizeof(zLineno)-1,"/* %4d */ ", iFirstLineno++); |
| 4896 | 4914 | zLineno[sizeof(zLineno)-1] = 0; |
| 4897 | 4915 | pik_append(p, zLineno, -1); |
| 4898 | 4916 | for(i=iStart; p->sIn.z[i]!=0 && p->sIn.z[i]!='\n'; i++){} |
| 4899 | | - pik_append_text(p, p->sIn.z+iStart, i-iStart, 0); |
| 4917 | + pik_append_errtxt(p, p->sIn.z+iStart, i-iStart); |
| 4900 | 4918 | iStart = i+1; |
| 4901 | 4919 | pik_append(p, "\n", 1); |
| 4902 | 4920 | } |
| 4903 | 4921 | for(iErrCol=0, i=iErrPt; i>0 && p->sIn.z[i]!='\n'; iErrCol++, i--){} |
| 4904 | 4922 | for(i=0; i<iErrCol+11; i++){ pik_append(p, " ", 1); } |
| | @@ -4918,28 +4936,36 @@ |
| 4918 | 4936 | int i; |
| 4919 | 4937 | if( p==0 ) return; |
| 4920 | 4938 | if( p->nErr ) return; |
| 4921 | 4939 | p->nErr++; |
| 4922 | 4940 | if( zMsg==0 ){ |
| 4923 | | - pik_append(p, "\n<div><p>Out of memory</p></div>\n", -1); |
| 4941 | + if( p->mFlags & PIKCHR_PLAINTEXT_ERRORS ){ |
| 4942 | + pik_append(p, "\nOut of memory\n", -1); |
| 4943 | + }else{ |
| 4944 | + pik_append(p, "\n<div><p>Out of memory</p></div>\n", -1); |
| 4945 | + } |
| 4924 | 4946 | return; |
| 4925 | 4947 | } |
| 4926 | 4948 | if( pErr==0 ){ |
| 4927 | 4949 | pik_append(p, "\n", 1); |
| 4928 | | - pik_append_text(p, zMsg, -1, 0); |
| 4950 | + pik_append_errtxt(p, zMsg, -1); |
| 4929 | 4951 | return; |
| 4930 | 4952 | } |
| 4931 | | - pik_append(p, "<div><pre>\n", -1); |
| 4953 | + if( (p->mFlags & PIKCHR_PLAINTEXT_ERRORS)==0 ){ |
| 4954 | + pik_append(p, "<div><pre>\n", -1); |
| 4955 | + } |
| 4932 | 4956 | pik_error_context(p, pErr, 5); |
| 4933 | 4957 | pik_append(p, "ERROR: ", -1); |
| 4934 | | - pik_append_text(p, zMsg, -1, 0); |
| 4958 | + pik_append_errtxt(p, zMsg, -1); |
| 4935 | 4959 | pik_append(p, "\n", 1); |
| 4936 | 4960 | for(i=p->nCtx-1; i>=0; i--){ |
| 4937 | 4961 | pik_append(p, "Called from:\n", -1); |
| 4938 | 4962 | pik_error_context(p, &p->aCtx[i], 0); |
| 4939 | 4963 | } |
| 4940 | | - pik_append(p, "</pre></div>\n", -1); |
| 4964 | + if( (p->mFlags & PIKCHR_PLAINTEXT_ERRORS)==0 ){ |
| 4965 | + pik_append(p, "</pre></div>\n", -1); |
| 4966 | + } |
| 4941 | 4967 | } |
| 4942 | 4968 | |
| 4943 | 4969 | /* |
| 4944 | 4970 | ** Process an "assert( e1 == e2 )" statement. Always return NULL. |
| 4945 | 4971 | */ |
| | @@ -7353,13 +7379,13 @@ |
| 7353 | 7379 | token.eEdge = 0; |
| 7354 | 7380 | token.z = pIn->z + i; |
| 7355 | 7381 | sz = pik_token_length(&token, 1); |
| 7356 | 7382 | if( token.eType==T_WHITESPACE ){ |
| 7357 | 7383 | /* no-op */ |
| 7358 | | - }else if( sz>1000 ){ |
| 7384 | + }else if( sz>50000 ){ |
| 7359 | 7385 | token.n = 1; |
| 7360 | | - pik_error(p, &token, "token is too long - max length 1000 bytes"); |
| 7386 | + pik_error(p, &token, "token is too long - max length 50000 bytes"); |
| 7361 | 7387 | break; |
| 7362 | 7388 | }else if( token.eType==T_ERROR ){ |
| 7363 | 7389 | token.n = (unsigned short)(sz & 0xffff); |
| 7364 | 7390 | pik_error(p, &token, "unrecognized token"); |
| 7365 | 7391 | break; |
| | @@ -7535,10 +7561,12 @@ |
| 7535 | 7561 | */ |
| 7536 | 7562 | int main(int argc, char **argv){ |
| 7537 | 7563 | int i; |
| 7538 | 7564 | int bSvgOnly = 0; /* Output SVG only. No HTML wrapper */ |
| 7539 | 7565 | int bDontStop = 0; /* Continue in spite of errors */ |
| 7566 | + int exitCode = 0; /* What to return */ |
| 7567 | + int mFlags = 0; /* mFlags argument to pikchr() */ |
| 7540 | 7568 | const char *zHtmlHdr = |
| 7541 | 7569 | "<!DOCTYPE html>\n" |
| 7542 | 7570 | "<html lang=\"en-US\">\n" |
| 7543 | 7571 | "<head>\n<title>PIKCHR Test</title>\n" |
| 7544 | 7572 | "<style>\n" |
| | @@ -7579,10 +7607,11 @@ |
| 7579 | 7607 | if( zHtmlHdr==0 ){ |
| 7580 | 7608 | fprintf(stderr, "the \"%s\" option must come first\n",argv[i]); |
| 7581 | 7609 | exit(1); |
| 7582 | 7610 | } |
| 7583 | 7611 | bSvgOnly = 1; |
| 7612 | + mFlags |= PIKCHR_PLAINTEXT_ERRORS; |
| 7584 | 7613 | }else |
| 7585 | 7614 | { |
| 7586 | 7615 | fprintf(stderr,"unknown option: \"%s\"\n", argv[i]); |
| 7587 | 7616 | usage(argv[0]); |
| 7588 | 7617 | } |
| | @@ -7603,11 +7632,11 @@ |
| 7603 | 7632 | continue; |
| 7604 | 7633 | } |
| 7605 | 7634 | sz = fread(zIn, 1, sz, in); |
| 7606 | 7635 | fclose(in); |
| 7607 | 7636 | zIn[sz] = 0; |
| 7608 | | - zOut = pikchr(zIn, "pikchr", 0, &w, &h); |
| 7637 | + zOut = pikchr(zIn, "pikchr", mFlags, &w, &h); |
| 7609 | 7638 | if( zOut==0 ){ |
| 7610 | 7639 | fprintf(stderr, "pikchr() returns NULL. Out of memory?\n"); |
| 7611 | 7640 | if( !bDontStop ) exit(1); |
| 7612 | 7641 | }else if( bSvgOnly ){ |
| 7613 | 7642 | printf("%s\n", zOut); |
| | @@ -7617,10 +7646,11 @@ |
| 7617 | 7646 | zHtmlHdr = 0; |
| 7618 | 7647 | } |
| 7619 | 7648 | printf("<h1>File %s</h1>\n", argv[i]); |
| 7620 | 7649 | if( w<0 ){ |
| 7621 | 7650 | printf("<p>ERROR</p>\n%s\n", zOut); |
| 7651 | + exitCode = 1; |
| 7622 | 7652 | }else{ |
| 7623 | 7653 | printf("<div id=\"svg-%d\" onclick=\"toggleHidden('svg-%d')\">\n",i,i); |
| 7624 | 7654 | printf("<div style='border:3px solid lightgray;max-width:%dpx;'>\n",w); |
| 7625 | 7655 | printf("%s</div>\n", zOut); |
| 7626 | 7656 | printf("<pre class='hidden'>"); |
| | @@ -7632,10 +7662,70 @@ |
| 7632 | 7662 | free(zIn); |
| 7633 | 7663 | } |
| 7634 | 7664 | if( !bSvgOnly ){ |
| 7635 | 7665 | printf("</body></html>\n"); |
| 7636 | 7666 | } |
| 7637 | | - return 0; |
| 7667 | + return exitCode; |
| 7638 | 7668 | } |
| 7639 | 7669 | #endif /* PIKCHR_SHELL */ |
| 7640 | 7670 | |
| 7641 | | -#line 7666 "pikchr.c" |
| 7671 | +#ifdef PIKCHR_TCL |
| 7672 | +#include <tcl.h> |
| 7673 | +/* |
| 7674 | +** An interface to TCL |
| 7675 | +** |
| 7676 | +** TCL command: pikchr $INPUTTEXT |
| 7677 | +** |
| 7678 | +** Returns a list of 3 elements which are the output text, the width, and |
| 7679 | +** the height. |
| 7680 | +** |
| 7681 | +** Register the "pikchr" command by invoking Pikchr_Init(Tcl_Interp*). Or |
| 7682 | +** compile this source file as a shared library and load it using the |
| 7683 | +** "load" command of Tcl. |
| 7684 | +** |
| 7685 | +** Compile this source-code file into a shared library using a command |
| 7686 | +** similar to this: |
| 7687 | +** |
| 7688 | +** gcc -c pikchr.so -DPIKCHR_TCL -shared pikchr.c |
| 7689 | +*/ |
| 7690 | +static int pik_tcl_command( |
| 7691 | + ClientData clientData, /* Not Used */ |
| 7692 | + Tcl_Interp *interp, /* The TCL interpreter that invoked this command */ |
| 7693 | + int objc, /* Number of arguments */ |
| 7694 | + Tcl_Obj *CONST objv[] /* Command arguments */ |
| 7695 | +){ |
| 7696 | + int w, h; /* Width and height of the pikchr */ |
| 7697 | + const char *zIn; /* Source text input */ |
| 7698 | + char *zOut; /* SVG output text */ |
| 7699 | + Tcl_Obj *pRes; /* The result TCL object */ |
| 7700 | + |
| 7701 | + if( objc!=2 ){ |
| 7702 | + Tcl_WrongNumArgs(interp, 1, objv, "PIKCHR_SOURCE_TEXT"); |
| 7703 | + return TCL_ERROR; |
| 7704 | + } |
| 7705 | + zIn = Tcl_GetString(objv[1]); |
| 7706 | + w = h = 0; |
| 7707 | + zOut = pikchr(zIn, "pikchr", 0, &w, &h); |
| 7708 | + if( zOut==0 ){ |
| 7709 | + return TCL_ERROR; /* Out of memory */ |
| 7710 | + } |
| 7711 | + pRes = Tcl_NewObj(); |
| 7712 | + Tcl_ListObjAppendElement(0, pRes, Tcl_NewStringObj(zOut, -1)); |
| 7713 | + free(zOut); |
| 7714 | + Tcl_ListObjAppendElement(0, pRes, Tcl_NewIntObj(w)); |
| 7715 | + Tcl_ListObjAppendElement(0, pRes, Tcl_NewIntObj(h)); |
| 7716 | + Tcl_SetObjResult(interp, pRes); |
| 7717 | + return TCL_OK; |
| 7718 | +} |
| 7719 | + |
| 7720 | +/* Invoke this routine to register the "pikchr" command with the interpreter |
| 7721 | +** given in the argument */ |
| 7722 | +int Pikchr_Init(Tcl_Interp *interp){ |
| 7723 | + Tcl_CreateObjCommand(interp, "pikchr", pik_tcl_command, 0, 0); |
| 7724 | + return TCL_OK; |
| 7725 | +} |
| 7726 | + |
| 7727 | + |
| 7728 | +#endif /* PIKCHR_TCL */ |
| 7729 | + |
| 7730 | + |
| 7731 | +#line 7756 "pikchr.c" |
| 7642 | 7732 | |