| | @@ -1,7 +1,8 @@ |
| 1 | 1 | /* This file is automatically generated by Lemon from input grammar |
| 2 | | -** source file "pikchr.y". */ |
| 2 | +** source file "pikchr.y". |
| 3 | +*/ |
| 3 | 4 | /* |
| 4 | 5 | ** Zero-Clause BSD license: |
| 5 | 6 | ** |
| 6 | 7 | ** Copyright (C) 2020-09-01 by D. Richard Hipp <[email protected]> |
| 7 | 8 | ** |
| | @@ -319,10 +320,11 @@ |
| 319 | 320 | char cw; /* True for clockwise arc */ |
| 320 | 321 | char larrow; /* Arrow at beginning (<- or <->) */ |
| 321 | 322 | char rarrow; /* Arrow at end (-> or <->) */ |
| 322 | 323 | char bClose; /* True if "close" is seen */ |
| 323 | 324 | char bChop; /* True if "chop" is seen */ |
| 325 | + char bAltAutoFit; /* Always send both h and w into xFit() */ |
| 324 | 326 | unsigned char nTxt; /* Number of text values */ |
| 325 | 327 | unsigned mProp; /* Masks of properties set so far */ |
| 326 | 328 | unsigned mCalc; /* Values computed from other constraints */ |
| 327 | 329 | PToken aTxt[5]; /* Text with .eCode holding TP flags */ |
| 328 | 330 | int iLayer; /* Rendering order */ |
| | @@ -490,11 +492,11 @@ |
| 490 | 492 | static PObj *pik_position_assert(Pik*,PPoint*,PToken*,PPoint*); |
| 491 | 493 | static PNum pik_dist(PPoint*,PPoint*); |
| 492 | 494 | static void pik_add_macro(Pik*,PToken *pId,PToken *pCode); |
| 493 | 495 | |
| 494 | 496 | |
| 495 | | -#line 521 "pikchr.c" |
| 497 | +#line 523 "pikchr.c" |
| 496 | 498 | /**************** End of %include directives **********************************/ |
| 497 | 499 | /* These constants specify the various numeric values for terminal symbols. |
| 498 | 500 | ***************** Begin token definitions *************************************/ |
| 499 | 501 | #ifndef T_ID |
| 500 | 502 | #define T_ID 1 |
| | @@ -634,10 +636,13 @@ |
| 634 | 636 | ** pik_parserARG_PDECL A parameter declaration for the %extra_argument |
| 635 | 637 | ** pik_parserARG_PARAM Code to pass %extra_argument as a subroutine parameter |
| 636 | 638 | ** pik_parserARG_STORE Code to store %extra_argument into yypParser |
| 637 | 639 | ** pik_parserARG_FETCH Code to extract %extra_argument from yypParser |
| 638 | 640 | ** pik_parserCTX_* As pik_parserARG_ except for %extra_context |
| 641 | +** YYREALLOC Name of the realloc() function to use |
| 642 | +** YYFREE Name of the free() function to use |
| 643 | +** YYDYNSTACK True if stack space should be extended on heap |
| 639 | 644 | ** YYERRORSYMBOL is the code number of the error symbol. If not |
| 640 | 645 | ** defined, then do no error processing. |
| 641 | 646 | ** YYNSTATE the combined number of states. |
| 642 | 647 | ** YYNRULE the number of rules in the grammar |
| 643 | 648 | ** YYNTOKEN Number of terminal symbols |
| | @@ -647,10 +652,12 @@ |
| 647 | 652 | ** YY_ERROR_ACTION The yy_action[] code for syntax error |
| 648 | 653 | ** YY_ACCEPT_ACTION The yy_action[] code for accept |
| 649 | 654 | ** YY_NO_ACTION The yy_action[] code for no-op |
| 650 | 655 | ** YY_MIN_REDUCE Minimum value for reduce actions |
| 651 | 656 | ** YY_MAX_REDUCE Maximum value for reduce actions |
| 657 | +** YY_MIN_DSTRCTR Minimum symbol value that has a destructor |
| 658 | +** YY_MAX_DSTRCTR Maximum symbol value that has a destructor |
| 652 | 659 | */ |
| 653 | 660 | #ifndef INTERFACE |
| 654 | 661 | # define INTERFACE 1 |
| 655 | 662 | #endif |
| 656 | 663 | /************* Begin control #defines *****************************************/ |
| | @@ -674,10 +681,13 @@ |
| 674 | 681 | #define pik_parserARG_SDECL |
| 675 | 682 | #define pik_parserARG_PDECL |
| 676 | 683 | #define pik_parserARG_PARAM |
| 677 | 684 | #define pik_parserARG_FETCH |
| 678 | 685 | #define pik_parserARG_STORE |
| 686 | +#define YYREALLOC realloc |
| 687 | +#define YYFREE free |
| 688 | +#define YYDYNSTACK 0 |
| 679 | 689 | #define pik_parserCTX_SDECL Pik *p; |
| 680 | 690 | #define pik_parserCTX_PDECL ,Pik *p |
| 681 | 691 | #define pik_parserCTX_PARAM ,p |
| 682 | 692 | #define pik_parserCTX_FETCH Pik *p=yypParser->p; |
| 683 | 693 | #define pik_parserCTX_STORE yypParser->p=p; |
| | @@ -692,10 +702,12 @@ |
| 692 | 702 | #define YY_ERROR_ACTION 443 |
| 693 | 703 | #define YY_ACCEPT_ACTION 444 |
| 694 | 704 | #define YY_NO_ACTION 445 |
| 695 | 705 | #define YY_MIN_REDUCE 446 |
| 696 | 706 | #define YY_MAX_REDUCE 601 |
| 707 | +#define YY_MIN_DSTRCTR 100 |
| 708 | +#define YY_MAX_DSTRCTR 103 |
| 697 | 709 | /************* End control #defines *******************************************/ |
| 698 | 710 | #define YY_NLOOKAHEAD ((int)(sizeof(yy_lookahead)/sizeof(yy_lookahead[0]))) |
| 699 | 711 | |
| 700 | 712 | /* Define the yytestcase() macro to be a no-op if is not already defined |
| 701 | 713 | ** otherwise. |
| | @@ -706,10 +718,26 @@ |
| 706 | 718 | ** for testing. |
| 707 | 719 | */ |
| 708 | 720 | #ifndef yytestcase |
| 709 | 721 | # define yytestcase(X) |
| 710 | 722 | #endif |
| 723 | + |
| 724 | +/* Macro to determine if stack space has the ability to grow using |
| 725 | +** heap memory. |
| 726 | +*/ |
| 727 | +#if YYSTACKDEPTH<=0 || YYDYNSTACK |
| 728 | +# define YYGROWABLESTACK 1 |
| 729 | +#else |
| 730 | +# define YYGROWABLESTACK 0 |
| 731 | +#endif |
| 732 | + |
| 733 | +/* Guarantee a minimum number of initial stack slots. |
| 734 | +*/ |
| 735 | +#if YYSTACKDEPTH<=0 |
| 736 | +# undef YYSTACKDEPTH |
| 737 | +# define YYSTACKDEPTH 2 /* Need a minimum stack size */ |
| 738 | +#endif |
| 711 | 739 | |
| 712 | 740 | |
| 713 | 741 | /* Next are the tables used to determine what action to take based on the |
| 714 | 742 | ** current state and lookahead token. These tables are used to implement |
| 715 | 743 | ** functions that take a state number and lookahead value and return an |
| | @@ -1250,18 +1278,13 @@ |
| 1250 | 1278 | #ifndef YYNOERRORRECOVERY |
| 1251 | 1279 | int yyerrcnt; /* Shifts left before out of the error */ |
| 1252 | 1280 | #endif |
| 1253 | 1281 | pik_parserARG_SDECL /* A place to hold %extra_argument */ |
| 1254 | 1282 | pik_parserCTX_SDECL /* A place to hold %extra_context */ |
| 1255 | | -#if YYSTACKDEPTH<=0 |
| 1256 | | - int yystksz; /* Current side of the stack */ |
| 1257 | | - yyStackEntry *yystack; /* The parser's stack */ |
| 1258 | | - yyStackEntry yystk0; /* First stack entry */ |
| 1259 | | -#else |
| 1260 | | - yyStackEntry yystack[YYSTACKDEPTH]; /* The parser's stack */ |
| 1261 | | - yyStackEntry *yystackEnd; /* Last entry in the stack */ |
| 1262 | | -#endif |
| 1283 | + yyStackEntry *yystackEnd; /* Last entry in the stack */ |
| 1284 | + yyStackEntry *yystack; /* The parser stack */ |
| 1285 | + yyStackEntry yystk0[YYSTACKDEPTH]; /* Initial stack space */ |
| 1263 | 1286 | }; |
| 1264 | 1287 | typedef struct yyParser yyParser; |
| 1265 | 1288 | |
| 1266 | 1289 | #include <assert.h> |
| 1267 | 1290 | #ifndef NDEBUG |
| | @@ -1601,41 +1624,49 @@ |
| 1601 | 1624 | /* 155 */ "object ::= objectname", |
| 1602 | 1625 | }; |
| 1603 | 1626 | #endif /* NDEBUG */ |
| 1604 | 1627 | |
| 1605 | 1628 | |
| 1606 | | -#if YYSTACKDEPTH<=0 |
| 1629 | +#if YYGROWABLESTACK |
| 1607 | 1630 | /* |
| 1608 | 1631 | ** Try to increase the size of the parser stack. Return the number |
| 1609 | 1632 | ** of errors. Return 0 on success. |
| 1610 | 1633 | */ |
| 1611 | 1634 | static int yyGrowStack(yyParser *p){ |
| 1635 | + int oldSize = 1 + (int)(p->yystackEnd - p->yystack); |
| 1612 | 1636 | int newSize; |
| 1613 | 1637 | int idx; |
| 1614 | 1638 | yyStackEntry *pNew; |
| 1615 | 1639 | |
| 1616 | | - newSize = p->yystksz*2 + 100; |
| 1617 | | - idx = p->yytos ? (int)(p->yytos - p->yystack) : 0; |
| 1618 | | - if( p->yystack==&p->yystk0 ){ |
| 1619 | | - pNew = malloc(newSize*sizeof(pNew[0])); |
| 1620 | | - if( pNew ) pNew[0] = p->yystk0; |
| 1640 | + newSize = oldSize*2 + 100; |
| 1641 | + idx = (int)(p->yytos - p->yystack); |
| 1642 | + if( p->yystack==p->yystk0 ){ |
| 1643 | + pNew = YYREALLOC(0, newSize*sizeof(pNew[0])); |
| 1644 | + if( pNew==0 ) return 1; |
| 1645 | + memcpy(pNew, p->yystack, oldSize*sizeof(pNew[0])); |
| 1621 | 1646 | }else{ |
| 1622 | | - pNew = realloc(p->yystack, newSize*sizeof(pNew[0])); |
| 1647 | + pNew = YYREALLOC(p->yystack, newSize*sizeof(pNew[0])); |
| 1648 | + if( pNew==0 ) return 1; |
| 1623 | 1649 | } |
| 1624 | | - if( pNew ){ |
| 1625 | | - p->yystack = pNew; |
| 1626 | | - p->yytos = &p->yystack[idx]; |
| 1650 | + p->yystack = pNew; |
| 1651 | + p->yytos = &p->yystack[idx]; |
| 1627 | 1652 | #ifndef NDEBUG |
| 1628 | | - if( yyTraceFILE ){ |
| 1629 | | - fprintf(yyTraceFILE,"%sStack grows from %d to %d entries.\n", |
| 1630 | | - yyTracePrompt, p->yystksz, newSize); |
| 1631 | | - } |
| 1653 | + if( yyTraceFILE ){ |
| 1654 | + fprintf(yyTraceFILE,"%sStack grows from %d to %d entries.\n", |
| 1655 | + yyTracePrompt, oldSize, newSize); |
| 1656 | + } |
| 1632 | 1657 | #endif |
| 1633 | | - p->yystksz = newSize; |
| 1634 | | - } |
| 1635 | | - return pNew==0; |
| 1658 | + p->yystackEnd = &p->yystack[newSize-1]; |
| 1659 | + return 0; |
| 1636 | 1660 | } |
| 1661 | +#endif /* YYGROWABLESTACK */ |
| 1662 | + |
| 1663 | +#if !YYGROWABLESTACK |
| 1664 | +/* For builds that do no have a growable stack, yyGrowStack always |
| 1665 | +** returns an error. |
| 1666 | +*/ |
| 1667 | +# define yyGrowStack(X) 1 |
| 1637 | 1668 | #endif |
| 1638 | 1669 | |
| 1639 | 1670 | /* Datatype of the argument to the memory allocated passed as the |
| 1640 | 1671 | ** second argument to pik_parserAlloc() below. This can be changed by |
| 1641 | 1672 | ** putting an appropriate #define in the %include section of the input |
| | @@ -1651,28 +1682,18 @@ |
| 1651 | 1682 | yyParser *yypParser = (yyParser*)yypRawParser; |
| 1652 | 1683 | pik_parserCTX_STORE |
| 1653 | 1684 | #ifdef YYTRACKMAXSTACKDEPTH |
| 1654 | 1685 | yypParser->yyhwm = 0; |
| 1655 | 1686 | #endif |
| 1656 | | -#if YYSTACKDEPTH<=0 |
| 1657 | | - yypParser->yytos = NULL; |
| 1658 | | - yypParser->yystack = NULL; |
| 1659 | | - yypParser->yystksz = 0; |
| 1660 | | - if( yyGrowStack(yypParser) ){ |
| 1661 | | - yypParser->yystack = &yypParser->yystk0; |
| 1662 | | - yypParser->yystksz = 1; |
| 1663 | | - } |
| 1664 | | -#endif |
| 1687 | + yypParser->yystack = yypParser->yystk0; |
| 1688 | + yypParser->yystackEnd = &yypParser->yystack[YYSTACKDEPTH-1]; |
| 1665 | 1689 | #ifndef YYNOERRORRECOVERY |
| 1666 | 1690 | yypParser->yyerrcnt = -1; |
| 1667 | 1691 | #endif |
| 1668 | 1692 | yypParser->yytos = yypParser->yystack; |
| 1669 | 1693 | yypParser->yystack[0].stateno = 0; |
| 1670 | 1694 | yypParser->yystack[0].major = 0; |
| 1671 | | -#if YYSTACKDEPTH>0 |
| 1672 | | - yypParser->yystackEnd = &yypParser->yystack[YYSTACKDEPTH-1]; |
| 1673 | | -#endif |
| 1674 | 1695 | } |
| 1675 | 1696 | |
| 1676 | 1697 | #ifndef pik_parser_ENGINEALWAYSONSTACK |
| 1677 | 1698 | /* |
| 1678 | 1699 | ** This function allocates a new parser. |
| | @@ -1724,22 +1745,22 @@ |
| 1724 | 1745 | ** inside the C code. |
| 1725 | 1746 | */ |
| 1726 | 1747 | /********* Begin destructor definitions ***************************************/ |
| 1727 | 1748 | case 100: /* statement_list */ |
| 1728 | 1749 | { |
| 1729 | | -#line 510 "pikchr.y" |
| 1750 | +#line 511 "pikchr.y" |
| 1730 | 1751 | pik_elist_free(p,(yypminor->yy235)); |
| 1731 | | -#line 1756 "pikchr.c" |
| 1752 | +#line 1777 "pikchr.c" |
| 1732 | 1753 | } |
| 1733 | 1754 | break; |
| 1734 | 1755 | case 101: /* statement */ |
| 1735 | 1756 | case 102: /* unnamed_statement */ |
| 1736 | 1757 | case 103: /* basetype */ |
| 1737 | 1758 | { |
| 1738 | | -#line 512 "pikchr.y" |
| 1759 | +#line 513 "pikchr.y" |
| 1739 | 1760 | pik_elem_free(p,(yypminor->yy162)); |
| 1740 | | -#line 1765 "pikchr.c" |
| 1761 | +#line 1786 "pikchr.c" |
| 1741 | 1762 | } |
| 1742 | 1763 | break; |
| 1743 | 1764 | /********* End destructor definitions *****************************************/ |
| 1744 | 1765 | default: break; /* If no destructor action specified: do nothing */ |
| 1745 | 1766 | } |
| | @@ -1769,13 +1790,30 @@ |
| 1769 | 1790 | /* |
| 1770 | 1791 | ** Clear all secondary memory allocations from the parser |
| 1771 | 1792 | */ |
| 1772 | 1793 | void pik_parserFinalize(void *p){ |
| 1773 | 1794 | yyParser *pParser = (yyParser*)p; |
| 1774 | | - while( pParser->yytos>pParser->yystack ) yy_pop_parser_stack(pParser); |
| 1775 | | -#if YYSTACKDEPTH<=0 |
| 1776 | | - if( pParser->yystack!=&pParser->yystk0 ) free(pParser->yystack); |
| 1795 | + |
| 1796 | + /* In-lined version of calling yy_pop_parser_stack() for each |
| 1797 | + ** element left in the stack */ |
| 1798 | + yyStackEntry *yytos = pParser->yytos; |
| 1799 | + while( yytos>pParser->yystack ){ |
| 1800 | +#ifndef NDEBUG |
| 1801 | + if( yyTraceFILE ){ |
| 1802 | + fprintf(yyTraceFILE,"%sPopping %s\n", |
| 1803 | + yyTracePrompt, |
| 1804 | + yyTokenName[yytos->major]); |
| 1805 | + } |
| 1806 | +#endif |
| 1807 | + if( yytos->major>=YY_MIN_DSTRCTR ){ |
| 1808 | + yy_destructor(pParser, yytos->major, &yytos->minor); |
| 1809 | + } |
| 1810 | + yytos--; |
| 1811 | + } |
| 1812 | + |
| 1813 | +#if YYGROWABLESTACK |
| 1814 | + if( pParser->yystack!=pParser->yystk0 ) YYFREE(pParser->yystack); |
| 1777 | 1815 | #endif |
| 1778 | 1816 | } |
| 1779 | 1817 | |
| 1780 | 1818 | #ifndef pik_parser_ENGINEALWAYSONSTACK |
| 1781 | 1819 | /* |
| | @@ -1953,14 +1991,14 @@ |
| 1953 | 1991 | #endif |
| 1954 | 1992 | while( yypParser->yytos>yypParser->yystack ) yy_pop_parser_stack(yypParser); |
| 1955 | 1993 | /* Here code is inserted which will execute if the parser |
| 1956 | 1994 | ** stack every overflows */ |
| 1957 | 1995 | /******** Begin %stack_overflow code ******************************************/ |
| 1958 | | -#line 544 "pikchr.y" |
| 1996 | +#line 545 "pikchr.y" |
| 1959 | 1997 | |
| 1960 | 1998 | pik_error(p, 0, "parser stack overflow"); |
| 1961 | | -#line 1986 "pikchr.c" |
| 1999 | +#line 2024 "pikchr.c" |
| 1962 | 2000 | /******** End %stack_overflow code ********************************************/ |
| 1963 | 2001 | pik_parserARG_STORE /* Suppress warning about unused %extra_argument var */ |
| 1964 | 2002 | pik_parserCTX_STORE |
| 1965 | 2003 | } |
| 1966 | 2004 | |
| | @@ -2000,29 +2038,23 @@ |
| 2000 | 2038 | if( (int)(yypParser->yytos - yypParser->yystack)>yypParser->yyhwm ){ |
| 2001 | 2039 | yypParser->yyhwm++; |
| 2002 | 2040 | assert( yypParser->yyhwm == (int)(yypParser->yytos - yypParser->yystack) ); |
| 2003 | 2041 | } |
| 2004 | 2042 | #endif |
| 2005 | | -#if YYSTACKDEPTH>0 |
| 2006 | | - if( yypParser->yytos>yypParser->yystackEnd ){ |
| 2007 | | - yypParser->yytos--; |
| 2008 | | - yyStackOverflow(yypParser); |
| 2009 | | - return; |
| 2010 | | - } |
| 2011 | | -#else |
| 2012 | | - if( yypParser->yytos>=&yypParser->yystack[yypParser->yystksz] ){ |
| 2043 | + yytos = yypParser->yytos; |
| 2044 | + if( yytos>yypParser->yystackEnd ){ |
| 2013 | 2045 | if( yyGrowStack(yypParser) ){ |
| 2014 | 2046 | yypParser->yytos--; |
| 2015 | 2047 | yyStackOverflow(yypParser); |
| 2016 | 2048 | return; |
| 2017 | 2049 | } |
| 2050 | + yytos = yypParser->yytos; |
| 2051 | + assert( yytos <= yypParser->yystackEnd ); |
| 2018 | 2052 | } |
| 2019 | | -#endif |
| 2020 | 2053 | if( yyNewState > YY_MAX_SHIFT ){ |
| 2021 | 2054 | yyNewState += YY_MIN_REDUCE - YY_MIN_SHIFTREDUCE; |
| 2022 | 2055 | } |
| 2023 | | - yytos = yypParser->yytos; |
| 2024 | 2056 | yytos->stateno = yyNewState; |
| 2025 | 2057 | yytos->major = yyMajor; |
| 2026 | 2058 | yytos->minor.yy0 = yyMinor; |
| 2027 | 2059 | yyTraceShift(yypParser, yyNewState, "Shift"); |
| 2028 | 2060 | } |
| | @@ -2387,619 +2419,619 @@ |
| 2387 | 2419 | ** break; |
| 2388 | 2420 | */ |
| 2389 | 2421 | /********** Begin reduce actions **********************************************/ |
| 2390 | 2422 | YYMINORTYPE yylhsminor; |
| 2391 | 2423 | case 0: /* document ::= statement_list */ |
| 2392 | | -#line 548 "pikchr.y" |
| 2424 | +#line 549 "pikchr.y" |
| 2393 | 2425 | {pik_render(p,yymsp[0].minor.yy235);} |
| 2394 | | -#line 2419 "pikchr.c" |
| 2426 | +#line 2451 "pikchr.c" |
| 2395 | 2427 | break; |
| 2396 | 2428 | case 1: /* statement_list ::= statement */ |
| 2397 | | -#line 551 "pikchr.y" |
| 2429 | +#line 552 "pikchr.y" |
| 2398 | 2430 | { yylhsminor.yy235 = pik_elist_append(p,0,yymsp[0].minor.yy162); } |
| 2399 | | -#line 2424 "pikchr.c" |
| 2431 | +#line 2456 "pikchr.c" |
| 2400 | 2432 | yymsp[0].minor.yy235 = yylhsminor.yy235; |
| 2401 | 2433 | break; |
| 2402 | 2434 | case 2: /* statement_list ::= statement_list EOL statement */ |
| 2403 | | -#line 553 "pikchr.y" |
| 2435 | +#line 554 "pikchr.y" |
| 2404 | 2436 | { yylhsminor.yy235 = pik_elist_append(p,yymsp[-2].minor.yy235,yymsp[0].minor.yy162); } |
| 2405 | | -#line 2430 "pikchr.c" |
| 2437 | +#line 2462 "pikchr.c" |
| 2406 | 2438 | yymsp[-2].minor.yy235 = yylhsminor.yy235; |
| 2407 | 2439 | break; |
| 2408 | 2440 | case 3: /* statement ::= */ |
| 2409 | | -#line 556 "pikchr.y" |
| 2441 | +#line 557 "pikchr.y" |
| 2410 | 2442 | { yymsp[1].minor.yy162 = 0; } |
| 2411 | | -#line 2436 "pikchr.c" |
| 2443 | +#line 2468 "pikchr.c" |
| 2412 | 2444 | break; |
| 2413 | 2445 | case 4: /* statement ::= direction */ |
| 2414 | | -#line 557 "pikchr.y" |
| 2446 | +#line 558 "pikchr.y" |
| 2415 | 2447 | { pik_set_direction(p,yymsp[0].minor.yy0.eCode); yylhsminor.yy162=0; } |
| 2416 | | -#line 2441 "pikchr.c" |
| 2448 | +#line 2473 "pikchr.c" |
| 2417 | 2449 | yymsp[0].minor.yy162 = yylhsminor.yy162; |
| 2418 | 2450 | break; |
| 2419 | 2451 | case 5: /* statement ::= lvalue ASSIGN rvalue */ |
| 2420 | | -#line 558 "pikchr.y" |
| 2452 | +#line 559 "pikchr.y" |
| 2421 | 2453 | {pik_set_var(p,&yymsp[-2].minor.yy0,yymsp[0].minor.yy21,&yymsp[-1].minor.yy0); yylhsminor.yy162=0;} |
| 2422 | | -#line 2447 "pikchr.c" |
| 2454 | +#line 2479 "pikchr.c" |
| 2423 | 2455 | yymsp[-2].minor.yy162 = yylhsminor.yy162; |
| 2424 | 2456 | break; |
| 2425 | 2457 | case 6: /* statement ::= PLACENAME COLON unnamed_statement */ |
| 2426 | | -#line 560 "pikchr.y" |
| 2458 | +#line 561 "pikchr.y" |
| 2427 | 2459 | { yylhsminor.yy162 = yymsp[0].minor.yy162; pik_elem_setname(p,yymsp[0].minor.yy162,&yymsp[-2].minor.yy0); } |
| 2428 | | -#line 2453 "pikchr.c" |
| 2460 | +#line 2485 "pikchr.c" |
| 2429 | 2461 | yymsp[-2].minor.yy162 = yylhsminor.yy162; |
| 2430 | 2462 | break; |
| 2431 | 2463 | case 7: /* statement ::= PLACENAME COLON position */ |
| 2432 | | -#line 562 "pikchr.y" |
| 2464 | +#line 563 "pikchr.y" |
| 2433 | 2465 | { yylhsminor.yy162 = pik_elem_new(p,0,0,0); |
| 2434 | 2466 | if(yylhsminor.yy162){ yylhsminor.yy162->ptAt = yymsp[0].minor.yy63; pik_elem_setname(p,yylhsminor.yy162,&yymsp[-2].minor.yy0); }} |
| 2435 | | -#line 2460 "pikchr.c" |
| 2467 | +#line 2492 "pikchr.c" |
| 2436 | 2468 | yymsp[-2].minor.yy162 = yylhsminor.yy162; |
| 2437 | 2469 | break; |
| 2438 | 2470 | case 8: /* statement ::= unnamed_statement */ |
| 2439 | | -#line 564 "pikchr.y" |
| 2471 | +#line 565 "pikchr.y" |
| 2440 | 2472 | {yylhsminor.yy162 = yymsp[0].minor.yy162;} |
| 2441 | | -#line 2466 "pikchr.c" |
| 2473 | +#line 2498 "pikchr.c" |
| 2442 | 2474 | yymsp[0].minor.yy162 = yylhsminor.yy162; |
| 2443 | 2475 | break; |
| 2444 | 2476 | case 9: /* statement ::= print prlist */ |
| 2445 | | -#line 565 "pikchr.y" |
| 2477 | +#line 566 "pikchr.y" |
| 2446 | 2478 | {pik_append(p,"<br>\n",5); yymsp[-1].minor.yy162=0;} |
| 2447 | | -#line 2472 "pikchr.c" |
| 2479 | +#line 2504 "pikchr.c" |
| 2448 | 2480 | break; |
| 2449 | 2481 | case 10: /* statement ::= ASSERT LP expr EQ expr RP */ |
| 2450 | | -#line 570 "pikchr.y" |
| 2482 | +#line 571 "pikchr.y" |
| 2451 | 2483 | {yymsp[-5].minor.yy162=pik_assert(p,yymsp[-3].minor.yy21,&yymsp[-2].minor.yy0,yymsp[-1].minor.yy21);} |
| 2452 | | -#line 2477 "pikchr.c" |
| 2484 | +#line 2509 "pikchr.c" |
| 2453 | 2485 | break; |
| 2454 | 2486 | case 11: /* statement ::= ASSERT LP position EQ position RP */ |
| 2455 | | -#line 572 "pikchr.y" |
| 2487 | +#line 573 "pikchr.y" |
| 2456 | 2488 | {yymsp[-5].minor.yy162=pik_position_assert(p,&yymsp[-3].minor.yy63,&yymsp[-2].minor.yy0,&yymsp[-1].minor.yy63);} |
| 2457 | | -#line 2482 "pikchr.c" |
| 2489 | +#line 2514 "pikchr.c" |
| 2458 | 2490 | break; |
| 2459 | 2491 | case 12: /* statement ::= DEFINE ID CODEBLOCK */ |
| 2460 | | -#line 573 "pikchr.y" |
| 2492 | +#line 574 "pikchr.y" |
| 2461 | 2493 | {yymsp[-2].minor.yy162=0; pik_add_macro(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy0);} |
| 2462 | | -#line 2487 "pikchr.c" |
| 2494 | +#line 2519 "pikchr.c" |
| 2463 | 2495 | break; |
| 2464 | 2496 | case 13: /* rvalue ::= PLACENAME */ |
| 2465 | | -#line 584 "pikchr.y" |
| 2497 | +#line 585 "pikchr.y" |
| 2466 | 2498 | {yylhsminor.yy21 = pik_lookup_color(p,&yymsp[0].minor.yy0);} |
| 2467 | | -#line 2492 "pikchr.c" |
| 2499 | +#line 2524 "pikchr.c" |
| 2468 | 2500 | yymsp[0].minor.yy21 = yylhsminor.yy21; |
| 2469 | 2501 | break; |
| 2470 | 2502 | case 14: /* pritem ::= FILL */ |
| 2471 | 2503 | case 15: /* pritem ::= COLOR */ yytestcase(yyruleno==15); |
| 2472 | 2504 | case 16: /* pritem ::= THICKNESS */ yytestcase(yyruleno==16); |
| 2473 | | -#line 589 "pikchr.y" |
| 2505 | +#line 590 "pikchr.y" |
| 2474 | 2506 | {pik_append_num(p,"",pik_value(p,yymsp[0].minor.yy0.z,yymsp[0].minor.yy0.n,0));} |
| 2475 | | -#line 2500 "pikchr.c" |
| 2507 | +#line 2532 "pikchr.c" |
| 2476 | 2508 | break; |
| 2477 | 2509 | case 17: /* pritem ::= rvalue */ |
| 2478 | | -#line 592 "pikchr.y" |
| 2510 | +#line 593 "pikchr.y" |
| 2479 | 2511 | {pik_append_num(p,"",yymsp[0].minor.yy21);} |
| 2480 | | -#line 2505 "pikchr.c" |
| 2512 | +#line 2537 "pikchr.c" |
| 2481 | 2513 | break; |
| 2482 | 2514 | case 18: /* pritem ::= STRING */ |
| 2483 | | -#line 593 "pikchr.y" |
| 2515 | +#line 594 "pikchr.y" |
| 2484 | 2516 | {pik_append_text(p,yymsp[0].minor.yy0.z+1,yymsp[0].minor.yy0.n-2,0);} |
| 2485 | | -#line 2510 "pikchr.c" |
| 2517 | +#line 2542 "pikchr.c" |
| 2486 | 2518 | break; |
| 2487 | 2519 | case 19: /* prsep ::= COMMA */ |
| 2488 | | -#line 594 "pikchr.y" |
| 2520 | +#line 595 "pikchr.y" |
| 2489 | 2521 | {pik_append(p, " ", 1);} |
| 2490 | | -#line 2515 "pikchr.c" |
| 2522 | +#line 2547 "pikchr.c" |
| 2491 | 2523 | break; |
| 2492 | 2524 | case 20: /* unnamed_statement ::= basetype attribute_list */ |
| 2493 | | -#line 597 "pikchr.y" |
| 2525 | +#line 598 "pikchr.y" |
| 2494 | 2526 | {yylhsminor.yy162 = yymsp[-1].minor.yy162; pik_after_adding_attributes(p,yylhsminor.yy162);} |
| 2495 | | -#line 2520 "pikchr.c" |
| 2527 | +#line 2552 "pikchr.c" |
| 2496 | 2528 | yymsp[-1].minor.yy162 = yylhsminor.yy162; |
| 2497 | 2529 | break; |
| 2498 | 2530 | case 21: /* basetype ::= CLASSNAME */ |
| 2499 | | -#line 599 "pikchr.y" |
| 2531 | +#line 600 "pikchr.y" |
| 2500 | 2532 | {yylhsminor.yy162 = pik_elem_new(p,&yymsp[0].minor.yy0,0,0); } |
| 2501 | | -#line 2526 "pikchr.c" |
| 2533 | +#line 2558 "pikchr.c" |
| 2502 | 2534 | yymsp[0].minor.yy162 = yylhsminor.yy162; |
| 2503 | 2535 | break; |
| 2504 | 2536 | case 22: /* basetype ::= STRING textposition */ |
| 2505 | | -#line 601 "pikchr.y" |
| 2537 | +#line 602 "pikchr.y" |
| 2506 | 2538 | {yymsp[-1].minor.yy0.eCode = yymsp[0].minor.yy188; yylhsminor.yy162 = pik_elem_new(p,0,&yymsp[-1].minor.yy0,0); } |
| 2507 | | -#line 2532 "pikchr.c" |
| 2539 | +#line 2564 "pikchr.c" |
| 2508 | 2540 | yymsp[-1].minor.yy162 = yylhsminor.yy162; |
| 2509 | 2541 | break; |
| 2510 | 2542 | case 23: /* basetype ::= LB savelist statement_list RB */ |
| 2511 | | -#line 603 "pikchr.y" |
| 2543 | +#line 604 "pikchr.y" |
| 2512 | 2544 | { p->list = yymsp[-2].minor.yy235; yymsp[-3].minor.yy162 = pik_elem_new(p,0,0,yymsp[-1].minor.yy235); if(yymsp[-3].minor.yy162) yymsp[-3].minor.yy162->errTok = yymsp[0].minor.yy0; } |
| 2513 | | -#line 2538 "pikchr.c" |
| 2545 | +#line 2570 "pikchr.c" |
| 2514 | 2546 | break; |
| 2515 | 2547 | case 24: /* savelist ::= */ |
| 2516 | | -#line 608 "pikchr.y" |
| 2548 | +#line 609 "pikchr.y" |
| 2517 | 2549 | {yymsp[1].minor.yy235 = p->list; p->list = 0;} |
| 2518 | | -#line 2543 "pikchr.c" |
| 2550 | +#line 2575 "pikchr.c" |
| 2519 | 2551 | break; |
| 2520 | 2552 | case 25: /* relexpr ::= expr */ |
| 2521 | | -#line 615 "pikchr.y" |
| 2553 | +#line 616 "pikchr.y" |
| 2522 | 2554 | {yylhsminor.yy72.rAbs = yymsp[0].minor.yy21; yylhsminor.yy72.rRel = 0;} |
| 2523 | | -#line 2548 "pikchr.c" |
| 2555 | +#line 2580 "pikchr.c" |
| 2524 | 2556 | yymsp[0].minor.yy72 = yylhsminor.yy72; |
| 2525 | 2557 | break; |
| 2526 | 2558 | case 26: /* relexpr ::= expr PERCENT */ |
| 2527 | | -#line 616 "pikchr.y" |
| 2559 | +#line 617 "pikchr.y" |
| 2528 | 2560 | {yylhsminor.yy72.rAbs = 0; yylhsminor.yy72.rRel = yymsp[-1].minor.yy21/100;} |
| 2529 | | -#line 2554 "pikchr.c" |
| 2561 | +#line 2586 "pikchr.c" |
| 2530 | 2562 | yymsp[-1].minor.yy72 = yylhsminor.yy72; |
| 2531 | 2563 | break; |
| 2532 | 2564 | case 27: /* optrelexpr ::= */ |
| 2533 | | -#line 618 "pikchr.y" |
| 2565 | +#line 619 "pikchr.y" |
| 2534 | 2566 | {yymsp[1].minor.yy72.rAbs = 0; yymsp[1].minor.yy72.rRel = 1.0;} |
| 2535 | | -#line 2560 "pikchr.c" |
| 2567 | +#line 2592 "pikchr.c" |
| 2536 | 2568 | break; |
| 2537 | 2569 | case 28: /* attribute_list ::= relexpr alist */ |
| 2538 | | -#line 620 "pikchr.y" |
| 2570 | +#line 621 "pikchr.y" |
| 2539 | 2571 | {pik_add_direction(p,0,&yymsp[-1].minor.yy72);} |
| 2540 | | -#line 2565 "pikchr.c" |
| 2572 | +#line 2597 "pikchr.c" |
| 2541 | 2573 | break; |
| 2542 | 2574 | case 29: /* attribute ::= numproperty relexpr */ |
| 2543 | | -#line 624 "pikchr.y" |
| 2575 | +#line 625 "pikchr.y" |
| 2544 | 2576 | { pik_set_numprop(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy72); } |
| 2545 | | -#line 2570 "pikchr.c" |
| 2577 | +#line 2602 "pikchr.c" |
| 2546 | 2578 | break; |
| 2547 | 2579 | case 30: /* attribute ::= dashproperty expr */ |
| 2548 | | -#line 625 "pikchr.y" |
| 2580 | +#line 626 "pikchr.y" |
| 2549 | 2581 | { pik_set_dashed(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy21); } |
| 2550 | | -#line 2575 "pikchr.c" |
| 2582 | +#line 2607 "pikchr.c" |
| 2551 | 2583 | break; |
| 2552 | 2584 | case 31: /* attribute ::= dashproperty */ |
| 2553 | | -#line 626 "pikchr.y" |
| 2585 | +#line 627 "pikchr.y" |
| 2554 | 2586 | { pik_set_dashed(p,&yymsp[0].minor.yy0,0); } |
| 2555 | | -#line 2580 "pikchr.c" |
| 2587 | +#line 2612 "pikchr.c" |
| 2556 | 2588 | break; |
| 2557 | 2589 | case 32: /* attribute ::= colorproperty rvalue */ |
| 2558 | | -#line 627 "pikchr.y" |
| 2590 | +#line 628 "pikchr.y" |
| 2559 | 2591 | { pik_set_clrprop(p,&yymsp[-1].minor.yy0,yymsp[0].minor.yy21); } |
| 2560 | | -#line 2585 "pikchr.c" |
| 2592 | +#line 2617 "pikchr.c" |
| 2561 | 2593 | break; |
| 2562 | 2594 | case 33: /* attribute ::= go direction optrelexpr */ |
| 2563 | | -#line 628 "pikchr.y" |
| 2595 | +#line 629 "pikchr.y" |
| 2564 | 2596 | { pik_add_direction(p,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy72);} |
| 2565 | | -#line 2590 "pikchr.c" |
| 2597 | +#line 2622 "pikchr.c" |
| 2566 | 2598 | break; |
| 2567 | 2599 | case 34: /* attribute ::= go direction even position */ |
| 2568 | | -#line 629 "pikchr.y" |
| 2600 | +#line 630 "pikchr.y" |
| 2569 | 2601 | {pik_evenwith(p,&yymsp[-2].minor.yy0,&yymsp[0].minor.yy63);} |
| 2570 | | -#line 2595 "pikchr.c" |
| 2602 | +#line 2627 "pikchr.c" |
| 2571 | 2603 | break; |
| 2572 | 2604 | case 35: /* attribute ::= CLOSE */ |
| 2573 | | -#line 630 "pikchr.y" |
| 2605 | +#line 631 "pikchr.y" |
| 2574 | 2606 | { pik_close_path(p,&yymsp[0].minor.yy0); } |
| 2575 | | -#line 2600 "pikchr.c" |
| 2607 | +#line 2632 "pikchr.c" |
| 2576 | 2608 | break; |
| 2577 | 2609 | case 36: /* attribute ::= CHOP */ |
| 2578 | | -#line 631 "pikchr.y" |
| 2610 | +#line 632 "pikchr.y" |
| 2579 | 2611 | { p->cur->bChop = 1; } |
| 2580 | | -#line 2605 "pikchr.c" |
| 2612 | +#line 2637 "pikchr.c" |
| 2581 | 2613 | break; |
| 2582 | 2614 | case 37: /* attribute ::= FROM position */ |
| 2583 | | -#line 632 "pikchr.y" |
| 2615 | +#line 633 "pikchr.y" |
| 2584 | 2616 | { pik_set_from(p,p->cur,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy63); } |
| 2585 | | -#line 2610 "pikchr.c" |
| 2617 | +#line 2642 "pikchr.c" |
| 2586 | 2618 | break; |
| 2587 | 2619 | case 38: /* attribute ::= TO position */ |
| 2588 | | -#line 633 "pikchr.y" |
| 2620 | +#line 634 "pikchr.y" |
| 2589 | 2621 | { pik_add_to(p,p->cur,&yymsp[-1].minor.yy0,&yymsp[0].minor.yy63); } |
| 2590 | | -#line 2615 "pikchr.c" |
| 2622 | +#line 2647 "pikchr.c" |
| 2591 | 2623 | break; |
| 2592 | 2624 | case 39: /* attribute ::= THEN */ |
| 2593 | | -#line 634 "pikchr.y" |
| 2625 | +#line 635 "pikchr.y" |
| 2594 | 2626 | { pik_then(p, &yymsp[0].minor.yy0, p->cur); } |
| 2595 | | -#line 2620 "pikchr.c" |
| 2627 | +#line 2652 "pikchr.c" |
| 2596 | 2628 | break; |
| 2597 | 2629 | case 40: /* attribute ::= THEN optrelexpr HEADING expr */ |
| 2598 | 2630 | case 42: /* attribute ::= GO optrelexpr HEADING expr */ yytestcase(yyruleno==42); |
| 2599 | | -#line 636 "pikchr.y" |
| 2631 | +#line 637 "pikchr.y" |
| 2600 | 2632 | {pik_move_hdg(p,&yymsp[-2].minor.yy72,&yymsp[-1].minor.yy0,yymsp[0].minor.yy21,0,&yymsp[-3].minor.yy0);} |
| 2601 | | -#line 2626 "pikchr.c" |
| 2633 | +#line 2658 "pikchr.c" |
| 2602 | 2634 | break; |
| 2603 | 2635 | case 41: /* attribute ::= THEN optrelexpr EDGEPT */ |
| 2604 | 2636 | case 43: /* attribute ::= GO optrelexpr EDGEPT */ yytestcase(yyruleno==43); |
| 2605 | | -#line 637 "pikchr.y" |
| 2637 | +#line 638 "pikchr.y" |
| 2606 | 2638 | {pik_move_hdg(p,&yymsp[-1].minor.yy72,0,0,&yymsp[0].minor.yy0,&yymsp[-2].minor.yy0);} |
| 2607 | | -#line 2632 "pikchr.c" |
| 2639 | +#line 2664 "pikchr.c" |
| 2608 | 2640 | break; |
| 2609 | 2641 | case 44: /* attribute ::= AT position */ |
| 2610 | | -#line 642 "pikchr.y" |
| 2642 | +#line 643 "pikchr.y" |
| 2611 | 2643 | { pik_set_at(p,0,&yymsp[0].minor.yy63,&yymsp[-1].minor.yy0); } |
| 2612 | | -#line 2637 "pikchr.c" |
| 2644 | +#line 2669 "pikchr.c" |
| 2613 | 2645 | break; |
| 2614 | 2646 | case 45: /* attribute ::= SAME */ |
| 2615 | | -#line 644 "pikchr.y" |
| 2647 | +#line 645 "pikchr.y" |
| 2616 | 2648 | {pik_same(p,0,&yymsp[0].minor.yy0);} |
| 2617 | | -#line 2642 "pikchr.c" |
| 2649 | +#line 2674 "pikchr.c" |
| 2618 | 2650 | break; |
| 2619 | 2651 | case 46: /* attribute ::= SAME AS object */ |
| 2620 | | -#line 645 "pikchr.y" |
| 2652 | +#line 646 "pikchr.y" |
| 2621 | 2653 | {pik_same(p,yymsp[0].minor.yy162,&yymsp[-2].minor.yy0);} |
| 2622 | | -#line 2647 "pikchr.c" |
| 2654 | +#line 2679 "pikchr.c" |
| 2623 | 2655 | break; |
| 2624 | 2656 | case 47: /* attribute ::= STRING textposition */ |
| 2625 | | -#line 646 "pikchr.y" |
| 2657 | +#line 647 "pikchr.y" |
| 2626 | 2658 | {pik_add_txt(p,&yymsp[-1].minor.yy0,yymsp[0].minor.yy188);} |
| 2627 | | -#line 2652 "pikchr.c" |
| 2659 | +#line 2684 "pikchr.c" |
| 2628 | 2660 | break; |
| 2629 | 2661 | case 48: /* attribute ::= FIT */ |
| 2630 | | -#line 647 "pikchr.y" |
| 2662 | +#line 648 "pikchr.y" |
| 2631 | 2663 | {pik_size_to_fit(p,&yymsp[0].minor.yy0,3); } |
| 2632 | | -#line 2657 "pikchr.c" |
| 2664 | +#line 2689 "pikchr.c" |
| 2633 | 2665 | break; |
| 2634 | 2666 | case 49: /* attribute ::= BEHIND object */ |
| 2635 | | -#line 648 "pikchr.y" |
| 2667 | +#line 649 "pikchr.y" |
| 2636 | 2668 | {pik_behind(p,yymsp[0].minor.yy162);} |
| 2637 | | -#line 2662 "pikchr.c" |
| 2669 | +#line 2694 "pikchr.c" |
| 2638 | 2670 | break; |
| 2639 | 2671 | case 50: /* withclause ::= DOT_E edge AT position */ |
| 2640 | 2672 | case 51: /* withclause ::= edge AT position */ yytestcase(yyruleno==51); |
| 2641 | | -#line 656 "pikchr.y" |
| 2673 | +#line 657 "pikchr.y" |
| 2642 | 2674 | { pik_set_at(p,&yymsp[-2].minor.yy0,&yymsp[0].minor.yy63,&yymsp[-1].minor.yy0); } |
| 2643 | | -#line 2668 "pikchr.c" |
| 2675 | +#line 2700 "pikchr.c" |
| 2644 | 2676 | break; |
| 2645 | 2677 | case 52: /* numproperty ::= HEIGHT|WIDTH|RADIUS|DIAMETER|THICKNESS */ |
| 2646 | | -#line 660 "pikchr.y" |
| 2678 | +#line 661 "pikchr.y" |
| 2647 | 2679 | {yylhsminor.yy0 = yymsp[0].minor.yy0;} |
| 2648 | | -#line 2673 "pikchr.c" |
| 2680 | +#line 2705 "pikchr.c" |
| 2649 | 2681 | yymsp[0].minor.yy0 = yylhsminor.yy0; |
| 2650 | 2682 | break; |
| 2651 | 2683 | case 53: /* boolproperty ::= CW */ |
| 2652 | | -#line 671 "pikchr.y" |
| 2684 | +#line 672 "pikchr.y" |
| 2653 | 2685 | {p->cur->cw = 1;} |
| 2654 | | -#line 2679 "pikchr.c" |
| 2686 | +#line 2711 "pikchr.c" |
| 2655 | 2687 | break; |
| 2656 | 2688 | case 54: /* boolproperty ::= CCW */ |
| 2657 | | -#line 672 "pikchr.y" |
| 2689 | +#line 673 "pikchr.y" |
| 2658 | 2690 | {p->cur->cw = 0;} |
| 2659 | | -#line 2684 "pikchr.c" |
| 2691 | +#line 2716 "pikchr.c" |
| 2660 | 2692 | break; |
| 2661 | 2693 | case 55: /* boolproperty ::= LARROW */ |
| 2662 | | -#line 673 "pikchr.y" |
| 2694 | +#line 674 "pikchr.y" |
| 2663 | 2695 | {p->cur->larrow=1; p->cur->rarrow=0; } |
| 2664 | | -#line 2689 "pikchr.c" |
| 2696 | +#line 2721 "pikchr.c" |
| 2665 | 2697 | break; |
| 2666 | 2698 | case 56: /* boolproperty ::= RARROW */ |
| 2667 | | -#line 674 "pikchr.y" |
| 2699 | +#line 675 "pikchr.y" |
| 2668 | 2700 | {p->cur->larrow=0; p->cur->rarrow=1; } |
| 2669 | | -#line 2694 "pikchr.c" |
| 2701 | +#line 2726 "pikchr.c" |
| 2670 | 2702 | break; |
| 2671 | 2703 | case 57: /* boolproperty ::= LRARROW */ |
| 2672 | | -#line 675 "pikchr.y" |
| 2704 | +#line 676 "pikchr.y" |
| 2673 | 2705 | {p->cur->larrow=1; p->cur->rarrow=1; } |
| 2674 | | -#line 2699 "pikchr.c" |
| 2706 | +#line 2731 "pikchr.c" |
| 2675 | 2707 | break; |
| 2676 | 2708 | case 58: /* boolproperty ::= INVIS */ |
| 2677 | | -#line 676 "pikchr.y" |
| 2709 | +#line 677 "pikchr.y" |
| 2678 | 2710 | {p->cur->sw = -0.00001;} |
| 2679 | | -#line 2704 "pikchr.c" |
| 2711 | +#line 2736 "pikchr.c" |
| 2680 | 2712 | break; |
| 2681 | 2713 | case 59: /* boolproperty ::= THICK */ |
| 2682 | | -#line 677 "pikchr.y" |
| 2714 | +#line 678 "pikchr.y" |
| 2683 | 2715 | {p->cur->sw *= 1.5;} |
| 2684 | | -#line 2709 "pikchr.c" |
| 2716 | +#line 2741 "pikchr.c" |
| 2685 | 2717 | break; |
| 2686 | 2718 | case 60: /* boolproperty ::= THIN */ |
| 2687 | | -#line 678 "pikchr.y" |
| 2719 | +#line 679 "pikchr.y" |
| 2688 | 2720 | {p->cur->sw *= 0.67;} |
| 2689 | | -#line 2714 "pikchr.c" |
| 2721 | +#line 2746 "pikchr.c" |
| 2690 | 2722 | break; |
| 2691 | 2723 | case 61: /* boolproperty ::= SOLID */ |
| 2692 | | -#line 679 "pikchr.y" |
| 2724 | +#line 680 "pikchr.y" |
| 2693 | 2725 | {p->cur->sw = pik_value(p,"thickness",9,0); |
| 2694 | 2726 | p->cur->dotted = p->cur->dashed = 0.0;} |
| 2695 | | -#line 2720 "pikchr.c" |
| 2727 | +#line 2752 "pikchr.c" |
| 2696 | 2728 | break; |
| 2697 | 2729 | case 62: /* textposition ::= */ |
| 2698 | | -#line 682 "pikchr.y" |
| 2730 | +#line 683 "pikchr.y" |
| 2699 | 2731 | {yymsp[1].minor.yy188 = 0;} |
| 2700 | | -#line 2725 "pikchr.c" |
| 2732 | +#line 2757 "pikchr.c" |
| 2701 | 2733 | break; |
| 2702 | 2734 | case 63: /* textposition ::= textposition CENTER|LJUST|RJUST|ABOVE|BELOW|ITALIC|BOLD|MONO|ALIGNED|BIG|SMALL */ |
| 2703 | | -#line 685 "pikchr.y" |
| 2735 | +#line 686 "pikchr.y" |
| 2704 | 2736 | {yylhsminor.yy188 = (short int)pik_text_position(yymsp[-1].minor.yy188,&yymsp[0].minor.yy0);} |
| 2705 | | -#line 2730 "pikchr.c" |
| 2737 | +#line 2762 "pikchr.c" |
| 2706 | 2738 | yymsp[-1].minor.yy188 = yylhsminor.yy188; |
| 2707 | 2739 | break; |
| 2708 | 2740 | case 64: /* position ::= expr COMMA expr */ |
| 2709 | | -#line 688 "pikchr.y" |
| 2741 | +#line 689 "pikchr.y" |
| 2710 | 2742 | {yylhsminor.yy63.x=yymsp[-2].minor.yy21; yylhsminor.yy63.y=yymsp[0].minor.yy21;} |
| 2711 | | -#line 2736 "pikchr.c" |
| 2743 | +#line 2768 "pikchr.c" |
| 2712 | 2744 | yymsp[-2].minor.yy63 = yylhsminor.yy63; |
| 2713 | 2745 | break; |
| 2714 | 2746 | case 65: /* position ::= place PLUS expr COMMA expr */ |
| 2715 | | -#line 690 "pikchr.y" |
| 2747 | +#line 691 "pikchr.y" |
| 2716 | 2748 | {yylhsminor.yy63.x=yymsp[-4].minor.yy63.x+yymsp[-2].minor.yy21; yylhsminor.yy63.y=yymsp[-4].minor.yy63.y+yymsp[0].minor.yy21;} |
| 2717 | | -#line 2742 "pikchr.c" |
| 2749 | +#line 2774 "pikchr.c" |
| 2718 | 2750 | yymsp[-4].minor.yy63 = yylhsminor.yy63; |
| 2719 | 2751 | break; |
| 2720 | 2752 | case 66: /* position ::= place MINUS expr COMMA expr */ |
| 2721 | | -#line 691 "pikchr.y" |
| 2753 | +#line 692 "pikchr.y" |
| 2722 | 2754 | {yylhsminor.yy63.x=yymsp[-4].minor.yy63.x-yymsp[-2].minor.yy21; yylhsminor.yy63.y=yymsp[-4].minor.yy63.y-yymsp[0].minor.yy21;} |
| 2723 | | -#line 2748 "pikchr.c" |
| 2755 | +#line 2780 "pikchr.c" |
| 2724 | 2756 | yymsp[-4].minor.yy63 = yylhsminor.yy63; |
| 2725 | 2757 | break; |
| 2726 | 2758 | case 67: /* position ::= place PLUS LP expr COMMA expr RP */ |
| 2727 | | -#line 693 "pikchr.y" |
| 2759 | +#line 694 "pikchr.y" |
| 2728 | 2760 | {yylhsminor.yy63.x=yymsp[-6].minor.yy63.x+yymsp[-3].minor.yy21; yylhsminor.yy63.y=yymsp[-6].minor.yy63.y+yymsp[-1].minor.yy21;} |
| 2729 | | -#line 2754 "pikchr.c" |
| 2761 | +#line 2786 "pikchr.c" |
| 2730 | 2762 | yymsp[-6].minor.yy63 = yylhsminor.yy63; |
| 2731 | 2763 | break; |
| 2732 | 2764 | case 68: /* position ::= place MINUS LP expr COMMA expr RP */ |
| 2733 | | -#line 695 "pikchr.y" |
| 2765 | +#line 696 "pikchr.y" |
| 2734 | 2766 | {yylhsminor.yy63.x=yymsp[-6].minor.yy63.x-yymsp[-3].minor.yy21; yylhsminor.yy63.y=yymsp[-6].minor.yy63.y-yymsp[-1].minor.yy21;} |
| 2735 | | -#line 2760 "pikchr.c" |
| 2767 | +#line 2792 "pikchr.c" |
| 2736 | 2768 | yymsp[-6].minor.yy63 = yylhsminor.yy63; |
| 2737 | 2769 | break; |
| 2738 | 2770 | case 69: /* position ::= LP position COMMA position RP */ |
| 2739 | | -#line 696 "pikchr.y" |
| 2771 | +#line 697 "pikchr.y" |
| 2740 | 2772 | {yymsp[-4].minor.yy63.x=yymsp[-3].minor.yy63.x; yymsp[-4].minor.yy63.y=yymsp[-1].minor.yy63.y;} |
| 2741 | | -#line 2766 "pikchr.c" |
| 2773 | +#line 2798 "pikchr.c" |
| 2742 | 2774 | break; |
| 2743 | 2775 | case 70: /* position ::= LP position RP */ |
| 2744 | | -#line 697 "pikchr.y" |
| 2776 | +#line 698 "pikchr.y" |
| 2745 | 2777 | {yymsp[-2].minor.yy63=yymsp[-1].minor.yy63;} |
| 2746 | | -#line 2771 "pikchr.c" |
| 2778 | +#line 2803 "pikchr.c" |
| 2747 | 2779 | break; |
| 2748 | 2780 | case 71: /* position ::= expr between position AND position */ |
| 2749 | | -#line 699 "pikchr.y" |
| 2781 | +#line 700 "pikchr.y" |
| 2750 | 2782 | {yylhsminor.yy63 = pik_position_between(yymsp[-4].minor.yy21,yymsp[-2].minor.yy63,yymsp[0].minor.yy63);} |
| 2751 | | -#line 2776 "pikchr.c" |
| 2783 | +#line 2808 "pikchr.c" |
| 2752 | 2784 | yymsp[-4].minor.yy63 = yylhsminor.yy63; |
| 2753 | 2785 | break; |
| 2754 | 2786 | case 72: /* position ::= expr LT position COMMA position GT */ |
| 2755 | | -#line 701 "pikchr.y" |
| 2787 | +#line 702 "pikchr.y" |
| 2756 | 2788 | {yylhsminor.yy63 = pik_position_between(yymsp[-5].minor.yy21,yymsp[-3].minor.yy63,yymsp[-1].minor.yy63);} |
| 2757 | | -#line 2782 "pikchr.c" |
| 2789 | +#line 2814 "pikchr.c" |
| 2758 | 2790 | yymsp[-5].minor.yy63 = yylhsminor.yy63; |
| 2759 | 2791 | break; |
| 2760 | 2792 | case 73: /* position ::= expr ABOVE position */ |
| 2761 | | -#line 702 "pikchr.y" |
| 2793 | +#line 703 "pikchr.y" |
| 2762 | 2794 | {yylhsminor.yy63=yymsp[0].minor.yy63; yylhsminor.yy63.y += yymsp[-2].minor.yy21;} |
| 2763 | | -#line 2788 "pikchr.c" |
| 2795 | +#line 2820 "pikchr.c" |
| 2764 | 2796 | yymsp[-2].minor.yy63 = yylhsminor.yy63; |
| 2765 | 2797 | break; |
| 2766 | 2798 | case 74: /* position ::= expr BELOW position */ |
| 2767 | | -#line 703 "pikchr.y" |
| 2799 | +#line 704 "pikchr.y" |
| 2768 | 2800 | {yylhsminor.yy63=yymsp[0].minor.yy63; yylhsminor.yy63.y -= yymsp[-2].minor.yy21;} |
| 2769 | | -#line 2794 "pikchr.c" |
| 2801 | +#line 2826 "pikchr.c" |
| 2770 | 2802 | yymsp[-2].minor.yy63 = yylhsminor.yy63; |
| 2771 | 2803 | break; |
| 2772 | 2804 | case 75: /* position ::= expr LEFT OF position */ |
| 2773 | | -#line 704 "pikchr.y" |
| 2805 | +#line 705 "pikchr.y" |
| 2774 | 2806 | {yylhsminor.yy63=yymsp[0].minor.yy63; yylhsminor.yy63.x -= yymsp[-3].minor.yy21;} |
| 2775 | | -#line 2800 "pikchr.c" |
| 2807 | +#line 2832 "pikchr.c" |
| 2776 | 2808 | yymsp[-3].minor.yy63 = yylhsminor.yy63; |
| 2777 | 2809 | break; |
| 2778 | 2810 | case 76: /* position ::= expr RIGHT OF position */ |
| 2779 | | -#line 705 "pikchr.y" |
| 2811 | +#line 706 "pikchr.y" |
| 2780 | 2812 | {yylhsminor.yy63=yymsp[0].minor.yy63; yylhsminor.yy63.x += yymsp[-3].minor.yy21;} |
| 2781 | | -#line 2806 "pikchr.c" |
| 2813 | +#line 2838 "pikchr.c" |
| 2782 | 2814 | yymsp[-3].minor.yy63 = yylhsminor.yy63; |
| 2783 | 2815 | break; |
| 2784 | 2816 | case 77: /* position ::= expr ON HEADING EDGEPT OF position */ |
| 2785 | | -#line 707 "pikchr.y" |
| 2817 | +#line 708 "pikchr.y" |
| 2786 | 2818 | {yylhsminor.yy63 = pik_position_at_hdg(yymsp[-5].minor.yy21,&yymsp[-2].minor.yy0,yymsp[0].minor.yy63);} |
| 2787 | | -#line 2812 "pikchr.c" |
| 2819 | +#line 2844 "pikchr.c" |
| 2788 | 2820 | yymsp[-5].minor.yy63 = yylhsminor.yy63; |
| 2789 | 2821 | break; |
| 2790 | 2822 | case 78: /* position ::= expr HEADING EDGEPT OF position */ |
| 2791 | | -#line 709 "pikchr.y" |
| 2823 | +#line 710 "pikchr.y" |
| 2792 | 2824 | {yylhsminor.yy63 = pik_position_at_hdg(yymsp[-4].minor.yy21,&yymsp[-2].minor.yy0,yymsp[0].minor.yy63);} |
| 2793 | | -#line 2818 "pikchr.c" |
| 2825 | +#line 2850 "pikchr.c" |
| 2794 | 2826 | yymsp[-4].minor.yy63 = yylhsminor.yy63; |
| 2795 | 2827 | break; |
| 2796 | 2828 | case 79: /* position ::= expr EDGEPT OF position */ |
| 2797 | | -#line 711 "pikchr.y" |
| 2829 | +#line 712 "pikchr.y" |
| 2798 | 2830 | {yylhsminor.yy63 = pik_position_at_hdg(yymsp[-3].minor.yy21,&yymsp[-2].minor.yy0,yymsp[0].minor.yy63);} |
| 2799 | | -#line 2824 "pikchr.c" |
| 2831 | +#line 2856 "pikchr.c" |
| 2800 | 2832 | yymsp[-3].minor.yy63 = yylhsminor.yy63; |
| 2801 | 2833 | break; |
| 2802 | 2834 | case 80: /* position ::= expr ON HEADING expr FROM position */ |
| 2803 | | -#line 713 "pikchr.y" |
| 2835 | +#line 714 "pikchr.y" |
| 2804 | 2836 | {yylhsminor.yy63 = pik_position_at_angle(yymsp[-5].minor.yy21,yymsp[-2].minor.yy21,yymsp[0].minor.yy63);} |
| 2805 | | -#line 2830 "pikchr.c" |
| 2837 | +#line 2862 "pikchr.c" |
| 2806 | 2838 | yymsp[-5].minor.yy63 = yylhsminor.yy63; |
| 2807 | 2839 | break; |
| 2808 | 2840 | case 81: /* position ::= expr HEADING expr FROM position */ |
| 2809 | | -#line 715 "pikchr.y" |
| 2841 | +#line 716 "pikchr.y" |
| 2810 | 2842 | {yylhsminor.yy63 = pik_position_at_angle(yymsp[-4].minor.yy21,yymsp[-2].minor.yy21,yymsp[0].minor.yy63);} |
| 2811 | | -#line 2836 "pikchr.c" |
| 2843 | +#line 2868 "pikchr.c" |
| 2812 | 2844 | yymsp[-4].minor.yy63 = yylhsminor.yy63; |
| 2813 | 2845 | break; |
| 2814 | 2846 | case 82: /* place ::= edge OF object */ |
| 2815 | | -#line 727 "pikchr.y" |
| 2847 | +#line 728 "pikchr.y" |
| 2816 | 2848 | {yylhsminor.yy63 = pik_place_of_elem(p,yymsp[0].minor.yy162,&yymsp[-2].minor.yy0);} |
| 2817 | | -#line 2842 "pikchr.c" |
| 2849 | +#line 2874 "pikchr.c" |
| 2818 | 2850 | yymsp[-2].minor.yy63 = yylhsminor.yy63; |
| 2819 | 2851 | break; |
| 2820 | 2852 | case 83: /* place2 ::= object */ |
| 2821 | | -#line 728 "pikchr.y" |
| 2853 | +#line 729 "pikchr.y" |
| 2822 | 2854 | {yylhsminor.yy63 = pik_place_of_elem(p,yymsp[0].minor.yy162,0);} |
| 2823 | | -#line 2848 "pikchr.c" |
| 2855 | +#line 2880 "pikchr.c" |
| 2824 | 2856 | yymsp[0].minor.yy63 = yylhsminor.yy63; |
| 2825 | 2857 | break; |
| 2826 | 2858 | case 84: /* place2 ::= object DOT_E edge */ |
| 2827 | | -#line 729 "pikchr.y" |
| 2859 | +#line 730 "pikchr.y" |
| 2828 | 2860 | {yylhsminor.yy63 = pik_place_of_elem(p,yymsp[-2].minor.yy162,&yymsp[0].minor.yy0);} |
| 2829 | | -#line 2854 "pikchr.c" |
| 2861 | +#line 2886 "pikchr.c" |
| 2830 | 2862 | yymsp[-2].minor.yy63 = yylhsminor.yy63; |
| 2831 | 2863 | break; |
| 2832 | 2864 | case 85: /* place2 ::= NTH VERTEX OF object */ |
| 2833 | | -#line 730 "pikchr.y" |
| 2865 | +#line 731 "pikchr.y" |
| 2834 | 2866 | {yylhsminor.yy63 = pik_nth_vertex(p,&yymsp[-3].minor.yy0,&yymsp[-2].minor.yy0,yymsp[0].minor.yy162);} |
| 2835 | | -#line 2860 "pikchr.c" |
| 2867 | +#line 2892 "pikchr.c" |
| 2836 | 2868 | yymsp[-3].minor.yy63 = yylhsminor.yy63; |
| 2837 | 2869 | break; |
| 2838 | 2870 | case 86: /* object ::= nth */ |
| 2839 | | -#line 742 "pikchr.y" |
| 2871 | +#line 743 "pikchr.y" |
| 2840 | 2872 | {yylhsminor.yy162 = pik_find_nth(p,0,&yymsp[0].minor.yy0);} |
| 2841 | | -#line 2866 "pikchr.c" |
| 2873 | +#line 2898 "pikchr.c" |
| 2842 | 2874 | yymsp[0].minor.yy162 = yylhsminor.yy162; |
| 2843 | 2875 | break; |
| 2844 | 2876 | case 87: /* object ::= nth OF|IN object */ |
| 2845 | | -#line 743 "pikchr.y" |
| 2877 | +#line 744 "pikchr.y" |
| 2846 | 2878 | {yylhsminor.yy162 = pik_find_nth(p,yymsp[0].minor.yy162,&yymsp[-2].minor.yy0);} |
| 2847 | | -#line 2872 "pikchr.c" |
| 2879 | +#line 2904 "pikchr.c" |
| 2848 | 2880 | yymsp[-2].minor.yy162 = yylhsminor.yy162; |
| 2849 | 2881 | break; |
| 2850 | 2882 | case 88: /* objectname ::= THIS */ |
| 2851 | | -#line 745 "pikchr.y" |
| 2883 | +#line 746 "pikchr.y" |
| 2852 | 2884 | {yymsp[0].minor.yy162 = p->cur;} |
| 2853 | | -#line 2878 "pikchr.c" |
| 2885 | +#line 2910 "pikchr.c" |
| 2854 | 2886 | break; |
| 2855 | 2887 | case 89: /* objectname ::= PLACENAME */ |
| 2856 | | -#line 746 "pikchr.y" |
| 2888 | +#line 747 "pikchr.y" |
| 2857 | 2889 | {yylhsminor.yy162 = pik_find_byname(p,0,&yymsp[0].minor.yy0);} |
| 2858 | | -#line 2883 "pikchr.c" |
| 2890 | +#line 2915 "pikchr.c" |
| 2859 | 2891 | yymsp[0].minor.yy162 = yylhsminor.yy162; |
| 2860 | 2892 | break; |
| 2861 | 2893 | case 90: /* objectname ::= objectname DOT_U PLACENAME */ |
| 2862 | | -#line 748 "pikchr.y" |
| 2894 | +#line 749 "pikchr.y" |
| 2863 | 2895 | {yylhsminor.yy162 = pik_find_byname(p,yymsp[-2].minor.yy162,&yymsp[0].minor.yy0);} |
| 2864 | | -#line 2889 "pikchr.c" |
| 2896 | +#line 2921 "pikchr.c" |
| 2865 | 2897 | yymsp[-2].minor.yy162 = yylhsminor.yy162; |
| 2866 | 2898 | break; |
| 2867 | 2899 | case 91: /* nth ::= NTH CLASSNAME */ |
| 2868 | | -#line 750 "pikchr.y" |
| 2900 | +#line 751 "pikchr.y" |
| 2869 | 2901 | {yylhsminor.yy0=yymsp[0].minor.yy0; yylhsminor.yy0.eCode = pik_nth_value(p,&yymsp[-1].minor.yy0); } |
| 2870 | | -#line 2895 "pikchr.c" |
| 2902 | +#line 2927 "pikchr.c" |
| 2871 | 2903 | yymsp[-1].minor.yy0 = yylhsminor.yy0; |
| 2872 | 2904 | break; |
| 2873 | 2905 | case 92: /* nth ::= NTH LAST CLASSNAME */ |
| 2874 | | -#line 751 "pikchr.y" |
| 2906 | +#line 752 "pikchr.y" |
| 2875 | 2907 | {yylhsminor.yy0=yymsp[0].minor.yy0; yylhsminor.yy0.eCode = -pik_nth_value(p,&yymsp[-2].minor.yy0); } |
| 2876 | | -#line 2901 "pikchr.c" |
| 2908 | +#line 2933 "pikchr.c" |
| 2877 | 2909 | yymsp[-2].minor.yy0 = yylhsminor.yy0; |
| 2878 | 2910 | break; |
| 2879 | 2911 | case 93: /* nth ::= LAST CLASSNAME */ |
| 2880 | | -#line 752 "pikchr.y" |
| 2912 | +#line 753 "pikchr.y" |
| 2881 | 2913 | {yymsp[-1].minor.yy0=yymsp[0].minor.yy0; yymsp[-1].minor.yy0.eCode = -1;} |
| 2882 | | -#line 2907 "pikchr.c" |
| 2914 | +#line 2939 "pikchr.c" |
| 2883 | 2915 | break; |
| 2884 | 2916 | case 94: /* nth ::= LAST */ |
| 2885 | | -#line 753 "pikchr.y" |
| 2917 | +#line 754 "pikchr.y" |
| 2886 | 2918 | {yylhsminor.yy0=yymsp[0].minor.yy0; yylhsminor.yy0.eCode = -1;} |
| 2887 | | -#line 2912 "pikchr.c" |
| 2919 | +#line 2944 "pikchr.c" |
| 2888 | 2920 | yymsp[0].minor.yy0 = yylhsminor.yy0; |
| 2889 | 2921 | break; |
| 2890 | 2922 | case 95: /* nth ::= NTH LB RB */ |
| 2891 | | -#line 754 "pikchr.y" |
| 2923 | +#line 755 "pikchr.y" |
| 2892 | 2924 | {yylhsminor.yy0=yymsp[-1].minor.yy0; yylhsminor.yy0.eCode = pik_nth_value(p,&yymsp[-2].minor.yy0);} |
| 2893 | | -#line 2918 "pikchr.c" |
| 2925 | +#line 2950 "pikchr.c" |
| 2894 | 2926 | yymsp[-2].minor.yy0 = yylhsminor.yy0; |
| 2895 | 2927 | break; |
| 2896 | 2928 | case 96: /* nth ::= NTH LAST LB RB */ |
| 2897 | | -#line 755 "pikchr.y" |
| 2929 | +#line 756 "pikchr.y" |
| 2898 | 2930 | {yylhsminor.yy0=yymsp[-1].minor.yy0; yylhsminor.yy0.eCode = -pik_nth_value(p,&yymsp[-3].minor.yy0);} |
| 2899 | | -#line 2924 "pikchr.c" |
| 2931 | +#line 2956 "pikchr.c" |
| 2900 | 2932 | yymsp[-3].minor.yy0 = yylhsminor.yy0; |
| 2901 | 2933 | break; |
| 2902 | 2934 | case 97: /* nth ::= LAST LB RB */ |
| 2903 | | -#line 756 "pikchr.y" |
| 2935 | +#line 757 "pikchr.y" |
| 2904 | 2936 | {yymsp[-2].minor.yy0=yymsp[-1].minor.yy0; yymsp[-2].minor.yy0.eCode = -1; } |
| 2905 | | -#line 2930 "pikchr.c" |
| 2937 | +#line 2962 "pikchr.c" |
| 2906 | 2938 | break; |
| 2907 | 2939 | case 98: /* expr ::= expr PLUS expr */ |
| 2908 | | -#line 758 "pikchr.y" |
| 2940 | +#line 759 "pikchr.y" |
| 2909 | 2941 | {yylhsminor.yy21=yymsp[-2].minor.yy21+yymsp[0].minor.yy21;} |
| 2910 | | -#line 2935 "pikchr.c" |
| 2942 | +#line 2967 "pikchr.c" |
| 2911 | 2943 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 2912 | 2944 | break; |
| 2913 | 2945 | case 99: /* expr ::= expr MINUS expr */ |
| 2914 | | -#line 759 "pikchr.y" |
| 2946 | +#line 760 "pikchr.y" |
| 2915 | 2947 | {yylhsminor.yy21=yymsp[-2].minor.yy21-yymsp[0].minor.yy21;} |
| 2916 | | -#line 2941 "pikchr.c" |
| 2948 | +#line 2973 "pikchr.c" |
| 2917 | 2949 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 2918 | 2950 | break; |
| 2919 | 2951 | case 100: /* expr ::= expr STAR expr */ |
| 2920 | | -#line 760 "pikchr.y" |
| 2952 | +#line 761 "pikchr.y" |
| 2921 | 2953 | {yylhsminor.yy21=yymsp[-2].minor.yy21*yymsp[0].minor.yy21;} |
| 2922 | | -#line 2947 "pikchr.c" |
| 2954 | +#line 2979 "pikchr.c" |
| 2923 | 2955 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 2924 | 2956 | break; |
| 2925 | 2957 | case 101: /* expr ::= expr SLASH expr */ |
| 2926 | | -#line 761 "pikchr.y" |
| 2958 | +#line 762 "pikchr.y" |
| 2927 | 2959 | { |
| 2928 | 2960 | if( yymsp[0].minor.yy21==0.0 ){ pik_error(p, &yymsp[-1].minor.yy0, "division by zero"); yylhsminor.yy21 = 0.0; } |
| 2929 | 2961 | else{ yylhsminor.yy21 = yymsp[-2].minor.yy21/yymsp[0].minor.yy21; } |
| 2930 | 2962 | } |
| 2931 | | -#line 2956 "pikchr.c" |
| 2963 | +#line 2988 "pikchr.c" |
| 2932 | 2964 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 2933 | 2965 | break; |
| 2934 | 2966 | case 102: /* expr ::= MINUS expr */ |
| 2935 | | -#line 765 "pikchr.y" |
| 2967 | +#line 766 "pikchr.y" |
| 2936 | 2968 | {yymsp[-1].minor.yy21=-yymsp[0].minor.yy21;} |
| 2937 | | -#line 2962 "pikchr.c" |
| 2969 | +#line 2994 "pikchr.c" |
| 2938 | 2970 | break; |
| 2939 | 2971 | case 103: /* expr ::= PLUS expr */ |
| 2940 | | -#line 766 "pikchr.y" |
| 2972 | +#line 767 "pikchr.y" |
| 2941 | 2973 | {yymsp[-1].minor.yy21=yymsp[0].minor.yy21;} |
| 2942 | | -#line 2967 "pikchr.c" |
| 2974 | +#line 2999 "pikchr.c" |
| 2943 | 2975 | break; |
| 2944 | 2976 | case 104: /* expr ::= LP expr RP */ |
| 2945 | | -#line 767 "pikchr.y" |
| 2977 | +#line 768 "pikchr.y" |
| 2946 | 2978 | {yymsp[-2].minor.yy21=yymsp[-1].minor.yy21;} |
| 2947 | | -#line 2972 "pikchr.c" |
| 2979 | +#line 3004 "pikchr.c" |
| 2948 | 2980 | break; |
| 2949 | 2981 | case 105: /* expr ::= LP FILL|COLOR|THICKNESS RP */ |
| 2950 | | -#line 768 "pikchr.y" |
| 2982 | +#line 769 "pikchr.y" |
| 2951 | 2983 | {yymsp[-2].minor.yy21=pik_get_var(p,&yymsp[-1].minor.yy0);} |
| 2952 | | -#line 2977 "pikchr.c" |
| 2984 | +#line 3009 "pikchr.c" |
| 2953 | 2985 | break; |
| 2954 | 2986 | case 106: /* expr ::= NUMBER */ |
| 2955 | | -#line 769 "pikchr.y" |
| 2987 | +#line 770 "pikchr.y" |
| 2956 | 2988 | {yylhsminor.yy21=pik_atof(&yymsp[0].minor.yy0);} |
| 2957 | | -#line 2982 "pikchr.c" |
| 2989 | +#line 3014 "pikchr.c" |
| 2958 | 2990 | yymsp[0].minor.yy21 = yylhsminor.yy21; |
| 2959 | 2991 | break; |
| 2960 | 2992 | case 107: /* expr ::= ID */ |
| 2961 | | -#line 770 "pikchr.y" |
| 2993 | +#line 771 "pikchr.y" |
| 2962 | 2994 | {yylhsminor.yy21=pik_get_var(p,&yymsp[0].minor.yy0);} |
| 2963 | | -#line 2988 "pikchr.c" |
| 2995 | +#line 3020 "pikchr.c" |
| 2964 | 2996 | yymsp[0].minor.yy21 = yylhsminor.yy21; |
| 2965 | 2997 | break; |
| 2966 | 2998 | case 108: /* expr ::= FUNC1 LP expr RP */ |
| 2967 | | -#line 771 "pikchr.y" |
| 2999 | +#line 772 "pikchr.y" |
| 2968 | 3000 | {yylhsminor.yy21 = pik_func(p,&yymsp[-3].minor.yy0,yymsp[-1].minor.yy21,0.0);} |
| 2969 | | -#line 2994 "pikchr.c" |
| 3001 | +#line 3026 "pikchr.c" |
| 2970 | 3002 | yymsp[-3].minor.yy21 = yylhsminor.yy21; |
| 2971 | 3003 | break; |
| 2972 | 3004 | case 109: /* expr ::= FUNC2 LP expr COMMA expr RP */ |
| 2973 | | -#line 772 "pikchr.y" |
| 3005 | +#line 773 "pikchr.y" |
| 2974 | 3006 | {yylhsminor.yy21 = pik_func(p,&yymsp[-5].minor.yy0,yymsp[-3].minor.yy21,yymsp[-1].minor.yy21);} |
| 2975 | | -#line 3000 "pikchr.c" |
| 3007 | +#line 3032 "pikchr.c" |
| 2976 | 3008 | yymsp[-5].minor.yy21 = yylhsminor.yy21; |
| 2977 | 3009 | break; |
| 2978 | 3010 | case 110: /* expr ::= DIST LP position COMMA position RP */ |
| 2979 | | -#line 773 "pikchr.y" |
| 3011 | +#line 774 "pikchr.y" |
| 2980 | 3012 | {yymsp[-5].minor.yy21 = pik_dist(&yymsp[-3].minor.yy63,&yymsp[-1].minor.yy63);} |
| 2981 | | -#line 3006 "pikchr.c" |
| 3013 | +#line 3038 "pikchr.c" |
| 2982 | 3014 | break; |
| 2983 | 3015 | case 111: /* expr ::= place2 DOT_XY X */ |
| 2984 | | -#line 774 "pikchr.y" |
| 3016 | +#line 775 "pikchr.y" |
| 2985 | 3017 | {yylhsminor.yy21 = yymsp[-2].minor.yy63.x;} |
| 2986 | | -#line 3011 "pikchr.c" |
| 3018 | +#line 3043 "pikchr.c" |
| 2987 | 3019 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 2988 | 3020 | break; |
| 2989 | 3021 | case 112: /* expr ::= place2 DOT_XY Y */ |
| 2990 | | -#line 775 "pikchr.y" |
| 3022 | +#line 776 "pikchr.y" |
| 2991 | 3023 | {yylhsminor.yy21 = yymsp[-2].minor.yy63.y;} |
| 2992 | | -#line 3017 "pikchr.c" |
| 3024 | +#line 3049 "pikchr.c" |
| 2993 | 3025 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 2994 | 3026 | break; |
| 2995 | 3027 | case 113: /* expr ::= object DOT_L numproperty */ |
| 2996 | 3028 | case 114: /* expr ::= object DOT_L dashproperty */ yytestcase(yyruleno==114); |
| 2997 | 3029 | case 115: /* expr ::= object DOT_L colorproperty */ yytestcase(yyruleno==115); |
| 2998 | | -#line 776 "pikchr.y" |
| 3030 | +#line 777 "pikchr.y" |
| 2999 | 3031 | {yylhsminor.yy21=pik_property_of(yymsp[-2].minor.yy162,&yymsp[0].minor.yy0);} |
| 3000 | | -#line 3025 "pikchr.c" |
| 3032 | +#line 3057 "pikchr.c" |
| 3001 | 3033 | yymsp[-2].minor.yy21 = yylhsminor.yy21; |
| 3002 | 3034 | break; |
| 3003 | 3035 | default: |
| 3004 | 3036 | /* (116) lvalue ::= ID */ yytestcase(yyruleno==116); |
| 3005 | 3037 | /* (117) lvalue ::= FILL */ yytestcase(yyruleno==117); |
| | @@ -3098,19 +3130,19 @@ |
| 3098 | 3130 | ){ |
| 3099 | 3131 | pik_parserARG_FETCH |
| 3100 | 3132 | pik_parserCTX_FETCH |
| 3101 | 3133 | #define TOKEN yyminor |
| 3102 | 3134 | /************ Begin %syntax_error code ****************************************/ |
| 3103 | | -#line 536 "pikchr.y" |
| 3135 | +#line 537 "pikchr.y" |
| 3104 | 3136 | |
| 3105 | 3137 | if( TOKEN.z && TOKEN.z[0] ){ |
| 3106 | 3138 | pik_error(p, &TOKEN, "syntax error"); |
| 3107 | 3139 | }else{ |
| 3108 | 3140 | pik_error(p, 0, "syntax error"); |
| 3109 | 3141 | } |
| 3110 | 3142 | UNUSED_PARAMETER(yymajor); |
| 3111 | | -#line 3136 "pikchr.c" |
| 3143 | +#line 3168 "pikchr.c" |
| 3112 | 3144 | /************ End %syntax_error code ******************************************/ |
| 3113 | 3145 | pik_parserARG_STORE /* Suppress warning about unused %extra_argument variable */ |
| 3114 | 3146 | pik_parserCTX_STORE |
| 3115 | 3147 | } |
| 3116 | 3148 | |
| | @@ -3227,23 +3259,16 @@ |
| 3227 | 3259 | yypParser->yyhwm++; |
| 3228 | 3260 | assert( yypParser->yyhwm == |
| 3229 | 3261 | (int)(yypParser->yytos - yypParser->yystack)); |
| 3230 | 3262 | } |
| 3231 | 3263 | #endif |
| 3232 | | -#if YYSTACKDEPTH>0 |
| 3233 | 3264 | if( yypParser->yytos>=yypParser->yystackEnd ){ |
| 3234 | | - yyStackOverflow(yypParser); |
| 3235 | | - break; |
| 3236 | | - } |
| 3237 | | -#else |
| 3238 | | - if( yypParser->yytos>=&yypParser->yystack[yypParser->yystksz-1] ){ |
| 3239 | 3265 | if( yyGrowStack(yypParser) ){ |
| 3240 | 3266 | yyStackOverflow(yypParser); |
| 3241 | 3267 | break; |
| 3242 | 3268 | } |
| 3243 | 3269 | } |
| 3244 | | -#endif |
| 3245 | 3270 | } |
| 3246 | 3271 | yyact = yy_reduce(yypParser,yyruleno,yymajor,yyminor pik_parserCTX_PARAM); |
| 3247 | 3272 | }else if( yyact <= YY_MAX_SHIFTREDUCE ){ |
| 3248 | 3273 | yy_shift(yypParser,yyact,(YYCODETYPE)yymajor,yyminor); |
| 3249 | 3274 | #ifndef YYNOERRORRECOVERY |
| | @@ -3382,11 +3407,11 @@ |
| 3382 | 3407 | #else |
| 3383 | 3408 | (void)iToken; |
| 3384 | 3409 | return 0; |
| 3385 | 3410 | #endif |
| 3386 | 3411 | } |
| 3387 | | -#line 781 "pikchr.y" |
| 3412 | +#line 782 "pikchr.y" |
| 3388 | 3413 | |
| 3389 | 3414 | |
| 3390 | 3415 | |
| 3391 | 3416 | /* Chart of the 148 official CSS color names with their |
| 3392 | 3417 | ** corresponding RGB values thru Color Module Level 4: |
| | @@ -3963,10 +3988,11 @@ |
| 3963 | 3988 | |
| 3964 | 3989 | /* Methods for the "diamond" class */ |
| 3965 | 3990 | static void diamondInit(Pik *p, PObj *pObj){ |
| 3966 | 3991 | pObj->w = pik_value(p, "diamondwid",10,0); |
| 3967 | 3992 | pObj->h = pik_value(p, "diamondht",9,0); |
| 3993 | + pObj->bAltAutoFit = 1; |
| 3968 | 3994 | } |
| 3969 | 3995 | /* Return offset from the center of the box to the compass point |
| 3970 | 3996 | ** given by parameter cp */ |
| 3971 | 3997 | static PPoint diamondOffset(Pik *p, PObj *pObj, int cp){ |
| 3972 | 3998 | PPoint pt = cZeroPoint; |
| | @@ -3988,10 +4014,12 @@ |
| 3988 | 4014 | } |
| 3989 | 4015 | UNUSED_PARAMETER(p); |
| 3990 | 4016 | return pt; |
| 3991 | 4017 | } |
| 3992 | 4018 | static void diamondFit(Pik *p, PObj *pObj, PNum w, PNum h){ |
| 4019 | + if( pObj->w<=0 ) pObj->w = w*1.5; |
| 4020 | + if( pObj->h<=0 ) pObj->h = h*1.5; |
| 3993 | 4021 | if( pObj->w>0 && pObj->h>0 ){ |
| 3994 | 4022 | PNum x = pObj->w*h/pObj->h + w; |
| 3995 | 4023 | PNum y = pObj->h*x/pObj->w; |
| 3996 | 4024 | pObj->w = x; |
| 3997 | 4025 | pObj->h = y; |
| | @@ -6334,12 +6362,16 @@ |
| 6334 | 6362 | } |
| 6335 | 6363 | if( pObj->type->xFit==0 ) return; |
| 6336 | 6364 | pik_bbox_init(&bbox); |
| 6337 | 6365 | pik_compute_layout_settings(p); |
| 6338 | 6366 | pik_append_txt(p, pObj, &bbox); |
| 6339 | | - w = (eWhich & 1)!=0 ? (bbox.ne.x - bbox.sw.x) + p->charWidth : 0; |
| 6340 | | - if( eWhich & 2 ){ |
| 6367 | + if( (eWhich & 1)!=0 || pObj->bAltAutoFit ){ |
| 6368 | + w = (bbox.ne.x - bbox.sw.x) + p->charWidth; |
| 6369 | + }else{ |
| 6370 | + w = 0; |
| 6371 | + } |
| 6372 | + if( (eWhich & 2)!=0 || pObj->bAltAutoFit ){ |
| 6341 | 6373 | PNum h1, h2; |
| 6342 | 6374 | h1 = (bbox.ne.y - pObj->ptAt.y); |
| 6343 | 6375 | h2 = (pObj->ptAt.y - bbox.sw.y); |
| 6344 | 6376 | h = 2.0*( h1<h2 ? h2 : h1 ) + 0.5*p->charHeight; |
| 6345 | 6377 | }else{ |
| | @@ -8208,6 +8240,6 @@ |
| 8208 | 8240 | |
| 8209 | 8241 | |
| 8210 | 8242 | #endif /* PIKCHR_TCL */ |
| 8211 | 8243 | |
| 8212 | 8244 | |
| 8213 | | -#line 8238 "pikchr.c" |
| 8245 | +#line 8270 "pikchr.c" |
| 8214 | 8246 | |