1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 1682 1683 1684 1685 1686 1687 1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698 1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837 1838 1839 1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075 2076 2077 2078 2079 2080 2081 2082 2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126 2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218 2219 2220 2221 2222 2223 2224 2225 2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338 2339 2340 2341 2342 2343 2344 2345 2346 2347 2348 2349 2350 2351 2352 2353 2354 2355 2356 2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 2368 2369 2370 2371 2372 2373 2374 2375 2376 2377 2378 2379 2380 2381 2382 2383 2384 2385 2386 2387 2388 2389 2390 2391 2392 2393 2394 2395 2396 2397 2398 2399 2400 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410 2411 2412 2413 2414 2415 2416 2417 2418 2419 2420 2421 2422 2423 2424 2425 2426 2427 2428 2429 2430 2431 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447 2448 2449 2450 2451 2452 2453 2454 2455 2456 2457 2458 2459 2460 2461 2462 2463 2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 2480 2481 2482 2483 2484 2485 2486 2487 2488 2489 2490 2491 2492 2493 2494 2495 2496 2497 2498 2499 2500 2501 2502 2503 2504 2505 2506 2507 2508 2509 2510 2511 2512 2513 2514 2515 2516 2517 2518 2519 2520 2521 2522 2523 2524 2525 2526 2527 2528 2529 2530 2531 2532 2533 2534 2535 2536 2537 2538 2539 2540 2541 2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 2592 2593 2594 2595 2596 2597 2598 2599 2600 2601 2602 2603 2604 2605 2606 2607 2608 2609 2610 2611 2612 2613 2614 2615 2616 2617 2618 2619 2620 2621 2622 2623 2624 2625 2626 2627 2628 2629 2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 2640 2641 2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652 2653 2654 2655 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665 2666 2667 2668 2669 2670 2671 2672 2673 2674 2675 2676 2677 2678 2679 2680 2681 2682 2683 2684 2685 2686 2687 2688 2689 2690 2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 2704 2705 2706 2707 2708 2709 2710 2711 2712 2713 2714 2715 2716 2717 2718 2719 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761 2762 2763 2764 2765 2766 2767 2768 2769 2770 2771 2772 2773 2774 2775 2776 2777 2778 2779 2780 2781 2782 2783 2784 2785 2786 2787 2788 2789 2790 2791 2792 2793 2794 2795 2796 2797 2798 2799 2800 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810 2811 2812 2813 2814 2815 2816 2817 2818 2819 2820 2821 2822 2823 2824 2825 2826 2827 2828 2829 2830 2831 2832 2833 2834 2835 2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 2861 2862 2863 2864 2865 2866 2867 2868 2869 2870 2871 2872 2873 2874 2875 2876 2877 2878 2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898 2899 2900 2901 2902 2903 2904 2905 2906 2907 2908 2909 2910 2911 2912 2913 2914 2915 2916 2917 2918 2919 2920 2921 2922 2923 2924 2925 2926 2927 2928 2929 2930 2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977 2978 2979 2980 2981 2982 2983 2984 2985 2986 2987 2988 2989 2990 2991 2992 2993 2994 2995 2996 2997 2998 2999 3000 3001 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 3013 3014 3015 3016 3017 3018 3019 3020 3021 3022 3023 3024 3025 3026 3027 3028 3029 3030 3031 3032 3033 3034 3035 3036 3037 3038 3039 3040 3041 3042 3043 3044 3045 3046 3047 3048 3049 3050 3051 3052 3053
|
%%% File: changes.tex
%%% A part of mfpic 0.7a beta 2004/04/16
%%%
Changes History.
VERSION 0.0.x:
Development versions. Never released.
VERSION 0.1:
First version released to network, 30 June 1992.
VERSION 0.1.x:
Test versions for new features, fixes, etc. None of them
were released for general distribution. Many new features added, bugs
worked out, code cleaned up.
VERSION 0.2:
Second version released to network, 7 Sept. 1992. (Still had 0.1.13.1
version number in code---oops!)
VERSIONS 0.2.x:
Resumed serious development of TeX code: Sun 7 Nov. 1993. Much work
done on graphbase code in meantime, especially by Geoffrey Tobin. The
primary task at this point was a radical rewrite of the TeX code,
including defining a prefix form for shading macros.
VERSION 0.2.5 of Wed 10 Nov. 1993:
Bug fix release Primarily work by Geoffrey Tobin.
REVISION 0.2.(5.0.)9 of Mon 28 Feb. 1994:
Intended to release as version 0.3 to network. Release delayed, as
picture operator code is overhauled to cope with arbitrary overlays: 11
Mar. 1994.
Horizontal offset by unwanted glue is traced to missing comment
characters: Fri 29 Apr. 1994.
Vertical displacement of shading reported for MF modes with
nonrectangular pixels: Mon 23 May 1994.
REVISION 0.2.5.1 of Wed 13 July 1994:
Bug fix release Corrected "unxconv" bug which remained in version
0.2.5's graphbase.mf.
Alpha Test Versions.
VERSION 0.2.9 Alpha of Thu 11 August 1994:
A test release prior to any official version 0.3, is ready for intrepid
users. Introduces coordinate transforms, and other novelties.
UPDATE 0.2.9.1 Alpha} of Thu 8 September 1994: Fixes a bug in \sclosed
and a bug in \white, corrects some omissions and typos in the
documentation, and adds the \shadewd, \hatchwd, \lhatch and \rhatch
macros.
UPDATE 0.2.9.2 Alpha of Fri 24 February 1995: Rearranges some code in
mfpic.tex; little else to report.
In 0.2.9.3 Alpha of Thu 21 March 1995:
GT renamed \fill to \gfill, in order to avoid conflict with the LaTeX
\fill macro.
UPDATE 0.2.9.4 Alpha of Thu 13 April 1995:
Contributes a test for an existing definition of each macro in
mfpic.tex,
Renaming of \label to \tlabel, and \caption to \tcaption, in order to
avoid conflict with the LaTeX macros with those names.
\white was renamed to \gclear, because \white is a likely name for a
color macro.
Also, a new macro for defining Metafont functions was introduced,
because user-defined functions provide more power, and function plotting
macros were added that accept Metafont function names instead of
Metafont expressions.
Renaming of graphbase.mf and graphdoc.tex to grafbase.mf and grafdoc.tex
to emphasise incompatible upgrade of mfpic Metafont macros, and to
provide $8+3$ filenames for ms-dos users.
Added \hbox{} to start of \mfpic, for some now forgotten reason to do
with formatting, I suppose.
VERSION 0.2.9.5 Alfa of Wed 19 July 1995:
Replaces TeX dimensions by font dimensions for economy.
Renames \mfcmd to \mfsrc for clarity.
Renames \wedge to \sector to avoid conflict with the character name
defined in plain TeX and LaTeX.
Introduces \mftitle, \tmtitle and \plr.
Abolishes \plrpoint, \plrlines, \plrcurve and \plrcyclic as
redundant specializations. The meaning of \turtle is changed to a
Cartesian form, for flexibility.
Changed objects.tex to use \tmtitle, \plr, \mfsrc, \gfill,
\gclear, \tlabel, and \tcaption.
Rendering macros redesigned, and \setrender introduced. Coordinate
transforms in grafbase.mf made slightly more robust. Begin an attempt
to make grafbase.mf compatible with John Hobby's MetaPost drawing
program.
Added comment in grafbase.mf about dangers of text arguments,
Updated the documentation files grafdoc.tex, Acknowl.tex, README2,
MANIFEST and mfpicdoc.tex.
UPDATE 0.2.9.6 Alfa of Mon 24 July 1995:
Contributes \thatch which provides hatching by lines at any angle.
Modifications to \pen, \shadewd and \hatchwd, along with changes to
grafbase.mf to make drawing, shading and hatching more independent.
Decided that the behavior of \point inside a connect environment was
bizarre, hazardous, and an unnecessary complication to the mfpic macros,
so \point has reverted to its original, obvious and simple definition.
Renamed \rotate to \rotatepath.
Also renamed the affine transform macros, so that they no longer use the
`s' of the present tense, which could be mistaken for a plural. (The
sample files did not hitherto use the affine transform macros, so the
damage may be slight.)
Modified grafbase.mf to use a transform stack to implement local
Metafont coordinate systems; this may be more robust, and extensible to
other graphic localizations.
UPDATE 0.2.9.7 alfa, Fri 18 August 1995:
Changes to pictures.tex:
Replaced version from "0.2.9.1 alpha Thu 8 September 1994" to
"0.2.9.7 alfa Sat 5 August 1995".
Added a comment containing an ASCII sketch of the commutative diagram
example, and indicated where each arc is drawn.
Replaced all uses of \label by \tlabel, \caption by \tcaption,
\fill by \gfill, \wedge by \sector.
Added some uses of \mftitle.
Moved one arrow in the commutative diagram, to illustrate the b
option of the \arrow command.
Simplified Metafont algebraic expressions used in function plots, so
that they use fewer * operators.
Edited the example of \turtle to allow for the new semantics of
rectangular coordinates.
Captioned all eight figures, with figure numbers and descriptions.
Deleted an instance of "\vfill\eject".
Increased the complexity of the seventh figure, to illustrate use of
hatching, closing, point, dotted curves, and so forth.
Made figures seven and eight twice as large.
Changes to lapictures.tex:
Renamed version from "0.2.9.1 alpha Thu 8 September 1994" to
"0.2.9.7 alfa Thu 17 August 1995".
Magnified the LaTeX pictures document to the same scale as the plain TeX
one, using the \mag command.
Set \fboxsep to zero.
Initialized arrow heads using \headshape.
Commented out the center environment around the commutative diagram
example.
Placed \fbox commands around each picture.
Other changes as in pictures.tex.
Extensive changes to grafbase.mf:
Turned warningcheck off.
Used an explicit designsize.
Debugging refined.
Rearranged some code.
Made ClipOn boolean (instead of numeric).
Added maparr macro.
Eliminated mistake of using hround in graph-to-pixel coordinate
transformation.
Remarked that clipping can distort paths by changing their points.
Tried to clip on character boundary.
Added Metafont vector coordinate transform, to complement affine
transform for geometric points.
Write message when drawing nominal Metafont bounding box.
Changed beginmfpic Metafont macro to take only the character code as
an argument.
Introduced global Metafont transform stack, for coordinate changes.
Replaced currentpen by drawpen in path stroking.
Changed ourfill and ourunfill to use an undelimited path argument.
Added setdotpath, ourdot.
Changed onedot to use dotpath instead of a scaled shape path.
Edited tightbbox and bbox to take a path described in pixel
coordinates as their first argument, instead of one in graph
coordinates.
Added tbbox.
Did some more saving of local variables in Metafont functions.
Deleted lhatchf and rhatchf.
Added thatchf, thatch, hhatch and xhatch.
Rewrote lhatch and rhatch to use thatch.
Edited dotted, renamed it dashed.
Added a separate dotted Metafont macro.
Changed head from a def to a vardef; edited head to clarify its
code.
Altered axis tic mark macros, xmarks and ymarks to ensure that the
tic marks are always at right angles to their axes, irrespective of
coordinate transforms.
Added a grid command.
Renamed mkellipse to ellipse, deleted old ellipse.
Renamed mkarc to arc.
UPDATE 0.2.9.8 alfa, Mon 11 September 1995:
Added to Acknowl.tex.
In mfpic.tex:
Add comment about use of \ignorespaces to skip spaces in user's
document after \mfpic command.
Retain line separations of user's document's mfpic environment when
writing Metafont file. This prevents long Metafont commands from
exceeding Metafont's input buffer.
UPDATE 0.2.9.9 alfa, Thu 5 October 1995:
In mfpicdoc.tex:
changed \wedge references to \sector, and \rotateabout to
\rotatearound.
Added some logical formatting commands to mfpicdoc.tex.
Included much more information about recent changes (from 0.2.9.1 to
0.2.9.8).
In mfpic.tex:
Renamed \@graph to \@graphfont for identifiability.
UPDATE 0.2.9.10 alfa, Fri 6 October 1995:
In grafbase.mf:
Deleted spurious argument to \xyswap.
Changed \store to take two arguments, and to logically bracket the
second, which is the path description.
UPDATE 0.2.9.11 alfa, Fri 24 November 1995:
In grafbase.mf:
Fixed X-coordinate rounding bug in thatchf.
REVISION 0.2.10.0 alfa, Wed 17 January 1996:
In mfpic.tex and grafbase.mf:
Changed names of five Metafont macros: xslanted, yslanted, zslanted,
boosted, and xyswapped to xslant, yslant, zslant, boost, xyswap.
In grafbase.mf:
Replaced my dash and dot code by Frank Michielsen's, modified to use
suffix arguments instead of text for l-values.
Also, the dotsize argument to dotted is now effective.
Deleted the unused ourdraw, ourfill, ourunfill macros.
Simplified the dotpath and onedot initialization code; it was too
baroque.
Added a pixdot macro as a shorthand for picdot(active_plane,onedot,p).
Replaced the apoint (w, a) macro by bpoint (w, b) which is a
shorthand for fullcircle scaled w shifted b.
Gratuitously added Bruce Leban's overlay macros from the METAFONTbook,
page 295.
Cosmetic reformatting of source.
In Acknowl.tex:
Add Frank Michielsen's name.
REVISION 0.2.10.1 alfa, Thu 18 January 1996:
In grafbase.mf:
Fixed wrong declaration in dotted of dp from path to pair.
REVISION 0.2.10.2 alfa, Tue 23 January 1996:
Editing to restore compatibility with older graphbase.mf versions used
with xfig's (actually, transfig's fig2dev's) mf driver (genmf.c).
In mfpic.tex:
Edited writing of setting of Metafont variables xscale and yscale to
omit factor of unitlen.
Changed references to drawwd to penwd in \drawpen.
In grafbase.mf:
Add declarations and initializations of these variables: unitlen,
xscale, yscale, xneg, xpos, yneg, ypos.
Renamed drawwd to its former name, penwd.
Again made penwd, hdwdr, hdten into newinternal variables, and
assign them using interim.
Definition of ztr now includes unitlen as a factor in the x and y
scaling.
mfpicenv and endmfpicenv defined as empty statements.
bounds defined for setting xneg, xpos, yneg, ypos.
beginchar now includes unitlen.
REVISION 0.2.10.3 alfa, Tue 6 February 1996:
In mfpicdoc.tex:
Updated documentation to cover to \dotted, \dotsize and \dotspace
on the one hand, and \dashed, \dashlen and \dashspace on the other.
REVISION 0.2.10.4 alfa, Mon 26 February 1996:
In mfpic.tex:
Let internal \sim@gdef (simple global definition) stand for \gdef.
Added \newgdef for new global definitions with a test for previous
definition.
Replaced use of \obeylines by \mfpicobeylines, to use \endgraf instead
of \par, because LaTeX(2e) redefines \par with unpleasant effects on
Metafont files when using LaTeX's center environment. (To wit, LaTeX's
center environment would write \@@par to the Metafont file.
Defined \preservelines to call \mfpicobeylines then set
\newlinechar to control-M (carriage return).
Use \preservelines in \mfsrc, thus bypassing (I hope) the mischief
arising from LaTeX in the center environment.
Wrapped replacement text of \mfsrc in a layer of braces.
Added descriptive comments for \tlabel and \tcaption.
Set TeX's primitives \leftskip and \rightskip to zero dimension
inside \tcaption, so as to protect typesetting of diagrams' captions
from unwanted effects.
REVISION 0.2.10.5 alfa, Sat 9 March 1996:
Minor reformatting of mfpic.tex, including adding spaces, adding
comment characters at end of more lines, and renaming some internal
register variables.
Introduced \polyline as an alternative name for \lines.
In order to avoid repetition of side-effects, changed \tcaption to use
\unhbox\@textbox, instead of repeating its text argument.
REVISION 0.2.10.6 alfa, (two hours later) on Sat 9 March 1996:
Updated mfpic.tex and documentation files to incorporate improvements
by Dan Luecking:
a loading check that automatically saves and restores the catcode of
`@';
the name of the graph base is now stored in a macro near the top of
mfpic.tex;
\leavevmode is now moved [GT has, for now, commented it out
completely];
\polyline introduced as a synonym for \lines; a \polygon figure
has been introduced;
\\ specifies explicit line breaks in tlabels and tcaptions;
\onelevel causes one level of expansion in an \edef;
\savepic and \copypic allow saving, use and copying of an entire
mfpic picture, including its tcaptions and tlabels.
Also modified \tcaption code to prevent repeated use of the text
argument, as that can cause side effects, as reported by Dennis
Petrovic.
REVISION 0.2.10.7 alfa, Sat 28 March 1996:
First release via Geoffrey Tobin's School's local anon ftp site:
ftp.ee.latrobe.edu.au : pub/gt/mfpic
Added skip-pix.tex file, which tests whether TeX's \leftskip
primitive breaks up mfpic's typesetting of diagrams. Fortunately, it
seems not.
REVISION 0.2.10.8 alfa, Tue 26 May 1996:
Second, and bug fix, release via Geoffrey Tobin's anonymous ftp area.
Due to change in syntax of \store to take the path command as a second
argument (which made coding of mfpic.tex easier), objects.tex and
part of mfpicdoc.tex needed to be amended. Reported by Miroslav Dont
(Thu 16 May 1996).
Descriptions of LaTeX environments clarified to emphasise that mfpic's
plain TeX command names may be used in LaTeX. This is useful to know
when designing automatic code generators. Reported by Van Snyder (Fri
17 May 1996).
Added hyphenation to \MFbook in documentation macro file header.tex.
Noticed that the method by which the line breaks in the TeX file are
copied into the Metafont file can cause command arguments to be omitted
from the Metafont file unless at least the left brace (immediately
before the arguments) occurs on the same line as the command. Corrected
objects.tex to obey this restriction. Also noted this phenomenon in
mfpicdoc.tex. Effect reported by Miroslav Dont (Thu 16 May 1996).
Updated lapictures.tex to LaTeX2e.
Added LaTeX2e logo to header.tex.
REVISION 0.3.0 alpha, 1998:
Numbers jump a lot from here because I (Dan Luecking) have been lax in
keeping track of changes. First version with support for Metapost.
(Yes!)
Translated grafbase.mf to grafbase.mp, retaining all(?)
functionality. Now any(?) .mf file created by a recent mfpic can be
run through Metapost to produce a PostScript picture. Lots of problems
with Metapost capacity, especially with shading. It is apparently a lot
more memory intensive to hold thousands of circular paths in memory than
hundreds of thousands of pixels. Ultimately recoded the grafbase.mp
shading macros to simply calculate a gray colored fill.
Added grafbase functions sin, cos, and their inverses invsin,
etc., that compute in radian measure. Also tan and cot.
Wrote mppicdoc.tex, which can be TeX-ed alone or input from
mfpicdoc.tex. Should probably combine the two documents. Made small
changes to header.tex: added logos for pdfTeX and pdfLaTeX. Changed
The macros \MF and \MP to use small capitals. Minor modifications to
\LaTeX and \LaTeXe
REVISION 0.3.8 alpha, 1999:
Color has been added. Standard colors for lines/curves (drawcolor),
fills (fillcolor), hatch patterns (hatchcolor), and arrowheads
(headcolor) added to grafbase.mp. Corresponding macros in mppic.tex
for setting these colors. Optional arguments for color added to \gfill,
\draw, \arrow, and all the hatching macros. A new macro \polkadot
creates polkadot fill patterns.
Changed some of the commands for setting dimensions so that they
actually worked, and so they are local to mfpic environments.
Added support for LaTeX2e's \usepackage command and options. Added
graphics inclusion code, summoning the following packages: epsf for
plain TeX or LaTeX209, graphics for LaTeX2e and pdfLaTeX, the macro
files supp-pdf.tex and supp-mis.tex from the ConTeXt distribution
for plain \pdfTeX). Added code to detect which TeX format was in use.
REVISION 0.3.9 alpha, 2000:
Altered almost all messages written to the log file or the terminal to
announce they were from mfpic. Altered format detection code to test
against both \UndEfInEd _and_ \relax (lest some previous package
convert certain commands to \relax using the \csname style test).
Minor change to definition of \circle to avoid error messages in LaTeX.
Changed the graphic placement code so that it tests for the existence of
the graphic first (to avoid all those error messages from epsf,
graphics, etc., on the first pass, or when Metapost fails to make a
graphic).
Tried to find and change code in grafbase where we could inadvertently
divide by zero. Added another closure prefix \uclosed and its
corresponding grafbase support, to close a path smoothly (meaning
simply matching directions at both ends), but keep the original curve
Unchanged. The current (\sclosed simply closes with ..cycle which
alters the original curve.
REVISION 0.3.10 alpha, 2000:
Put mfpic version, date and package name into macros for use in
messages. Decided the package name is "mfpic" if it is input as
mfpic.tex or mfpic.sty, otherwise mppic, regardless of whether the
metafont or metapost option is used. There are four files
m[fp]ic.[sty,tex], which simply set the package name and input
mppic.tex if necessary. Also put this version and date info into
strings in grafbase.mf.
Added changes contributed by Jaromir Kuben (Thanks!): An option
centercaptions and command \centercaptions to center the lines in a
\tcaption. Also \nocentercaptions; these can be used at any point to
turn the feature on and off. Improvements (corrections?) to the code
that positions text labels (so that) labels that extend outside the
picture are correctly taken into account. Changes to the positioning
parameters in \tlabel. Both c and b now take into account the
depth of the text b puts the absolute bottom of the text in line with
the point. A new parameter B to align the baseline of the text with
the point. Jaromir also contributed several corrections to grafbase.mp
(mostly inadvertently introduced by me, DHL).
Added option dvipsnames to allow color names as in the dvips header
color.pro. Requires file dvipsnam.mp. Added grafbase.mp macros:
cmyk, RGB, gray and rgb to convert from the indicated color space
to Metapost's internal color space (which is rgb, so the last is a
no-op). In plain TeX the command \dvipsnames can be used in the
preamble (before \opengraphsfile).
Added macro \ConTeXt to header.tex, a macro \opt for style of
LaTeX2e option names. Changed \prog to typeset its argument in
sans serif font. Changed \tmtitle in mppic.tex so it _doesn't_ ignore
following spaces (it ended with \mftitle which invokes \ignorespaces).
Added functions tanh, its inverse atanh, and additional trig
functions secd, sec, cscd, csc, atan, invtan. Made log a
synonym for ln. Added complex variables functions Arg, cis, zexp
and Log.
Changed all trig, hyperbolic, exp, log, etc, to use syntax "vardef
<name> primary X" so as to match (I hope) as close as possible the
behavior of the built-in sind and cosd.
Changed \do@ptparami so that it does not strip too many braces. This
was done by changing the line \redef\@ptparami to be parameterless
(delaying the reading of the optional parameter). The old code read the
optional parameter, replaced it, then read it again. This strips two
levels of braces, making two levels of bracing necessary to hide an
enclosed bracket:
\draw[{{\color[cmyk]{1,1,0,0}}}]...
(Such use of LaTeX color macros has not yet been added, but might be one
day.) This strategy is closer to LaTeX's optional parameter handling
technique.
REVISION 0.3.11 alpha, 2000:
Added \plot (usage \plot[<size>,<separation>]{<shape>}...) similar to
\dotted except:
1) explicit shape required (shapes Triangle, Square, Circle, Plus,
Cross, Star, SolidTriangle, SolidSquare, SolidCircle).
2) initial size and separation are 2pt and 5pt.
3) Size is governed by \plotsymbolsize, and separation by
\plotsymbolspace. The dimension \plotsymbolsize corresponds
roughly to the _average_ diameter of the shape.
Added code to mkfcn and parafcn so that the end of the curve falls
on the given endpoint (even if bst doesn't go evenly into bmax-bmin).
Also ensure the loop parameter doesn't exceed infinity. Also avoid
problems if the sign of bmax-bmin differs from that of bst.
REVISION 0.3.12 alpha, 2000:
Save and restore catcodes of certain punctuation (@.,:;!?{}`'=/- and
parentheses), as well as spaces, setting punctuation to 12 while reading
mppic.tex to ensure the right stuff gets written to the .log and .mp
files.
Added macro \datafile to read a file of number pairs and create the
polygonal path connecting them. Works like the other figure macros
(i.e., may take any prefixes).
Added options clip (to clip all pictures to the specified dimensions),
truebbox (to give the metapost output file the true bounding box rather
than the one specified in the \mfpic arguments), and debug (write
debugging info to terminal and log file). Command forms: \clipmfpic
turns it on \noclipmfpic turns it off. Similarly, \usetruebbox and
\notruebbox. For debug we can define \mfpicdebug before loading
mfpic.tex (which will turn on debugging information written prior to
option processing), and in the rest of a source file, \mfpicdebugtrue
and \mfpicdebugfalse will switch it on and off.
%%% Revised after here, adding spaces before and after code and math
%%% removing blank lines, stray TeX markup, reformatting paragraphs, etc.
Changed names of various commands to a more imperative form:
\usingmetapost becomes \usemetapost, \usingmetafont becomes
\usemetafont, \dvipsnames becomes \usedvipsnames, etc. Also changed
name of option centercaptions to centeredcaptions. Changed many
internal names, prefixing most with "mfp@", inserting "@mfp@" in the
\if... commands.
REVISION 0.3.13 alpha, 2000:
\datafile rewritten, now ignores leading blank lines and comments, and
won't gag on commented out EOLs. Code somewhat modularized.
Went back to technique of expanding argument of \tcaption twice
(caveat emptor).
New command \plotdata reads a data file and draws one (polygonal) path
for each non-blank sequence of lines in the data file. Exits when a pair
of blank lines is encountered (or EOF). Cycles through six different
drawing styles for successive curves. User may elect different colors
(with \coloredlines), different symbols (\pointedlines), or
different dashing patterns (\dashedlines). NOT a figure macro, (i.e.,
no prefixes).
New command \using affects what \datafile and \plotdata write to
the .mf output. Default is \using{#1 #2 #3}{#1,#2}, meaning: of two
or more space delimited numbers, write the first two separated by a
comma.
Brand new dashing and dotting code in grafbase. A complete
reorganization of the code made dashing faster. That was followed by
another reorganization and the gendashed (generalized dashes) command
added to grafbase. Now any dashing pattern can be drawn. A dashing
pattern, ptrn, consists of three arrays: ptrn.start[], ptrn.rep[],
ptrn.finish[]. The command gendashed (ptrn) p; draws the path p
beginning with ptrn.start, repeating ptrn.rep, and ending with
ptrn.finish. The arrays are numeric and specify the lengths of dashes
and gaps. A command
dashpat (suffix name) (text dims)
takes a comma separated list dims, assigns them to the array name.rep,
and computes reasonable name.start and name.finish.
\gendashed{<pattern>}... is a generalized dashing command; <pattern>
is the name of a dashing pattern.
\dashpat{<name>}{<dim1>,<dim2>,...,<dim2n>}
will create a dashing pattern with the specified name. Here <dim1>,
etc., are dimensions specifying the length of dashes (odd positions) and
the length of gaps (even positions). A dash length of 0 is written as a
dot. Patterns dashtype0 through dashtype5 are predefined and used by
\plotdata when \dashedlines is selected.
Commented out several macros in grafbase that were never used
elsewhere, and also some that were only used once (replacing that use by
the replacement text). I haven't done any comparisons, but for the macro
dotted, avoiding two expansions out of four (what it used to take to
draw a dot) might be a significant time saving when thousands of dots
are being drawn.
Added a couple of rounding commands to the .mf shading code. All dots
now pixel aligned, looks infinitely better.
Corrections to mkfcn and parafcn, they could still have overshot the
value of bmax.
Removed all spaces (commenting out EOL's) in mppic.tex. It can now be
\input in horizontal mode without generating any spaces (even without
switching to \nullfont). Removed \nullfont.
Changed some more internal names. Added Diamond and SolidDiamond to
the symbols available to \plot and \plotsymbol.
At some point (perhaps this or the last revision) I added a command
\fcncurve that draws a function (i.e., curve doesn't double back) if
the x-values are unique and listed in order. It has an optional
tension-like argument. Added an optional tension parameter to \curve,
also.
REVISION 0.3.14 alpha, 2000:
Added \@@tlabel to write label text to output file between btex and
etex. Added mplabels to make \tlabel use it instead of original
\@tlabel. Commands \usemplabels and \nomplabels to turn the option
on and off. Added third part to the optional argument of \tlabel to
rotate the text (ignored in \@tlabel) so \tlabel[Bl45] will place
the left baseline at the point and rotate 45 degrees around that point.
New macro \mfpdatacomment so that \datafile and \plotdata can now
have their comment character reset. A side effect is that `%'s in the
data file will be recognized. Commands \makepercentother and
\makepercentcomment created to allow the user to use `%' in \using
arguments.
Gave \plotdata the ability to cycle through 8 colors or 9 symbols
(instead of only 6), but still only 6 dash patterns. (Too many makes for
confusion. Only increased colors and symbols because it was so easy.)
Added framing macro. On the first TeX run (indicated by nonexistence of
.tfm or fig.1), now show a visible rectangle of appropriate size with
the figure number inside. For plain TeX users, the internal code is made
available in the user level command \framed[<fgap>]{...}. Parameters
\framegap and \framethickness control the default appearance.
(Internal code for undefined figures uses \framegap =-\framethickness
so not to take up any extra space.)
Added some error checking: when option mplabels is selected without
metapost, issue error message and ignore. Same when \usemetapost is
used after \opengraphsfile. Remove dvipsnames option, making all
dvips color names always available to mfpic.
Multiple changes to documentation: Added \GS for Ghostscript and \sc
for small caps to header.tex. Folded all the new macros and their
descriptions into mfpicdoc.tex. Still keeping mppicdoc.tex for more
detail on differences between the Metafont and Metapost support.
Made some small additions to MFobjs.tex and MPobjs.tex to better
illustrate some new features. Adjusted pictures.tex and
lapictures.tex so they produce the same output and no overfull boxes.
Changed TeXMPobjs.tex and LTXMPobjs.tex so that they work better in
pdfTeX and pdfLaTeX, resetting \pdfpageheight and \pdfpagewidth (which
otherwise get magnified by \mag=1200).
Replaced curves.dat with curves1.dat and curves2.dat to better
show features of \plotdata.
Changed the default for \using to \using{#1 #2 #3}{(#1,#2)},
(redundant parentheses).
Added \fdef, which seemed to be documented, but not defined! Changed
the format slightly and adjusted the documentation to reflect that.
Changed \savepic: Now use \newpic{\foo} to allocate a box,
\savepic{\foo} to store the next picture, and \usepic{\foo} to copy
it. Now more like LaTeX's system of save boxes.
REVISION 0.3.15 alpha, 2000:
In grafbase, changed secd and cscd so that abs(temp) <
nottoosmall is tested instead of temp itself (which was incorrect when
temp < -nottoosmall). Renamed dashed to DASHED to make primitive
dashed available to power users. Added some error checking to dashing
code. Added save in several places in *fcn commands. Changed
hatching code in grafbase.mp so that all (even those not used by mfpic)
respect hatchcolor.
Redefined parafcn so it can call mkfcn like all the other function
drawing commands.
Added \mfpverbtex to write verbatimtex block to .mp file.
Changed a few \newdef-s and \newlets to \def and \let to keep
ConTeXt from complaining. Affected commands are \rotate, \mirror,
\scale and \grid. Changed code for date written to output file for
same reason.
Changed \newpic to \newsavepic to more closely parallel LaTeX's
\newsavebox command.
Allow plotting of a number in a data file against its sequence position
with \using{...}{...\sequence...}.
Rename \mf@gobble to \mfp@gobble. Move the definition of \newdef
earlier and use it more (didn't catch any new conflicts).
Changed \rotatepath from a \@modmac to a \@closmac (even though it
doesn't close anything), because that makes its behavior vis-a-vis
rendering more in line with what one might expect. Actually, closing and
rotating both simply accept a path, change it, and pass the result on.
So both should be handled the same.
Added contributed macro \pointdef: \pointdef{A}(1,3) makes \A expand
to (1,3), with \Ax and \Ay expanding
to 1 and 3, respectively.
Provide a directory structure to the distribution. Rename file mppic.tex
to mfpic.tex and provide files mppic.tex, mfpic.sty, and mppic.sty
as wrappers to input it. Made Metapost the default when mppic.* are
used.
Add some error correction to dashpat: force an even number of
dimensions.
REVISION 0.3.16 alpha, 2000:
In grafbase:
Change name of glabel (in grafbase.mp) to gblabel so as not to
conflict with glabel from graph.mp in the standard Metapost
distribution. Adjusted mfpic.tex accordingly.
Correct the change to dashpat made in 0.3.15: don't force dashing when
there are fewer than 2 dimensions in the list. Instead, this is the
signal to draw a solid curve.
Save the variables dashes and dots used in the macros DASHED and
dotted.
Uncomment three macros commented out in 0.3.13: tightbbox, tbbox and
bbox. Though these are not used in any other macro, but they might
nevertheless be useful to users of grafbase.
Change the dashtype[] arrays that mix dots and dashes so they begin
with a dot. This will produce a dot at the ends of the curve. This just
looks better than a partial dash.
Added unbound.tex updating mfpic info in "TeX Unbound".
Restored mf-revu.tex, somewhat altering its formatting and correcting a
TeX error.
Changed \endconnect so it tests for its use in LaTeX as an
environment and if so issues \aftergroup\@startfigtrue and
\aftergroup\@imrendtrue to bypass the LaTeX-supplied \endgroup.
Added a similar test to \endmfpic to set \@ignoretrue.
REVISION 0.4.0 beta, Aug 2000:
Released to CTAN. Removed mppic.*, package is named mfpic regardless
of whether MF or MP support is needed.
REVISION 0.4.01 beta, Nov/Dec 2000:
Sergei V. Znamenskii reported (and mostly solved) an incompatibility
with AmSTeX using amsppt style if mfpic.tex is input after the
\documentstyle[amsppt] command. The file amstex.tex loads the dummy
font, setting 22 font dimensions. Then amsppt.sty loads some more fonts.
It appears that if font loading intervenes, mfpic.tex cannot add extra
font dimension parameters to dummy to use with \newfdim. Solved by
changing
\font\@dummy=dummy
to
\font\@dummy=dummy scaled 1002
in mfpic.tex
Also corrected code that purported to detect LaTeX when in fact AmSTeX
was in use.
Added documentation of a bug in supp-pdf.tex which requires
\usemetapost (as well as \usepackage[metapost]{mfpic}) to come before
\usepackage[french]{babel} when running pdfLaTeX. The conflict was
reported by Pascal Chantriaux.
Changed \tmtitle and \mftitle so they read the argument as a token
list and write it to .mf file and .log file without expansion. Simple
things like "\'" expand to quite long expressions in LaTeX2e.
Added commands \MFPdebugwrite (to write its argument only in presence
of debug option), \MFPmsg (as a synonym for \immediate\write16) and
\MFPICmsg (to write its argument preceded by "MFpic: ".
Added \restoreCODE to shorten all the lines in \mfpic-package that
restore the category codes of punctuation.
Added a few new debug lines in response to previous failure to detect
\AmSTeX.
Rewrote \mfp@now (which generates a time-stamp for the output file) to
use only 2 \count registers instead of three.
Added \dimendef\mfp@scratch=255 for scratch use instead having
\dimen255 hard coded. This will make changes easier should use of
\dimen255 cause any problem.
Added \penwd as a synonym for \pen (to be more in line with
\shadewd, etc.).
Removed redundant parentheses from default \using.
Changed internal command \mfp@rwdata, which is responsible for reading
and writing in the \datafile and \plotdata commands, so that it
outputs
polyline (false)((x_1,y_1),(x_2,y_2),...,(x_n,y_n));
instead of
(x_1,y_1)--(x_2,y_2)--...--(x_n,y_n);
The intent is to have a better interface if ever we get 3D support
started. For example, polyline calls textpairs which processes the
list of coordinates. In a hypothetical 3D environment, we'd need to
change only \using to write triples, and then textpairs could choose
to run some command that processes triples instead of pairs.
Changed use of \unpreservelines in \plotdata, etc., to the expicit
resetting of the category of ascii 13 (which was its only purpose
anyway).
Added macros \xaxis[<hlen>] and \yaxis[<hlen>] with the obvious
meanings. Plan on adding something like \leftaxis, \bottomaxis, etc.,
with changes to \xmarks and \ymarks for putting tics on them.
(Haven't figured out the best interface yet.)
Added some new error messages. Rewrote almost all error messages, adding
linebreaks. Added command \mfp@errmsg to format error messages and set
the \errhelp tokens.
REVISION 0.4.02 beta, Jan 2001:
Backward comparability was inadvertently destroyed when \curve was
given an optional parameter and the definition of curve in grafbase.m?
was changed. Any .mf file created by using \curve with an older
version of mfpic would give curve the wrong number of parameters for the
new grafbase files. I renamed the new curve to tcurve and gave curve
a definition equivalent to its old one.
REVISION 0.4.03 beta, Feb 2001:
Corrected a typo in vardef thegblabel: had zz for a parameter, but
used z in the replacement text. I am surprised \tlabel _ever_ worked
when the mplabels option was selected.
REVISION 0.4.04 beta, Mar 2001:
Added \smoothdata[<tension>] to cause \datafile and \plotdata to
draw smooth curves with optional tension setting. And \unsmoothdata to
restore the default.
Changed \pointedlines to work as documented (causing \plotdata to
issue the equivalent of \plot{<symbol>}) and added \datapointsonly to
behave as it used to (causing \plotdata to issue the equivalent of
\plotnodes, plotting only the data points).
Some documentation changes: added info that something like
\xmarks{-4 step 2 until 6} is valid.
REVISION 0.4.05 beta, Mar 2001:
Changed vc=vt; to vc:=vt; in function clipsto. When used on an
array of paths, the original caused an "Inconsistent equation" error
on the second iteration. Fortunately, this does not come up in mfpic
except for very advanced users.
REVISION 0.4.10 beta, May 2001:
Renamed \fileversion and \filedate to \mfpfileversion and
\mfpfiledate to avoid name clashes with other packages. Most packages
only use these macros for messages while loading, but mfpic writes the
information as a header comment in the output file
Added \mfp@ifnextchar, a clone of LaTeX's \@ifnextchar, and
redefined the macros \do@ptparam and \alt@ptparam in terms of it.
Copied LaTeX's code to eat one space after a command into the macro
\eatspacedef.
Added \mfp@delim as an all-purpose argument delimiter. For debugging
purposes, its definition is to issue an error message saying it
shouldn't ever be triggered.
Slight rewrite of \mfp@now and \mfp@today.
Renamed \framed and related macros by prefixing mfp or mfp@. Some
formats and packages (ConTeXt, for example) have a \framed macro. Now
\mfpframed _can_ be used, and _must_ be used if \framed already
exists (as in ConTeXt). Replaced \framegap and \framethickness
with \mfpframegap and \mfpframethickness. If \framed is already
defined, the old version is kept and the user may not get the effect
described.
Slight change to what is printed in the .dvi file when a mfpic detects
that Metafont or Metapost has not been run, or the figure is absent.
New dimensions: \tlabel@hadj, \tlabel@vadj and \tlabel@sep for
shifting \tlabel text. The first is a horizontal adjustment, the second
vertical, added to every label. The third shifts the label directly away
from the point of placement (unless optional argument "[Bc]" or
"[cc]" is used). A label is shifted by \tlabel@sep downward when the
`t' parameter is found, upward for `b', rightward for `l' and
leftward for `r'. The first two dimensions can be set with a new macro
\adjustlabels{<hadj>}{<vadj>} (name later changed to \tlabeljustify,
and the third with \tlabelsep{<dimen>}. Need to do it this way because
under mplabels they need to write the information to the output file.
Added \expandafter before \@render\fi in several places. This now
appears not to be needed, but the \fi following \@render caused
problems with some experimental versions of optional argument handling.
Added the following macros for drawing axes along the borders of the
picture:
\leftaxis
\rightaxis
\topaxis
\bottomaxis
\bottomleftaxes
\borderaxes
\leftaxisshift
\rightaxisshift
\topaxisshift
\bottomaxisshift
The first four draw the appropriate axis (no head by default), the last
four set an amount (in graph units) to shift the axis inward.
For tick marks we have:
\lmarks
\rmarks
\tmarks
\bmarks
\lmarksposition
\rmarksposition
\tmarksposition
\bmarksposition
\xmarksposition
\ymarksposition
The first four set the positions (and optionally size) of the tick marks
on the corresponding axis, the next six determine if the marks are
centered, or on one side of the axis. They take an argument which must
be one of inside, outside, centered, ontop, onbottom,
onleft, or onright. For side axes the default is inside, while
for x- and y-axes it is centered.
For arrowheads on the side axis we have \sideaxishead which takes a
dimension argument and sets the length of the arrowhead. To turn heads
off again set the length to 0pt.
Added \gridlines to draw a regular grid of lines. It's syntax is the
same as that of \grid. Changed the behavior of \grid so that instead
of starting at the left and bottom, it draws the grid centered on the
origin of the graph coordinates.
Changed most of the \if-tests so that if an incorrect optional parameter
is used, the default behavior will be seen. For example, \function
takes an optional argument of [s] or [p] with s the default. The
code had been:
\if ##1s true\else false\fi
and I changed it to
\if ##1p false\else true\fi
so for the typographical error \function[o], the user will get the effect
of the default s.
Added the command \labeljustify to change the default justification
of text labels. For example, \labeljustify[cr] makes the default
[cr] instead of [Bl].
When truebbox is in effect, but mfpic detects that Metapost has not
been run, truebbox is turned off for each picture. Before, this was
global, now it is local (so that it doesn't affect a new \opengraphsfile
command, even though mfpic does not officially support more than one
\opengraphsfile commands per file).
Added the command \tlabels (note the plural). It has one mandatory
argument which contains a concatenation of arguments for one or more
\tlabel commands. These arguments may (but need not be) separated by
spaces or new-lines.
Replaced all occurrences of \@labeldim, which had been \let equal to
\mfp@scratch, to the explicit control sequence \mfp@scratch. This was
to avoid confusion that could have been caused by changing one of them,
not realizing they should be the same.
REVISIONs 0.4.11--15 beta, July 2001:
Restored a lost backward comparability: I stored the (Metapost)
primitive meaning of dashed in the command dashed_ and made dashed
synonymous with DASHED. Power users will have to use dashed_ if they
wish to invoke that primitive after loading grafbase.mp
Added \MFPICwarn in addition to \MFPICmsg and \mfp@errmsg. Added
"MFpic error: " to the front of all mfpic generated error messages.
Introduced \on@line (from LaTeX) to place the line number in warnings.
Removed many more spaces and eols from mfpic.tex (lest it be input
with spaces or eols active). Added some spaces between a command and
`!' lest the latter have category 11.
Changed name of \restoreCODE (and others) to \MFPrestorecode (etc.)
after running across a package which defined \restorecode. Introduced
\@xp (from AMSLaTeX) for \expandafter. Removed saving of the current
font as \@torig, since we no longer change to \nullfont.
Added test for equality to \relax in \testdef. Removed \newlet
(later put it back), \sim@def and \sim@gdef as they are not used (any
longer). The latter two were used once each and those were changed.
Changed handling of \if@mfp@metafont and \if@mfp@metapost to ensure
they are kept mutually exclusive. Changed handling of
\@if@mfp@beforefileopen from a simple \if...\else...\fi to saving the
alternatives in a macro and then issuing the macro after the test.
Changed \mfp@clip to make it global if issued before \opengraphsfile.
Redid \mfp@truebbox to ensure it is global, but leave an out so that
\@mfp@truebboxtrue/false could be set locally. Made similar
changes to mplabels.
Removed \unpreservelines from \mfsrc since grouping restores EOLs.
Also made \mfsrc check that a .mf/p file has been opened.
Removed the definition of \mf@bsl since it is not used (any longer).
Delayed the definition of \mfp@data until \@mfpic@graf@macs.
Introduce the hook \mfp@additions, to be expanded last in
\@mfpic@graf@macs.
Changed the name of macro \mfplinestyle to \mfplinetype and the
\count register \mfp@linestyle to \mfp@linetype.
Changed name of \missinggraphfileerror to \nooutputfileerror.
Changed name of \adjustlabels to \tlabeloffset.
Changed name of \labeljustify to \tlabeljustify.
Try to support multiline labels even in the case of mplabels by writing
appropriate definition of `\\' to the .mp.
Changed definition of \mfp@scratch from \dimension255 to a register
defined by \newdimen.
Added ability to create a curve surrounding some text: macro
\textboundary creates a rectangle, with optionally rounded corners,
\textoval creates an ellipse with aspect ratio the same as the block of
text, \textellipse creates an ellipse with a given aspect ratio,
\textcircle is \textellipse with aspect ratio of 1. TeX measures
the text and transmits the information to Metafont.
New macro \axislabels. This takes a letter indicating the axis, an
optional justification parameter (as in \tlabel) and a comma separated
list of TeX text and numbers. The numbers indicating the position on the
given axis to place the text. Since side axes may be offset from the
edge of the graph, the utility \mfp@addto is used to add the boundary
coordinate (one of the parameters of \mfpic) to the appropriate offset,
returning the result in graph units for use in a \tlabel command. The
default justification depends on the axis. It is chosen so that the text
ends up outside the border axes, below the x-axis and left of the
y-axis.
Color additions: added \tlabelcolor and grafbase color variable
tlabelcolor to control color of Metapost placed text; added
\backgroundcolor to set the color variable background, the color used
by \gclear and by all plain Metapost unfill operations. Had to
rewrite the various color setting macros since, till now, all assumed
the color variable name ended with the string "color".
Changed the macros introduced in 0.4.10 or previous that controlled the
position of the side axis. Now instead of saying
\leftaxisshift{<num>}
one says
\axismargin{l}{<num>}.
One can set all 4 margins at once with
\setaxismargins{<num>}{<num>}{<num>}{<num>}.
or all margins to the same number with
\setallaxismargins{<num>}.
A similar change was made to the setting of the axis marks position
(i.e., inside, outside or centered). Instead of
\lmarksposition{inside}
one writes
\setaxismarks{l}{inside}.
One can also set the position of all the border marks at once with
\setbordermarks, or all border marks to the same position with
\setallbordermarks.
Command \drawaxes added: it takes a comma separated list of
letters chosen from x, y, l, b, r and t, and draws the specified
axes. Later renamed to \doaxes, and commas omitted.
Added optional parameter to \plotdata and \datafile which
has the form p or s<num>. "[p]" causes a polygonal curve to be
plotted and "[s<num>]" causes a smooth curve to be drawn, with the
given number as the tension. The number may be omitted, and then
grafbase's value of curvetension (default 1.0) will be used. Any
other letter or none is the same as [p]. Internally, the optional
parameter is passed to \mfp@rwdata, which now, of course, takes
parameters. Along with this, \smoothdata was revamped to simply
change the default optional parameter, rather than set a switch.
When option metapost is selected, each mfpic environment writes the
current font to the output file (in verbtimtex) to have at least the
chance (under mplabels) to match the fonts that TeX would use in
tlabels.
Framing code: in addition to \framed or \mfpframed, we now have a
LaTeX environment: \begin{mfpframe}...\end{mfpframe} or, in plain TeX,
a command group \mfpframe...\endmfpframe. This is actually recommended
(over the first form) if the user wishes to frame an mfpic environment.
This ensures that category codes are not prematurely set by reading the
whole picture as an argument.
Changes to grafbase:
Moved interim warningcheck:=0; after mode_setup because mode_setup
sets it to 1. Now that warningcheck is correctly set, we can change
the test of parameters in secd, etc., from comparing with nottoosmall,
to comparing with reallysmall.
Streamlined minpair and maxpair.
Define transform vtr on its own in setztr rather than only the macro
vconv being defined (in terms of ztr). Define ztr in terms of vtr
(the "right way to do things", said the linear algebra teacher).
Remove definition of invztr and use inverse ztr the few times necessary.
Remove the "complicated zconv" entirely.
Added plain Metapost's image command to grafbase.mf.
Changed the command executed when clipall is true to clipto instead
of clipsto.
Added textboundary, textoval and textellipse to put paths around
text. Only the size and center point of the text is passed by mfpic, not
the actual text. These implement the mfpic commands \textboundary, etc.
Added parameters pair label_adjust and numeric label_sep.
These are used in grafbase.mp for shifting labels. They are also
used there and in grafbase.mf for positioning and sizing textboundary,
textoval and textellipse.
Added test for ClipOn to dashing code, plotsymbol and plotnodes.
arrowdraw now checks for hlen > 0 before drawing head.
Complete rewrite of axes code and drawing of hash marks on axes. Four
new axes added leftaxis, etc.
Changed code for grid so it is fitted to the coordinates: integer
multiples of xspace and yspace are plotted. Added gridlines.
Changed arcppp in grafbase for more robustness (I hope) and better
result on small values of sweep.
REVISION 0.4.16 beta, July 28--30 2001:
-- Changed name of \textboundary to \tlabelboundary and then
\tlabelrect.
-- Changed name of \textoval to \tlabeloval.
-- Changed name of \textellipse to \tlabelellipse.
-- Added "star form" of each that defines the curve without placing the
label.
-- Renamed grafbase command textboundary to textrect.
Replaced the four commands \leftaxis, etc., with single
command
\axis[<hlen>]{<one-axis>}
(example \axis{l}) and \borderaxes, etc., with
\doaxes[<hlen>]{<axis-list>}
(example \doaxes{lbrt} for the 4 borders).
Recoded \mfp@now so that only 1 count register is used.
REVISION 0.4.17 beta, July 28--Aug 10, 2001:
Changed grafbase.mp commands textrect, etc., so the first two
parameters (dimensions of some unspecified text) became one parameter,
which could be either of type pair (the two dimensions), string, or
picture (e.g., a btex...etex expression). In the latter two cases,
Metapost measures it and uses those dimensions to make a rectangle, etc.
Gave all commands that take a [s] smoothness specification the
option to make it [s<tension>] to draw the curve more tightly.
Commands affected: \function, \parafcn, \plrfcn, \btwnfcn and
\plrregion. This necessitated changes in grafbase code to mkfcn so
that it accepts a tension parameter. Plus changes to all the macros that
call it: parafcn, xfcn, function, rfcn, and plrfcn. Those that
are used by mfpic, like function, were altered as follows. The name was
changed to tfunction, it was given a tension parameter and the call to
mkfcn passes that parameter. A new macro named function simply calls
tfunction with default tension. This was to make the new grafbase
accept old files generated by mfpic. Those macros not used by mfpic
(rfcn and xfcn) simply call mkfcn with tension equal to 1.
Redid doplot, plotsymbol, and plotnodes so that the plotting symbol
can be a picture as well as a path. If a path, it is scaled by the scale
parameter. A picture is not scaled, since this is essentially not
possible in Metafont and since it is expected that in Metapost it will
be a btex...etex expression and the size is determined by the font.
Because this is expected to be the typical case, the picture is shifted
so that its center at the chosen position (instead of the left
baseline). This is not done in Metafont since finding the center of a
picture is non-trivial. In grafbase.mp the first parameter is also
allowed to be a string, and is then converted to a picture with the
infont operator. In all other cases it reverts to a default dot scaled
by the second parameter.
Changed the \mfpic command so both optional parameters may be omitted
(scale 1 is then assumed). Also, the first parameter is no longer saved
in \@param. That was not a serious problem, but I did experience a
hard-to-debug problem from using the same temporary name in another
command. (It seems that \@param is not expanded until \@xconv and
\@yconv are used in tlabels, and I included a redefinition of \@param
in a command that calls \tlabel).
Added EOL, `*', `"' and `$' to the list of symbols whose catcodes
are saved, changed while reading mfpic.tex, and restored at the end.
`$' is put in category 12 and used then in several \if tests for empty
arguments (previously `!' was used, then `@'. (Changed again a couple
of times!)
REVISION 0.4.18 beta, Aug 10--20, 2001:
Added point size option to \grid.
Added a macro \plottext similar to \plotsymbol except instead of a
symbol, it takes a bit of TeX text. The macro runs entirely in TeX,
issuing a sequence of \tlabel commands.
Changed grid and gridlines so the lines and points are fitted to the
pixel grid. We now use safedraw on
hroundpair(zconv(p1))--hroundpair(zconv(point)) instead of on
zconv((p1)--(p2)). When grid and gridlines are used with the same
parameters, this seems to make the picture periodic.
Added \plrgrid and \plrpatch.
Added \piechart and \piewdge.
Removed \d@adv, \i@mul, \i@div, \q@mul as it turns out they are
either no longer used or unnecessary: \i@mul and \i@div, were only
used in \q@mul and it isn't needed as \x= 1.2\x works for fdims.
\d@adv seems to have disappeared from use.
REVISION 0.4.19 beta, Aug 20--26, 2001:
Added \mfpicnumber to set the number of the next character or figure.
Removed explicit references to gcode, instead of writing
beginmfpic(incr gcode), \mfpic now writes
beginmfpic(\number\mfp@count). This way TeX's understanding of the
current figure number and Metafont's understanding are guaranteed to be
the same. The opening code of beginmfpic sets gcode in case any existing
files make use of it. This simplifies maintenance, and such things as
\noship and \mfpicnumber.
Speaking of which, added code to \noship to set a switch so
\endmfpic could skip placing an empty box. I hope this makes an
mfpic environment a typesetting no-op. The only worry is that an
invisible character or box might creep into the output. (It hasn't yet,
that I've noticed, but checking would require testing virtually every
macro we've defined that can be used in an mfpic.)
REVISION 0.4.20 beta, Aug 26--Sep 1, 2001:
Added \barchart (it was easy after \piechart) after seeing comments
on gnuplot list that deprecated pie charts as a means of conveying
quantitative information. The rectangles become available as
\chartbar{<n>}. Where <n> is the number of the bar.
Changed the code (again!) for shade in grafbase.mf. I was certain
there had to be a faster way. The key turned out to be not to do a
double loop. Instead, draw the bottom row of pixels in one loop, and
then copy that row in a separate loop. The original looped O(nm) times
if n and m are the dimensions of the rectangle. The new one loops,
O(n+m) times. A slight extra bit of efficiency in coding is obtained
by finding the smallest repeating pattern and repeating that (avoids
shifting every other row). This turned out to be two dots at a 45 degree
angle placed \shadespace apart. Then copy _that_ picture.
I was worried that this algorithm had to copy a much larger picture the
second loop, but it seemed to make little difference. The bottleneck
seems to be the loop overhead. There was a seven-fold speed increase in
shading a 100pt by 100pt rectangle with a \shadespace of 1.2pt
(this is about the most dots MiKTeX's Metafont could handle). I came up
with another algorithm that is O(m/n + \log n), when n < m. But it
was only marginally better at the sizes Metafont could handle. Plus it
traded memory for speed. It built a shading rectangle of size at least
n/8 in O(\log n) iterations and then tiled with O(m/n) of them.
This could require up to an additional 12.5% more memory, as the last
row or column could overshoot by up to n/8.
Changed timing so that \mfp@count is initialized to 1, and
incremented only in \endmfpic (where it is in the code skipped if
\noship is used).
Changed \newdef to \def for \arrow so eplain won't generate a
complaint.
REVISION 0.4.21 beta, Sept 1--10, 2001:
Got tired of typing "\macro" so I changed it to \mac. Also got
tired of "\vskip\myskip", etc., so I wrote \bcd and \ecd to
bracket the headers of command descriptions. For examples, I wrote
\bex and \eex. Changed the font for \prog to small caps and for
\opt to sans serif. Added \null to the end of the definition of \TeX
for \spacefactor reasons (saw this somewhere).
Wrote a \myverbatim macro for mfpicdoc.tex since header.tex's
verbatim wouldn't work for me. Completely rewrote \head and \subhead
for better spacing and page breaks. (One of these days I will give them
numbers and perhaps translate everything to either LaTeX or eplain to
provide cross references.)
Added SolidStar to symbols allowed by \plot, etc. Changed grafbase
code so that Star produces an open five-pointed star instead of the
asterisk previously drawn. Added Asterisk in case anyone prefers the
old way.
Separated the part of \mfp@rwdata that writes the rendering code from
the part that writes the data. This is for later enhancements. The
wrapper that writes the rendering code is called \do@datafile. Took
out of \mfp@rwdata the code that wraps the point in (redundant)
parentheses. Now the parentheses _must_ be added by \using.
Changed the name of \mfpic-package to MFPicpackagE, (part of
the paranoia that catcodes of punctuation might be changed).
Added code to several commands to test for empty optional arguments. The
reason: when an optional argument has two parts, as in \plotdata[s1.2]
the code splits it up as [#1#2] so that s is assigned to
#1 and 1.2 is assigned to #2. If 1.2 is omitted, then #2 is
empty, but if both parts are accidentally omitted, then the closing
bracket is assigned to #1 and TeX searches for another right
bracket. This can cause extremely unhelpful error messages from internal
commands generated much later. Now, a command like \plotdata[] is
treated as if there were no optional argument: default values are used.
The user can deduce from incorrect output where an error occurred.
Did the above for \tlabel, but only for the second part of the
optional parameter (laziness).
Added commands similar to \rotatepath: \shiftpath{p}, \scalepath{p,sc},
\xscalepath{x,sc}, \yscalepath{y,sc} and \slantpath{y,sl}. "p" is a
point "sc" is a scale factor, "x" is an x-coordinate, "y" is a
y-coordinate and "sl" is a slant factor. These commands accept a
following path and pass back the corresponding transformed path (to
preceding prefix macros).
Released to alpha testers.
REVISION 0.4.22 beta, Sept 11--22, 2001:
Added \reflectpath{p1,p2}, \xyswappath and \yslantpath{x,sl}. Added
also \xslantpath as a synonym for \slantpath.
Removed grouping in \mftitle that inadvertently caused \tmtitle's
argument to be omitted from the .log file. Rewrote both to call a
third macro. The third macro loads the argument in a token list and
writes to the .mf file. \mftitle supplies the grouping to preserve
the token variable. \tmtitle also adds the grouping, plus writes to
the .log and to the document.
Redid \tlabel so that it checks for completely empty optional
parameter.
Also avoid duplicating every \@...tlabel command. Only ever did that
to avoid the message about rotation being ignored in the \nomplabels
case. Somewhere along the way handling of default optional parameters
made that moot.
Now \tlabel begins a group, then sets \tlabel@rot to empty (not
zero!) if mplabels is not in effect, then passes
"[\tlabel@vpos\tlabel@hpos\tlabel@rot]" as the optional parameter. The
two different commands \@tlabel and \@@tlabel ultimately end the
group. This necessitated changing a number of commands that call for
tlabels: I thought it more efficient to say
\if@mfp@mplabels\expandafter\@tlabels\else\@@tlabels\fi...
than to call \tlabel directly. But now that would unbalance the
grouping.
Somehow I overwrote the version of mfpic.tex in which I made the above
three paragraphs of changes with the previous version. So I did it all
again, but now it does the following. \tlabel starts a group and calls
two different commands: if no "[]" follows, it defines \tlabel@rot
to be empty under \nomplabels; and if "[]" follows, it calls
\tlabeljustify. Finally it calls either \@@tlabel or \@tlabel,
depending on mplabels, feeding the arguments \tlabel@vpos,
\tlabel@hpos and \tlabel@rot. This ensures that insufficient optional
parameters produce default results, as \tlabeljustify does default
things with empty parameters.
In grafbase: push vtr in bcoords command and pop it in ecoords.
Added vtr:=ztr shifted -zconv((0,0)); to apply_t. It seems coords
and apply_t were broken ever since I defined vconv in terms of vtr
instead of zconv.
Added \@firstoftwo and \@secondoftwo and rewrote several commands to
use them, including \@if@mfp@beforefileopen..
REVISION 0.5.0 beta, Sept 24--Oct25, 2001:
Change comment written at the top of the output file. Now includes the
name of the output file, as well as the \jobname of the TeX source
that produced it.
Changed how \grid handles optional point size. Now it writes a command
vgrid that takes the extra parameter (and the old grid just calls
vgrid with default parameter).
Made \mfpic and \endmfpic write the source line number to the
output for debugging use.
Added token list \every@tlabel and a command \everytlabel for
setting it (and writing the settings to the .mp file when mplabels
is in effect.) In order to make this local to mfpic
environments, now \mfpic writes "verbatimtex \begingroup etex" to
output and \endmfpic ends the group (under mplabels).
Renamed \if@graphfileexists to \ifmfpicFirstTime which
required reversing the sense of all \if... tests. This will allow the
user to override the behavior of mfpic in unusual circumstances.
Restored the command that expands to a backslash with category 12, for
writing the outer token \newtoks to the output file.
Because \mfsrc ends with \ignorespaces (should it?) commands
can generate a space under metafont but not under metapost with
mplabels (because they write TeX code to the output). I have therefore
started to look out for such differences and am adding \ignorespaces
when I notice them.
Released to CTAN, Oct ??, 2001.
REVISION 0.5.01 beta
This modification actually occurred in February 2002, but I made it on
version 0.5.0, correcting a small bug by adding some braces around the
point arguments of \tlabel in a couple of places. The problem was that
Metapost code in the point argument could contain parentheses or commas,
and these had to be hidden inside braces. The code of \tlabels and
other commands would read this argument twice so two levels of braces
were needed, but that would cause errors in other contexts. The internal
braces in the right places meant the user need only use one. All of this
was only a problem with mplabels.
REVISION 0.5.02 alpha, Oct 26--Nov 8, 2001:
Put most of the catcode changes (in the "paranoia" section of
mfpic.tex) in a command \mfp@sanitize for possible reuse.
In preparation for a planned enhancement, I have divided \@figmac into
three parts: the set-up, write, and post-write phases. The idea is that,
e.g., \@curve[1.2] will do the setup, and write the code
tcurve(1.2, false) but not the points or the ending semicolon, then
close with the all-purpose macro \@figmacdata. This macro will scoop up
the last parameter (listing the points), write them to output, adding
the semicolon, and then issue the post-write code. Why? Ultimately I
would like to be able to present the data in more than one form.
\@figmacdata would detect the form and do the appropriate thing. In
particular I would like to be able to do something like
\curve[1.2]\datafile{file.dat} to draw a curve connecting the points
listed in file.dat.
Have actually changed the definition of \curve and \cyclic to use
this scheme, although \@figmacdata just writes the inline data points
to output. Shouldn't be unusually hard to make it open the file handle
and call \mfp@rwdata. I will first try to organize the opening,
reading, writing and closing of files into reusable modules.
REVISION 0.5.03 alpha, Nov 8, 2001--???:
Further modified \@figmacdata: Split it in two. First, \mfp@writelist
writes the list, enclosed in parentheses and followed by a semicolon,
then issue \@figmacend. This is because lists are also used by
"non-figmacs", like \xmarks and \point. For these I just use
\mfp@writelist. Perhaps it wouldn't hurt to include \@figmacend on
those, but I wasn't prepared to chance it. Also put the common
combination \@figmacstart\mfsrc{#1}\@figmacdata in a new macro
\@listmac.
Now all those macros that take a list as last argument (thank goodness
it always _is_ the last argument) follow the scheme. This includes
\xmarks, \ymarks, \lmarks, \bmarks, \rmarks, \tmarks, \point,
\plotsymbol, \piechart, \barchart, \polyline, \polygon, \fcncurve,
\curve, \cyclic, \qspline, \closedqspline, \cspline,
\closedcspline, and \turtle. Ultimately, I may make \@figmacdata
write data from a file (if the next token is \datafile) or data listed
inline as if in a file (if the next token is \inline).
I rewrote the code in \@mfpic that loads the figure into \@wholegraph
so that when \ifmfpicdraft is true then it is skipped completely and
\@wholegraph is just set to an empty box. Then, at the end of \@mfpic,
if \ifmfpicdraft is true, the figure number in \tt is set as a
\tlabel (so the size of the figure will automatically adjust to
accommodate it).
Oops! Had to change the above behavior: \tlabel doesn't expand its
contents when writing to the .mp file in mplabels. So it is
impossible to get \mfp@count (the picture number) written as a number.
Rather than have to write the definition of \mfp@count to the output
file, I changed the code that loads the figure into \@wholegraph to put
the figure number into the box as straight text. Now, the figure number
may again overwrite the boundaries of the box, but that's OK, I guess,
since it's just a temporary situation.
REVISION 0.5.04 alpha, ???--April 11, 2002:
Added \@XP which expands to three \expandafters.
Changed what the truebbox option writes to the .mf file. The scope
in Metafont should now more closely match the scope in TeX.
Added options draft, final, and nowrite (as well as command
versions \mfpicdraft, \mfpicfinal, and \mfpicnowrite) which should
avoid including the pictures (draft) or include the pictures (final),
overriding automatic decisions. Option nowrite avoids writing anything
to the .mf file.
Made several assignments, such as \mfp@count, \@graphfont, etc.,
global, in case the command \opengraphsfile is issued inside a group.
Rewrote \tlabel and friends so that the point arguments could
optionally be enclosed in braces. This was done by checking for a left
parenthesis with \mfp@ifnextchar and branching on that. This allowed
me to change the gblabel command to accept a list of points, and now
\tlabel can, under mplabels accept a list of points in braces.
Completely reorganized the data file reading macros (much smaller and
free of \loop...\repeat constructs). Also added the previously
mentioned capability to replace any list after a macro such as
\curve{...} with the construct such as \curve\datafile{<file>} to
construct the list from the data in file
Changed explicit value of 5 data points per line to the value of
\mfpdataperline when plotting data files.
Added error messages \nodatafileerror and \emptydatafileerror.
Added command resizedrawpen to grafbase to unclutter the
output file.
Collected the common code in \xmarks, \ymarks, etc., so that now they
are implemented with \marks x, etc.
Added aliases \lattice and \gridpoints for \grid.
Changed the option handling in \tlabel so that it is translated into
integer values and \ifcase can be used, making for simpler conditional
code. Added \mfp@justifyerror to the \tlabeljustify command, to
occur if an invalid letter is used.
Added \extra@tlabel command at the end of \@tlabel and \@@tlabel.
Redefining this makes it easier to write macros looping through many
\tlabel commands.
REVISION 0.5.05 alpha, April 16, 2002:
Corrected bug in \mfpverbtex which caused # symbols to be doubled in
the output: simply change catcode of # before reading the verbatimtex
material into the token list.
Remove \DeclareGraphicsRule commands issued in mfpic.tex so
as not to interfere with the graphics package error checking. Instead
the equivalent is done inside a group for each picture with
\@namedef{Gin@rule@.\mfp@count}.
Added a command index to \mfpicdoc.tex. The distribution now includes
a recent version of eplain.tex for the indexing macros and the actual
index mfpicdoc.ind. The makeindex style file that was used,
mfpic.ist, is also included.
REVISION 0.5.06 alpha, April 16--May 7, 2002:
After installing new MiKTeX and forgetting to set localfont, I found
that textrect, textoval and textellipse (in grafbase.mf) fail due
to arithmetic overflow. This is because rather simple text can be (say)
40pt by 40pt. Since that is 400 by 400 pixels (under mode:=ljfour),
and we have to compute numbers on the order of their product, we exceed
the 32K limit on numbers. Changed these commands to do computations in
graph coordinates. That is at least resolution independent. Also change
some formulas involving sqrt to instead use ++ or abs to minimize
such problems.
Updated most docs. Changed mfpic.ist so it will write an mfpic package
comment to the top of mfpicdoc.ind.
REVISION 0.5.07 alpha, May 7--June 25, 2002:
Added \usingpairdefault to reset the \using specification to the
default. Also \usingnumericdefault for commands that take a numeric
list (equivalent to \using{#1 #2}{#1} ).
Documented \marks<axis> commands.
REVISION 0.5g alpha, June 26--July 31, 2002:
Changed version numbering scheme so LaTeX file utilities like the
snapshot package are better served.
Change the graphic inclusion to use \@setmfpicgraphic which, in
addition to executing \setmfpicgraphic, also runs any additional
commands that may be needed and should be transparent to the user. These
include the above setting of the graphics inclusion rule, and now also a
scheme for recovering the bounding box (for future feature allowing
truebbox without mplabels). The graphics package makes this hard by
not saving it globally except in \@gtempa, which hardly seems safe to
rely on. Nevertheless that is what I use now, though it doesn't get used
yet.
Changed \DeclareOption* to print a warning or a message (depending on
whether graphics was already loaded or not) instead of just passing
the option on to graphics package).
The default verbatimtex stuff that was written to the out file in
\opengraphsfile is now stored in a token register
\mfp@commonverbatimtex and then written.
\opengraphsfile now checks for the existence of a file with the
extension of the current value of \mfp@count (default 1) in case the
user changes its value (with \mfpicnumber) before that command.
mfpic.tex now sets it to 1 rather than rely on \opengraphsfile to do
so.
Changed \tlabel to place its contents in a simple left aligned
\halign. This makes it possible to right-align or center multi-line
labels with an \hfill or \hfil on left.
Corrected bugs in file read/write (\plotdata, etc.): Moved whitespace
resetting to \@processdatafile, and changed one \def in
\mfp@rwdataloop to \edef.
Moved the LaTeX2e graphics rule stuff to \mfpic, \usemetapost now just
saves the graphics rule signature ("eps" or "mps") for use in that
stuff.
Remove eplain.tex, substituting indexing.tex which contains only(?)
macros necessary to process the one indexing command actually used in
mfpicdoc.tex, and the two-column printing of the index.
REVISION 0.5h alpha, Aug 1--6, 2002:
Added code to \@setmfpicgraphic to retain the lower left corner of the
picture under metapost. I did this by redefining \Gin@def@bp to make
its definitions (of \Gin@llx, etc.) global. Then added that info to
\@xconv and \@yconv. This allows truebbox to work without mplabels.
Added code to graphbase.mp that keeps track of maximum bounding box of
all the text labels and to adjust the figure's bounding box if that
extends past the boundary of the mfpic environment. This allows labels
to expand the size of the graph (as documented) in the remaining case:
with mplabels but without truebbox.
This requires that any user who redefines \setmfpicgraphic must also
redefine a command \getmfpicoffset that stores the coordinates of the
lower left corner in the macros \mfpicllx and \mfpiclly.
Reverted to the previous \tlabel method of producing multiline
labels. The \halign method (specifically the \let\\=\cr) produces
an error when either of the packages latexsym or amsfonts is used. So it
is not (yet) possible to right align or center multiline labels.
Reverted back when I discovered that \def\\{\cr} did _not_ conflict
and seems to work just as well. It is again possible to right align and
center multiline labels.
Added \gclip rendering macro (did no one ever miss this?), that clips
the current picture to the interior of the following path. And added an
example to *objs.tex.
REVISION 0.5i alpha, Aug 7--12, 2002:
Rearranged the endmfpic code of grafbase.mp so that truebbox, clip
and mplabels interact properly, meaning that text which is clipped off
_doesn't_ expand the bounding box.
Announced to mfpic mailing list. Maybe this will become version 0.6 beta.
(Ha!)
REVISION 0.5j alpha, Aug 12--15, 2002:
Changed name of \marks command (introduced in 0.5.04) to \axismarks
to avoid name clash with \eTeX primitive command (reported by Guy
Worthington).
REVISION 0.5k alpha, Aug 15--26, 2002:
Rearrangement of \begingroup-s at some point caused a problem with
\datafile commands: the \@figmacend was issued inside a group.
(reported by Jaromir Kuben).
I moved the location of \@figmacstart and \@figmacend and that
solved it but caused a problem with \plotdata, which reused that code.
Solved by putting an appropriate \@figmacend in the \plotdata code.
REVISION 0.5l alpha, Aug 26--29, 2002:
Changed the code that saves the lower left corner of the picture under
metapost. Instead of making \Gin@llx, etc., global, I redefine
\Gread@parse@bb to store them globally in our own macros. This
redefinition happens only in the \mfpic environment (in fact only
inside the box where the graphic is included).
I settled on this as having almost no side effects. Perhaps there is a
reason the \Gin@* commands are local even though no one on
comp.text.tex came up with one.
Also, since now the only \begingroup/\endgroup pair in the
file read/write code is in one place: the \@processdatafile command, I
deleted all the \global in front of \read commands.
REVISION 0.5m alpha, Aug 29--30, 2002:
Updates to *.txt, readme.1st, and documentation.
Changed \mfp@ifnextchar so that when looking for the next token, it
will skip over \relax. This means one can put the optional argument on
another line even when \preservelines is in effect (at which time the
line end character is active and has been \let equal to \relax)
Change \@figmaclist and \@mfp@writelist so they preserve lines.
Since all commands that write lists of data to the output file
ultimately run one of these, all those commands preserve lines. Then I
removed \preservelines from \mfpic. Now we no longer need the
caution about putting a macro and its arguments on the same line.
REVISION 0.5n alpha, Aug 30--Sep 04, 2002:
Allow \tlabelsep and \tlabeloffset to have any <dimen> argument. I
was so stupid: it was just a matter of setting the TeX dimensions first
and then writing their values to the output.
Documented \mfpdataperline. Also changed it to a macro rather than a
\count because LaTeX users are unfamiliar with count registers
(\newcounter, yes, \newcount, no). I could have called it
\c@mfpdataperline, but then it wouldn't be user-level for plain TeX.
Changed "\ifnum\mfp@n=\mfpdataperline" to
"\ifnum\mfp@n<\mfpdataperline" and exchanged the true and false clauses.
Just in case some user sets \mfpdataperline to some number which is not a
positive integer.
Added \space to "\mfsrc{verbatimtex\endgroup\space etex}", just in
case TeX could enter a state where it doesn't append a space when it
writes the \endgroup.
REVISION 0.5o alpha, Sep 04--06, 2002:
Corrected LTXMFobj.tex and LTXMPobj.tex. After testing various
combinations of mplabels and truebbox, I'd incorrectly added these
options to the former file and failed to restore them to the latter.
REVISION 0.5p alpha, Sep 06--09, 2002:
Added commands \setpapersize and \setpagegeometry to header.tex.
Now the preamble of almost every .tex file in the docs directory is
reduced to using these two commands.
Deleted old verbatim macros which were no longer used.
Removed save piecenter; from grafbase. This variable was documented to
be set by the piechart command, but saving it made it unavailable.
Corrected the example concerning \datafile with \xmarks: the
parameters of \using needed a space between them.
REVISION 0.5q alpha, Sep 09--12, 2002:
Multiple documentation refinements.
Removed \if@mfp@metafont, using only the switch \if@mfp@metapost.
Added \mfp@ifdefined: it checks if a token is neither \undefined nor
\relax. Used in macros to detect format. Moved definition of
\@firstoftwo and \@secondoftwo before it.
Made some definitions in \usemetapost global, in case it is
mistakenly issued inside a group.
Removed \@eatspacedef since it was used only once to define something,
and it was shorter to define it directly.
Changed all \ifx in \@@arrowoption to \if in case someone wants to
pass the the letter as a macro
In axis code, changed `\x to simply `x lest \x have some
definition and some TeX state causes it to be expanded.
Gave \newsavepic a definition closer to \newsavebox, which uses
\@ifundefined rather than strictly testing against \undefined.
REVISION 0.6 beta, Sep 12, 2002:
Uploaded to CTAN.
REVISION 0.6a alpha, Sep 12--Nov 5, 2002.
Added \let\par\relax in the definition of \@mfpic to
nullify blank lines in user code. Needed since I stopped using
\preservelines. (Reported by Jaromir Kuben.) Put in commands to
restore \par to its normal meaning in labels and captions.
REVISION 0.6b beta, Nov 6--, 2002.
Incorrect sign on sinh function in grafbase.
REVISION 0.6c beta, Nov 6--, 2002.
Bounding box had the horizontal and vertical data reversed if all
of the following three options were selected: metapost, mplabels and
clip.
REVISION 0.63 alpha
Mfpic:
Added code to write into the graphs file a test of the major version
number (to assure that the files mfpic.tex and graphbase.mf/p are
comparable).
Added a switch \in@mfpicenv that is true inside an mfpic environment and
false outside. This allows macros to make global changes outside and
local changes inside, helping TeX and Metafont stay in sync. Modified
some commands to use it (clip and truebbox options, so far). Added
\mfp@local which expands to nothing inside and mfpic environment and
to \global outside.
Changed \@dummy to \mfp@dummy (mfpic.tex) lest its name clash with
other packages.
Added a \partialpath{a,b} command. It's argument is two fractions
separated by a comma and produces the subpath of the following path f
that goes from a*length(f) to b*length(f). (Hmmm...so
\partialpath{1,0} would inefficiently reverse a path!)
Also added \subpath{a,b} to give the equivalent of the MF code
subpath (a, b) of <following path>
Added command \closed[<tension>]{<method>} where <method> is l, b,
s, cb, or u so that, for example, \closed[2]{s} does the same as
\sclosed, except that added or modified links will have tension equal
to 2. Then I defined the previous commands in terms of this one (tension is
ignored for \lclosed and \cbclosed since they specify exactly what the
link should be.) Default for <tension> is 1.
Moved \fdef to a global location and added "save #1;" to its
definition. Functions defined with it should now be local if it is used
in an mfpic environment and global otherwise.
Redefine \+ for entire mfpic.tex. Avoids somewhat complicated
work-around of its outerness in \usemetapost. Restore previous meaning
at end of file.
Added \@bsphack and \@esphack (as in LaTeX).
Rewrote \tlabelrect, etc., so that they take a second optional
parameter: the label justification. Made the current \tlabel defaults
the default for \tlabel<path> also. Might change this to [cc] after
talking to Jaromir.
Changed \store to be usable as a prefix command. It still takes a
second argument but doesn't wrap anything around it, so
\store{m}\circle{...} is as valid as \store{m}{\circle{...}}. But now
\xscalepath{0,2}\store{m}\circle{...}
is also valid, storing the untransformed circle. It is written as a
\@rendmac so that it turns off automatic path rendering. It invokes a
new grafbase command stored , which stores the path and passes it on
(as the other prefix macros do). This may have restored the old behavior
(prior to 0.2.9.10 alpha), but I can't tell, since I never had any
experience using those versions and don't know why the change was made.
Streamlined \arrow so that instead of a chain of 4 macros (that all
did the same thing!), each calling the next, it loops until no more
optional arguments are found.
Renamed \mfpicdebugwrite to \mfpDBwrite to streamline the source
file. Later renamed to \mfp@DBlog to remind me that it only writes to
the .log .
Change \getmfpicoffset and \preparemfpicgraphic so they take an
argument: the name of the figure file. The default versions do nothing
with it. Changed \@setmfpicgraphic so it calls them with the name of
file. In case a power user needed the file name in his redefinition.
Shortened \usemetapost. Defined as much as possible outside it, and
include only what needs to be changed. E.g., we no longer redefine
\@setmfpicgraphic inside it (nor \preparemfpicgraphic in the
non-LaTeX version).
Rearranged code so that \usemetapost is defined in three ways instead
of two: LaTeX2e, plain pdfTeX and plain TeX. Formerly the second two
were combined in one which contained an \ifpdf-\else-\fi construct. That
is now moved to an outer level. Shortened the name of \if@mfp@pdftex to
\if@mfp@pdf since pdftex could be used to produce dvi output, and we
want this to be true only when pdf is being produced.
Added \mfcmd (adds semicolon to argument) and \mflist (wraps argument
in parentheses). Done so that we can delay reading the argument and
therefore preserve lines. Both of these and \mfsrc now call \@mfwrite
with an appropriate argument. It initiates \preservelines and
continues with \@mfcmd, \@mflist, or \@mfsrc. These read the
argument and end with \@mfsrc, which ends line preserving.
Rearranged code of \@figmac. It now issues \@startfigtrue before
writing its argument and doesn't do \@imrendtrue. This allows it to
end with the code to read the argument, and avoids some cases of having
to read large arguments before \preservelines is issued. There was
only one case where the timing mattered: \connect, and there we needed
the current order!
Simplified the scheme for list macros (\mfp@writedata). The above
rearrangement meant there was no longer any need for different treatment
of figmacs and non-figmacs.
Grafbase:
Added code to grafbase file to test if the major version of mfpic
(assuming it is input by an mfpic generated file) and that of
grafbase.mf/p are comparable. Added a boolean MFPIC that is true if
the test succeeds. Not used yet.
Rewrote most of the arc commands in grafbase, focusing on trying to make
any points that were explicitly specified into actual nodes of the path
(i.e., use nothing that could result in round-off error) plus trying to
increase robustness.
"Corrected" cbclosed command in grafbase. Its code used to put in one
cubic B-spline link and connect that to the beginning and end of the
path f with two ordinary MF Bezier path joins. Now it connects with
three cubic B-spline links, the middle one being the same as before.
removed w, d, and h as internal variables because of another user
name clash, this time with \fdef(h)... .
Rewrote grafbase messages and error messages for consistency and
pithiness.
Changed gblabel to newlabel, but gblabel remains as an interface for old
files, calling newlabel. There are now three parameters rather than four
for horizontal and vertical adjustment. The first gives the fraction
of the text left of the point of placement. The third is a
boolean. If false, the second parameter is taken as the absolute
fraction of the text below this point. If true, it represents the same
except the depth of the text is ignored. This (.5,0,true) gives [Bc]
placement, while (.5,0,false) gives [bc].
Added textrectx, textellipsex and textovalx which now allow horizontal
and vertical adjustment and rotation, just like gblabel. The original
commands just call it with the old default (centered, not rotated).
Rewrote nearly all error messages in grafbase.mf/p. Changed "GUBED" to
"END DEBUG". (That has always bothered me.)
Reintroduced "bounds" to the mfpic file. It seemed a reasonable
shorthand, replacing four lines of code with one. And has been around
forever.
Reexamined clipping, trying to make sure that when ClipOn is true,
nothing is written outside the clipping paths. Except there are things
drawn for debugging purposes, so I added noclip() which executes its
contents in a group where ClipOn is set to false. Added DoClip(v) as a
shorthand for:
if ClipOn and (ClipPath > 0) : clipsto (v, ClipPath); fi
Correspondingly changed several commands to write to a temporary picture
variable, which is then DoClip-ed before adding to active_plane. This
turned out to be a prescient act for the purpose of using color in MF
(see below).
Changed P1 in headpath (giving the direction of the arrowhead)
from "direction n of g" to "point n of g - precontrol n of g".
This gives the arrowhead from \arrow\rect{...} a reasonable direction
without having to rotate it +/- 45 degrees.
Determined that the filling commands shade , polkadot and tess (all
these are my doing) did not respect aspect_ratio. Changed all of
them to invoke a macro, filledwith, that returns a rectangular picture
tiled with shifted copies of a given picture. This macro respects
aspect_ratio (i.e, invokes .t_ where it should -- I hope).
Introduced color to Metafont (gray levels only): made color synonymous
with numeric; assigned numeric gray levels to the variables red,
green, etc. Defined the color commands (rgb, RGB, cmyk, gray and
named) to produce appropriate gray levels. Added macro makegray for
this purpose. Allow black or white in drawing commands and gray
levels in filling commands. Gray fill is implemented by a new macro
shaded which is similar in some ways to the internal code of shade and
may one day replace it. Right now shade uses round dots and respects
shadewd and the spacing parameter. But shaded just builds a square
picture which is either two black almost-squares in a white background
(gray levels > .5) or two white almost-squares in a black background.
Works well in simple tests so far.
Changed the code executed if mode is unknown back to switching on a
default mode, but this time ljfour instead of cx.
Removed the aspect_ratio scaling from resizedrawpen, and also from
the definition of drawpen and hatchpen. Added that scaling to
shpath.
Added partialpath and gsubpath to support mfpic's \partialpath
and \subpath .
Docs:
Changed this file (changes.tex) from a .tex file to a .txt file for
simplicity of maintenance.
Transcribed mfpicdoc.tex to a LaTeX file adding mfpdoc.sty to preserve
most of the previous formatting. Adds a table of contents; allows an index
without the extra files indexing.tex and mfpic.ist (both now removed).
Added hyperref, producing a linked .pdf file if pdflatex is used. Did
the same with grafdoc.tex and mf-revu.tex, except the latter has no
index. Have removed mppicdoc.tex since the small part of it that was
not already covered in mfpicdoc.tex has been added in an additional
appendix.
Made mfpic.dtx, mfpic.ins and grafbase.dtx files. Processing
mfpic.ins produces mfpic.tex and mfpic.sty from mfpic.dtx, plus
grafbase.mf, grafbase.mp and dvipsnam.mp from grafbase.dtx.
REVISION 0.64 alpha
Grafbase:
Rewrote the mfpic macro \polkadotwd so all it does is set the width
(omitting the code "thepolkadot := setdot(...)"). The grafbase polkadot
command now remakes the dot each time it is run. This is really just for
simplicity (for the \cs{polkadotwd} macro). Same was done for \shadewd
and shade. To change the shape of the dots used, I've added
shadedotpath and polkadotpath in addition to dotpath. The last is
now only used for dotted lines and grid.
Added command threeangles (suffix s) (expr A, B, C) that finds the
three angles of the triangle ABC and assigns them to the s1, s2, and
s3. Now used in arcppp and the new command circleppp . Later
threeangles was replaced by three calls to a new vardef: cornerangle
(A,B,C) , which was useful on its own.
Added circleppp producing the circle through three points.
Added circlecp producing the circle with center at a given point, and
passing through a given point.
Added circlepps producing the circle completing the arc produced by
the corresponding arcpps. These three form their circle from arcs,
ensuring that the circle (a) begins at the first given point on the
circumference, (2) has all the given points as nodes (though more may
have to be added, of course), and (iii) it is at least as robust as the
arc commands, into which a lot of thought was put.
Added commands that produce circles related to triangle. A triangle Q
is, by definition, required to be a closed path in the form
Q0--Q1--Q2--cycle.
circumcircle Q produces the circle through all three corners
incircle Q produces the inscribed circle (inside the triangle
and tangent to all three sides)
excircle n of Q produces the exscribed circle opposite Q[n] (tangent
to Q[n-1]--Q[n+1], and to the extensions of
Q[n]--Q[n-1] and Q[n]--Q[n+1] outside the triangle)
ninepointcircle Q The circle through the base of all three altitudes,
through all three midpoints of the sides and through
the points on each median that is halfway
between the corner and the common intersection of
the medians.
And commands that produce points related to a triangle:
incenter Q center of incircle Q (= intersection of angle
bisectors)
circumcenter Q center of circumcircle Q
excenter n of Q center of excircle n of Q
ninepointcenter Q center of ninepointcircle Q
None of the triangle related command integrated into mfpic yet.
Added command pathcenter c which obtains the center of a circle c
(or a rectangle c!) by finding the intersection of the perpendicular
bisectors of two chords. It will happily find the "center" of any path.
Mfpic:
Rewrote \function, \plrfcn and \parafcn so they all simply define
\mfp@fcnname to the appropriate grafbase command name and call the
same macro to write the code. As with a lot of other commands, we now
write the old shorter commands when the new parameter (in this case the
tension) is absent: \function {...} produces "function (true) (...)"
while \function[s1.5]{...} produces "tfunction (true) (1.5) (...)".
In retrospect it would have made cleaner code if I had placed the extra
"t" at the end of the name and the tension parameter at the beginning of
the parameters.
Made similar changes to \btwnfcn and \plrregion .
All the commands that have an optional argument for the color (\draw,
\gfill, \arrow and all the hatching commands) now have an empty value
for color as the default. When the color is empty we write the old
simpler commands. That is, "\draw..." or "\draw[]..." produces
"drawn ..." rather than "colordrawn (drawcolor) ..." Trying to
streamline the output file.
Added optional argument to \circle (similar to the ones for \arc). So
the circle through three points can be easily drawn, filled, etc.
Renamed \@graphdp to \@graphbot, since it is not the TeX depth, but
the coordinate of the bottom recalculated after each \tlabel . Also
\@graphht -> \@graphtop for the consistency.
Streamlined some aspects of tlabel macros, reducing number of
macros in the chain. Also keep track of the \@graphleft, etc.,
calculations so that we can later set the label on the graph with only
two kerns and no \if-clauses. \tb@moveright is the accumulated value to
kern horizontally, and \tb@raise is the amount to move vertically.
Streamlined \tlabel<path> macros, including consolidating main code into
one, rather than two alternative macros.
Added \@firstofone and use it in place of \mfp@identity . Also use it
when passing a pair of coordinates for \tlabel : provides grouping that
is not stripped by parameter matching, but also not written into output
file.
Assigned numbers to axes: x=0, y=1, l=2, b=3, r=4, t=5 . Defined
\get@axisnum similar to \tlabeljustify to assign the numbers, and can
now use \ifnum in \axis and \ifcase in \axislabels to branch on.
This also consolidates the error message in one place.
Rewrote the \endmfpic debug messages to give me information I want to
see: compare \@graphleft and \@graphright with \wd\@wholegraph, etc.
Rewrote \plottext under the assumption that all points are specified
as in other plotting commands: pairs separated by commas (i.e., no
braces). Changed docs to reflect it.
Redid \axislabels so that it could proceed gracefully on an empty
argument. In fact...
Added \mfp@ifempty as an abbreviation for
\if~#1~\@xp\@firstoftwo \else \@xp\@secondoftwo\fi
to make several such changes possible. Redid \do@mtparam using it.
Docs:
Documented some aspects of MF naming conventions (basically: no
suffixes) and suggested only letters be used.
REVISION 0.65 alpha
Mfpic:
Rename \mfp@metaposttrue to \mfp@mposttrue, etc.
Since \@mfp@mposttrue is never otherwise used, we don't define it
(i.e., remove \newif command), instead, replace its use in
\mfp@mposttrue with \global\let\if@mfp@mpost\iftrue . Similar
changes for the false version and for other switches: \if@mfp@clip,
\if@mfp@centcapt (formerly \if@mfp@centercaptions), \if@mfp@mplabels
Added \mfp@ifmpost{1}{2} as shorthand for \if@mfp@mpost 1\else 2\fi.
Added \@ifmplabels{1}{2} as shorthand for \if@mfp@mplabels 1\else 2\fi.
Added \xxxfalse (initializations). Though unnecessary, it provides
documentation of the default.
Renamed \@if@mfp@beforefileopen to \@if@mfp@filenotopen (since it
could conceivably have been previously opened but then closed).
Added \setdatadashes, \setdatacolors, and setdatasymbols, to allow
the user to set the dashing style, colors and symbols used when
\dashedlines, \coloredlines , or \pointedlines (or \datapointsonly),
respectively, are in effect. (later removed them, see below).
Added \@nameuse and \@namedef and replaced a several lines of code
with shorter versions using them.
Added \@ifmtarg (from ifmtarg.sty) and use it when possible instead
of \mfp@ifempty
Reordered much of both mfpic.dtx and grafbase.dtx (many times!) to
make documentation more natural.
Rather extensive revision of \axislabels , mainly so that braces around
the text argument are not prematurely stripped (bug introduced when we
tried to "gracefully" handle empty portions of the arguments).
Added \@makeother and used it in \mfp@sanitize.
Removed a number of \newif's : those whose values are always set by
another command. These commands now contain \let\ifxxx\iftrue instead
of \xxxtrue . This saves a couple of strings of pool.
Added \mf@T for the frequently used string "true" , and \mf@F for
"false" .
Removed grafdoc.tex from the manifest (grafbase.dtx documents the
grafbase macros). Also removed mf-revu.tex (because I'm lazy).
But will add mfpguide.tex as a short intro/tutorial.
Set \@mfp@verbtexfalse after writing the verbatimtex in
\opengraphsfile (in case it a user tries to have more than one
\opengraphsfile command in a document).
The utility \mfp@gettoks that was only used in \tmtitle and
\mftitle has now been used to abbreviate similar \afterassignment
constructs elsewhere.
Rewrote \curve and \cyclic so both call the same command (as was
done some time ago with \polyline and \polygon though not documented
until now).
Rewrote \noship and added \stopshipping and \resumeshipping so that
shipping can be turned off for several figures.
Simplifies \mfpdatacomment so that it just sets the register
\@datacommentchar to the character code. Then \mfp@setcomment
changes the category of \@datacommentchar to 14 (comment).
Added \transformpath , similar to \applyT except that it is a
modification macro for figures. It's argument is a transformer
Added \cutoffafter {<obj>} and \cutoffbefore {<obj>} as prefix
macros that cut the following path after its intersection with the named
<obj> (a name defined with \store)
Added \trimpath{<dim1>,<dim2>} , a prefix macro that removes the part
of the following path within <dim1> of its start and within <dim2>
of its end.
Grafbase:
Added transformedpath (transformer) expr f that reads a path f , applies
the transformer and returns the result. This is to supply the correct
syntax for the \transformpath macro.
Added gbcutafter and gbcutbefore . Unlike the similarly named MP
macros, these try to cut off as much as possible. Later changed the
names to cutoffafter and cutoffbefore, but gave them standard mfpic
syntax: "vardef cutoffbefore (expr b) expr f =". Also reverted to
essentially the same as the MP definitions.
Added trimmedpath (expr a,b) to implement \trimpath .
Rewrote textovalx and textellipsex so they now simply call a common
command, xellipse with a switch set that affects only two lines of the
calculations.
Slightly revised MF handling of colors. Now the only real difference
between MF and MP is in one macro, makeclr , plus the "color" keyword
("color" still means "numeric" in MF). What makeclr does is accept
three parameters and calculate a gray level in MF, but simply return a
color triple in MP. Then rgb(r, g, b) means
makeclr(snapto(r), snapto(g), snapto(b))
while all other color functions (except named ) call rgb .
REVISION 0.66 alpha
Grafbase:
Will try to converge behavior of labels between options mplabels and
nomplabels . Therefor, we add the labels in grafbase on top of the
drawing, after any clipping. We do this in newgblabel (oh, yes, I
renamed newabel to newgblabel) by adding the label to their own
picture: currentlabels. Then currentlabels is added onto the picture
as the very last thing in endmfpic .
Added emin(x,y) and emax(x,y) as somewhat more efficient versions
of min() and max() . They are vardefs and take two expression
arguments rather than a text parameter with an arbitrary list.
Added the possibility for textrectx to be given "maximally" rounded
corners: each quarter circle meets the one at the nearest corner so the
end is a semicircle. This is done by allowing the radius parameter to be
a boolean. When it is true, maximal roundedness is used, when false the
corners are not rounded. Provided a mfpic interface by defining the
boolean variable roundends, which is true by default.
Added TruncateWarn and NoCycleWarn , that print common warning
messages.
Added pointcolor , the color in which points are drawn by pointd and
in which symbols are drawn by plotsymbol . Now implement pointd with
plotsymbol . However plotnodes , being a drawing command, uses
drawcolor .
Removed "withcolor fillcolor" from the definition of interior , which
is normally only used in grafbase.mp in some other command that has a
color parameter. The only really "benefit" of having it there was a
dubious one: plotsymbol produced fillcolor solid symbols and
drawcolor open ones. Now all are in pointcolor . Also moved a couple
of other instances of withcolor out of low level commands and into
higher level commands.
Removed the color parameter from thatchf . For MF to respond to
hatchcolor , the color has to be invoked when the hatching is added to
active_plane , and only the higher level command, thatch , does that.
Rearranged some of grafbase.dtx for documentation purposes. I am
trying to follow this order: bitwise operations, picture manipulation
commands with use-motivated names, and then the rendering commands that
use those to manipulate active_plane, finally followed by the graph
coordinate rendering commands.
Added vardefs pnt@#(f) , pre@#(f) and post@#(f) as abbreviations
for point @# of f , precontrol @# of f and postcontrol @# of f .
Changed a few "max (x,0)" to "abs(x)". These had mostly been not
well-thought-out attempts to gracefully handle erroneous negative values
of "x". The "abs(x)" versions avoid problems in more situations
Mfpic:
I will eventually move the import of the picture from the beginning of
the environment (\mfpic) to the end (\endmfpic). Labels (when TeX is
placing them) will be kept in a separate box, and it will be added onto
the picture at the end.
The optional parameter of \tlabelrect may now be the literal word
"roundends". This will make the radius of the quarter circles equal to
half the narrower dimension of the rectangle, giving the "rectangle"
semicircular ends.
Added \pointcolor for setting the color of points (for \point) and for
symbols (\plotsymbol), but \plotnodes is interpreted as a drawing
command, and so still uses \drawcolor.
Changed (again!) the name of \@if@mfp@filenotopen, this time to
\@if@mfp@fileisopen, reversing its sense, and reversed the order of all
commands.
Moved the undefining of \mfp@filename in \closegraphsfile outside
the conditional (just in case).
REVISION 0.67 alpha
Grafbase:
Added knownarray suffix arr, which returns a boolean: true if arr is
the name of a known array (arr is numeric and a positive integer and
arr[1] through arr[arr] are known). Added isdashpat suffix pat,
which applies knownarray to pat.start, pat.rep and pat.finish.
Added defaultdashes, defaultsymbols, and defaultcolors, which
contains the code to define dashtype0, etc., pointtype0, etc., and
colortype0, etc.
Added setdatadashes, setdatasymbols, and setdatacolors to allow the
user to change the definitions of the dashtype, pointtype, and
colortype arrays.
Added getdashpat, getsymbol, and getcolor which perform the modding
operation that used to be done in TeX for reverting (for example) to
pointtype0 after the ninth curve is drawn by \plotdata.
Changed thepolkadot (in MF) so it is shaded. But we should make it
cover other contents of a region, and we need to subtract black ones
before we add gray ones. Done.
Added regularpolygon (expr n) (suffix P) (text eqns), where n
is the number of sides, P is the name of the array of vertices, and
eqns is a pair of equations specifying either the center, P0, and one
vertex, or two vertices. Vertices are numbered anticlockwise (otherwise
two points are not enough data).
Added variables default_tension and fcn_tension to be used as the
default in path creation commands instead of the hard coded values 1 and
1.2.
Mfpic:
Realized that the opening code of \mfpic no longer needs to know the
setting of truebbox. No longer make it an error to use it in an mfpic
environment.
Replaced the three commands \setdatadashes, \setdatacolors etc., with
a single command \reconfigureplot which takes the word `dashes',
`colors', or `symbols' for an argument. Added \defaultplot which
takes the same arguments and restores the builtin defaults.
Changed name of \partialpath to \partpath.
Added \regpolygon{n}{P}{<eqn1>}{<eqn2>} which writes
reguralpolygon (n) (P) (<eqn1>;<eqn2>;) (see above).
Moved the loading of the figure to \endmfpic. Now tlabels are added
to a box \@alltlabels which is appended to the figure right after it
is loaded. This helps keep most of the box loading in one place. It also
permits the possibility of adding a write-18 capability for on-the-fly
figure creation.
Added \mpobj as a synonym for \mfobj.
Added \settension to set the grafbase variable default_tension.
and \setfcntension to set the grafbase variable fcn_tension.
Docs:
Started mfpguide.tex, a beginner's tutorial.
Renamed mfpicdoc.tex to mfpicman.tex (can't remember why -- maybe
because I got it confused with mfpdoc.sty).
REVISION 0.68 alpha
Grafbase:
Improved fcncurve: fcncontrol does `the right thing' when two
successive points have the same x-coordinate. This gives the curve a
decent ending if, instead of extending the sequence by symmetry (in
order to calculate the controls for the endpoints) we extend by making
the additional points equal to the endpoints. Looks _so_ much better!
That was surprising given that all I tried to do was avoid dividing by
0!
Modified plotnodes as well as plotsymbol so that both store the
relevant pairs in an array and call dosymbols, which draws the symbol
at each coordinate in the array. And dosymbols call another command,
addsymbols, one or two times (once to clear).
Added boolean: clearsymbols. When true, those symbols place by
plotsymbol or plotnodes which are `clearable' (open paths that satisfy
their first point equals their last) are first closed and filled with
background color in MP (cleared in MF) before being drawn.
Added complex function sgn Z : returns 0 if Z is (0,0) otherwise
unitvector Z.
Modified shadepic. The main point to make sure we don't divide by 0.
But also, set dimensions for the picture by doing the lowest resolution
first (thus ensuring both dimensions are at least 2 _pixels_).
Modified the arrowhead routine so that when the head is filled, the
extra line that closes the head is also drawn.
Modified arcpps so that angles less than 45 are drawn as a single
segment without passing through a midpoint.
Modified pathcenter c so it can find the center when c is only an
arc.
Added barycenter expr t to average the points of the the path t.
Added makesector expr p, where p is an arc (or any path). Connects
pathcenter p to its endpoints. Could be a little more accurate if we
limited it to arcpps and used arccenter.
Added boolean: overlaylabels. When true, labels are added to
current_labels, which is then overlayed at endmfpic (new behavior),
when false, labels are added immediately to active_plane.
Changed these so they produce a path (line segment); used to be they
returned the endpoint. (You can get the point by invoking
"point 1 of altitude n of Q".)
altitude n of Q the altitude from Q[n] to the opposite side
(produced if necessary).
median n of Q the median from Q[n] to the opposite side
anglebisector n of Q the angle bisector from Q[n] to the opposite
side
Added
tbezier (expr tens, cyclic) (text lst)
which makes the simple cubic bezier (connects the points in the list
with ..tension tens.. ), as well as its non-tense counterpart bezier.
Also added
mkbezier (expr tens, cyclic) (suffix pts)
which is called by the above after loading the text list in the
the array pts.
For quadratic Be'ziers we have qbezier, and mkqbezier.
Removed fcn_tension, using instead 1.2*default_tension. This is for
consistency, all curves responding to the same default
Added verbatimtex definition to grafbase.mf. It just gobbles
everything to the next semicolon.
Redid openqbs and closedqbs so they behave like most other
path-making commands: they call textpairs and then some common code,
mkqbs with the name of an array. Also redid mkclosedcbs so it
utilizes mkopencbs.
Mfpic:
Changed the axis commands so they explicitly call \arrow. The purpose
was to ensure that the arrowhead is drawn _after_ the shaft.
Significant only for colored heads. This turns out to make axis@# in
grafbase unnecessary \arrow[l##1]\@figmac{axisline.##2} is all that is
required.
Added \makesector, a \@closmac prefix that can make a sector out of
a following arc. Useful when the arc is given without a known center
([t] or [s]).
Added \let\@nl=\@activectrlM to \@mfwrite so that \@nl can
be used for line breaks when catcodes of EOL are already fixed (e.g., in
macro definitions)
Added check to \opengraphsfile that no previous file is still open.
Added \clearsymbols \noclearsymbols to interface with the grafbase
clearsymbols boolean. Added clearsymbols LaTeX option
Added \newdef\pinumber{3.14159}.
Added new option: overlaylabels and commands \overlaylabels and
\nooverlaylabels. Similar in implementation to truebbox: a TeX
boolean is used only to communicate the setting to \opengraphsfile
before a file is open. Otherwise a MetaPost boolean (above) is switched
on or off.
Moved \@processdatafile outside \@mfpic@graf@macs. Also moved
\skipBlanksandComments and definition of \mfp@data since they are
used by \@processdatafile. Also moved \skipcoomments because it
seemed it should go along with \skipBlanksandComments. Then I rewrote
the latter to actually call \skipcomments, so now it _has_ to go where
it goes.
Renamed \mfp@empty to \@empty.
Added \pairarray{<name>}{<list-of-pairs>} and
\numericarray{<name>}{<list-of-numbers>}. They define, respectively, an
array of pairs and an array of numbers. They can be used outside an mfpic
environments (unlike \patharr), and have the usual scoping properties.
Added \mfbezier[<tens>]{<list>} to interface with grafbase's new
bezier command. Also \closedmfbezier.
And the equivalent of (a sequence of) LaTeX \qbezier: \qbeziers and
\closedqbeziers.
Removed \setfcntension because grafbase's fcn_tension was removed.
Adjusted docs.
Renamed \if@mfp@mpost to \ifmfpmpost so power users can use it to
write code dependent on the figure processor. The commands to change it
are still private: \mfp@mposttrue/false .
Added the test for file being open to \setmfvariable. Saves a lot of
tokens. It seems we never used it without \@if@mfp@fileisopen. Require
moving it considerably earlier.
Added \mfp@let as abbreviation for \mfp@local\let. Likewise
\mfp@def.
Renamed \mfp@addto to \mfpaddto for power users (i.e., me) and added
\mfpmultiply (same syntax and similar effect).
Renamed \@if@mfp@fileisopen to \@ifmfpfileisopen (it was just too
many @'s !)
Changed \everytlabel so it tests for metapost rather than mplabels.
This allows it to be used anywhere without worrying whether \nomplabels
might have cancelled its effect.
Renamed \massage@data to \parse@data.
Make sure every write of verbatimtex ... etex ends with a semicolon so
it can be used by grafbase.mf (see above).
Docs:
First version of mfpguide.tex finished. Writing it exposed a number of
bugs that got by the usual suite of tests. It is the first documentation
that actually shows the code and its result together.
Second version of mfpguide.tex, adds appendices. Planning to ship a
PDF version.
REVISION 0.69 alpha and 0.69a
Mfpic:
Rewrote \do@ptparam so its first parameter is the command token (e.g.,
\do@ptparam\@draw{} instead of the old \do@ptparam{@draw}{}). Added a
command \simple@opt to process simple optional arguments (those that
don't need further parsing), it calls a second command to read the
option, substitute the default if empty, and then call the command with
the given or supplied option as a normal (brace enclosed) argument. The
idea is to make all empty optional arguments the same as none at all.
Added a command \null@opt which is essentially \do@ptparam with a null
second argument. It turns out that now all commands can be handled by
the last two: \do@ptparam and \alt@ptparam are not used anywhere
anymore, although the bare "\mfp@ifnextchar[" does appear once or twice.
Make \gridlines honor the settings of \axismargin (see grafbase
section below).
Added \hgridlines to draw only the horizontal and \vgridlines to
draw only the vertical.
Added \gridarcs and \gridrays to draw only the arcs or rays of a
polar grid.
Added \setmfboolean for \setmfvariable{boolean}.
Added \setmfnumeric for \setmfvariable{numeric}.
Grafbase:
Rewrote gridlines to honor the axis margins (laxis, baxis, raxis,
and taxis).
Added hgridlines (expr ysp) and vgridlines (expr xsp)
Corrected polargrid. How did it ever last this long without a bug
report? The computation of rmin was wrong, and it seems a semicolon
was missing! Added gridarcs (expr rstep) to draw only the arcs, and
gridrays (tstep) for only the rays. Complemented plrpatch with
patcharcs and patchrays for this purpose.
Corrected polargrid again! It seems the calculation of max and min
angles didn't take into account that angle (0,0) was undefined but
could occur in the code.
Redid resizedrawpen to save drawpen and currentpen (not just
penwd).
Removed mindiam and substituted minpenwd in the MP version (they
were equal anyway).
Added \InputIfFileExists{mfpic.cfg} in the LaTeX section just before
\ProcessOptions. Added code to detect and input mfppatch.tex if it
exists.
Docs:
Added a file plotting example to pictures.tex and lapictures.tex.
Added some of the new commands to Objects.tex . Converted Objects.tex
to use built-in \ifmfpmpost instead of the ad hoc \ifmetapost
defined in TeXMPobj.tex and LTXMPobj.tex.
Renamed mfpicman.tex to mfpman.tex.
Distribution:
Packed up for distribution in mfpic69b.zip:
mfpic.dtx
grafbase.dtx
mfpic.ins
README.txt
install.txt
changes.txt
mfpman.pdf
mfpguide.pdf
examlpes\pictures.tex
examlpes\lapictures.tex
examlpes\forfun.tex
examlpes\data.dat
scr\mfpman.tex
scr\mfpguide.tex
scr\refcard.tex
scr\mfpdoc.sty
And placed on web site.
REVISION 0.69c alpha
Grafbase:
Redid gendashed so that it balances speed versus memory: If there are
n repeated patterns, add sqrt(_n) of them to the picture _v, then
DoClip (_v); coloraddto (drawcolor) (active_plane, _v); <repeat>. Doing
that for each pattern was too slow, doing it only once wasted memory.
Put on web site.
REVISION 0.69d
Grafbase:
Modified barchart so that the data can be pairs. Interpret (a,b)
as an interval and creates bars that begin at a and end at b (Gantt
diagrams).
Added predirection@# (expr p) and postdirection@# (expr p) which
give correct results *whenever* the path p is nontrivial. Based on
the easily prove fact (which I only recently discovered) that for a
nontrivial single knot with keypoints A, B, C and D, the direction at A
is towards the first one of B, C or D that is not equal to A. The
predirection[j] returns (0,0) if the path is trivial. If the path is
trivial upto time j, it returns postdirection[j]. postdirection[j]
is analogous.
Changed headpath to use predirection[length p](p) instead of
point length p of p - precontrol length p of p.
Mfpic:
Added \gantt (= \barchart)
Distribution:
Placed on web site, announced on c.t.t.
REVISION 0.69e
Grafbase:
Somehow the last version of grafbase included failed to include a
long-ago change to colorsafefill in which non-black fills first
subtract the interior under MF. Corrected that.
Experimented with a O(log n) loop for filledwith. Made no significant
difference in speed in tests. Must be the extra overhead. Keeping old
O(n) method.
Experimented with using "..tension atleast tens.." in mksmooth and
sclosed. All other tension using operations either call these or
require different treatment. The one case in the test suite where a
visible difference occured, it looked worse. Returned to old method.
Proofed grafbase.dvi, the documentation of grafbase macros.
Docs:
Proofed mfpguide.
REVISION 0.69f
Mfpic:
Made [cc] the default for \tlabelrect, etc. Added command
\tlpathjustify to change the default.
Added code to input local additions, defaults, etc., in mfpic.usr, if
it exists.
Changed \let\par\relax to \let\par\@empty at the beginning of
\@mfpic. It isn't really necessary to use \relax, we just want
to disable blank lines, we don't necessarily want to skip over them in
\mfp@ifnextchar. In fact, for catching errors, it is better if a blank
line stops \mfp@ifnextchar.
Grafbase:
New definition of image (writing on active_plane) prevents use of
plain.mp macros (draw and undraw, for example) inside it. Revert
to plain.mp version.
Change patcharcs and patchrays so they draw on a suffix parameter
This avoids the use of image and saves memory since drawing on a
picture takes less memory (in some circumstances) than creating a
picture and then assigning it. Actually, the least memory would be to
clip each line as created and add that directly to active_plane.
Re-examined use (or lack of use) of mono(). Added a few.
REVISION 0.69g
Packed it up in mfpic69g.zip and put it on my web site.
Docs:
Added documentation that several arrays become defined after a
\piechart or \barchart command.
Added documentation on \mfpicversion. Added a couple of overlooked
\index entries and a couple of commands omitted from the "by type"
list.
Grafbase:
Modified piechart and barchart so that the documentation about
arrays was correct What was missing: pieangle and piedirection
(without numeric suffixes) were not declared, nor given the correct
value.
Modified code of textrectx so that documentation of \tlabelrect was
accurate: negative values of the optional argument should now produce
indented arcs and reversed path. All that needed doing was reversing the
order of the path connections for negative radii.
Fine tune the calculation of gray level for the MP version of shade so
that the result more closely matches the MF version on modern printers
(600+ DPI). Formula is now gray = 1 - (.88*shadewd/sp)**2, which gives
a lighter gray than before. We therefore rewrite the MF code to permit
shadewd to be as high as sp/.88 before resorting to filling. The
number .88 was empirically arrived at (i.e. I determined what number
made most of the MP and MF shaded figures in Objects.tex look the most
similar on two different printers; then I averaged the two values).
Change pi and deg to internals (along with radians).
Make plrpatch do what it used to do: draw in drawcolor. Also change
polarpatch back to calling plrpatch.
REVISION 0.7 beta, 14 Nov 2003
Packed up and put on web page and CTAN.
REVISION 0.7a beta, 16 Apr 2004
Change one semicolon (;) in a string written by \opengraphsfile to a
colon (:) to work around a bug in the perl scripts mptopdf and/or
texexec.
------------------------------------------------------------------------
Stuff To Do
------------------------------------------------------------------------
Pie-in-the-sky stuff
A command to obtain the boundary of a region defined by F(x,y), where
F is a boolean valued function. Easy if the region is convex.
A command to draw a path paralleling another path. Will need
predirection and postdirection and some notion of what to do when
they differ. Inside corners/cusps should be easy,
/\ /\
/ \ --> / \
/ \ / /\ \
outside corners might need some limit on "mitering":
__ /\
/ \ / \
/\ --> / /\ \ or / /\ \ or a rounded (circular?) connection.
A command to render a path with a "photon"?
Try 'write18' on-the-fly creation of figures? Most straightforward would
be to mimic \opengraphsfile with each \mfpic. That would require
rethinking those commands that write to the graph file _outside_ an
mfpic figure. Maybe redo \mfsrc so it added to some macro or token list,
and write _that_ after the file is opened.
Or maybe: \opengraphsfile at beginning of document, then
\closegraphsfile just before processing the figure, then \opengraphsfile
again right afterwards. Then only commands we insert occur when a file
is closed.
Truebbox for MF? Might be done if every drawing command kept track of
bounding boxes (commands that fill, hatch, etc. already get this info
with gbbox). Would just need to add it to plotsymbol (for pointd and
plotnodes) and to the drawing commands (drawn, gendashed, etc.). Might
want to skip the lower-level things like safedraw, safefill, etc. (or
maybe add it _only_ there). Don't want to do it for anything that
doesn't add to active_plane. But some things only add pictures to
active_plane and by then it's impossible to determine the size. Once a
bounding box is known, endmfpic can adjust tfm dimensions. and shift the
picture before shipout.
|