/* A Bison parser, made from Gmsh.y by GNU Bison version 1.28 */ #define YYBISON 1 /* Identify Bison output. */ #define tDOUBLE 257 #define tSTRING 258 #define tBIGSTR 259 #define tEND 260 #define tAFFECT 261 #define tDOTS 262 #define tPi 263 #define tExp 264 #define tLog 265 #define tLog10 266 #define tSqrt 267 #define tSin 268 #define tAsin 269 #define tCos 270 #define tAcos 271 #define tTan 272 #define tRand 273 #define tAtan 274 #define tAtan2 275 #define tSinh 276 #define tCosh 277 #define tTanh 278 #define tFabs 279 #define tFloor 280 #define tCeil 281 #define tFmod 282 #define tModulo 283 #define tHypot 284 #define tPrintf 285 #define tSprintf 286 #define tDraw 287 #define tPoint 288 #define tCircle 289 #define tEllipsis 290 #define tLine 291 #define tSurface 292 #define tSpline 293 #define tVolume 294 #define tCharacteristic 295 #define tLength 296 #define tParametric 297 #define tElliptic 298 #define tPlane 299 #define tRuled 300 #define tTransfinite 301 #define tComplex 302 #define tPhysical 303 #define tUsing 304 #define tBump 305 #define tProgression 306 #define tRotate 307 #define tTranslate 308 #define tSymmetry 309 #define tDilate 310 #define tExtrude 311 #define tDuplicata 312 #define tLoop 313 #define tRecombine 314 #define tDelete 315 #define tCoherence 316 #define tView 317 #define tAttractor 318 #define tLayers 319 #define tScalarTetrahedron 320 #define tVectorTetrahedron 321 #define tTensorTetrahedron 322 #define tScalarTriangle 323 #define tVectorTriangle 324 #define tTensorTriangle 325 #define tScalarLine 326 #define tVectorLine 327 #define tTensorLine 328 #define tScalarPoint 329 #define tVectorPoint 330 #define tTensorPoint 331 #define tBSpline 332 #define tNurbs 333 #define tOrder 334 #define tWith 335 #define tBounds 336 #define tKnots 337 #define tColor 338 #define tFor 339 #define tIn 340 #define tEndFor 341 #define tIf 342 #define tEndIf 343 #define tExit 344 #define tMerge 345 #define tReturn 346 #define tCall 347 #define tFunction 348 #define tB_SPLINE_SURFACE_WITH_KNOTS 349 #define tB_SPLINE_CURVE_WITH_KNOTS 350 #define tCARTESIAN_POINT 351 #define tTRUE 352 #define tFALSE 353 #define tUNSPECIFIED 354 #define tU 355 #define tV 356 #define tEDGE_CURVE 357 #define tVERTEX_POINT 358 #define tORIENTED_EDGE 359 #define tPLANE 360 #define tFACE_OUTER_BOUND 361 #define tEDGE_LOOP 362 #define tADVANCED_FACE 363 #define tVECTOR 364 #define tDIRECTION 365 #define tAXIS2_PLACEMENT_3D 366 #define tISO 367 #define tENDISO 368 #define tENDSEC 369 #define tDATA 370 #define tHEADER 371 #define tFILE_DESCRIPTION 372 #define tFILE_SCHEMA 373 #define tFILE_NAME 374 #define tMANIFOLD_SOLID_BREP 375 #define tCLOSED_SHELL 376 #define tADVANCED_BREP_SHAPE_REPRESENTATION 377 #define tFACE_BOUND 378 #define tCYLINDRICAL_SURFACE 379 #define tCONICAL_SURFACE 380 #define tCIRCLE 381 #define tTRIMMED_CURVE 382 #define tGEOMETRIC_SET 383 #define tCOMPOSITE_CURVE_SEGMENT 384 #define tCONTINUOUS 385 #define tCOMPOSITE_CURVE 386 #define tTOROIDAL_SURFACE 387 #define tPRODUCT_DEFINITION 388 #define tPRODUCT_DEFINITION_SHAPE 389 #define tSHAPE_DEFINITION_REPRESENTATION 390 #define tELLIPSE 391 #define tTrimmed 392 #define tSolid 393 #define tEndSolid 394 #define tVertex 395 #define tFacet 396 #define tNormal 397 #define tOuter 398 #define tLoopSTL 399 #define tEndLoop 400 #define tEndFacet 401 #define tAFFECTPLUS 402 #define tAFFECTMINUS 403 #define tAFFECTTIMES 404 #define tAFFECTDIVIDE 405 #define tOR 406 #define tAND 407 #define tEQUAL 408 #define tNOTEQUAL 409 #define tAPPROXEQUAL 410 #define tLESSOREQUAL 411 #define tGREATEROREQUAL 412 #define tCROSSPRODUCT 413 #define tPLUSPLUS 414 #define tMINUSMINUS 415 #define UNARYPREC 416 #line 1 "Gmsh.y" /* $Id: Gmsh.tab.cpp,v 1.45 2000-12-11 19:39:14 geuzaine Exp $ */ #include <stdarg.h> #include "Gmsh.h" #include "Const.h" #include "Context.h" #include "Geo.h" #include "CAD.h" #include "DataBase.h" #include "Mesh.h" #include "Create.h" #include "Views.h" #include "StepGeomDatabase.h" #include "Options.h" #include "Colors.h" #include "Parser.h" #include "Main.h" #include "FunctionManager.h" #include "ColorTable.h" #ifdef __DECCXX // bug in bison #include <alloca.h> #endif int Force_ViewNumber = 0 ; List_T *Symbol_L; extern Mesh *THEM; extern Post_View *ActualView; extern char ThePathForIncludes[NAME_STR_L]; static FILE *yyinTab[MAX_OPEN_FILES]; static int yylinenoTab[MAX_OPEN_FILES]; static fpos_t yyposImbricatedLoopsTab[MAX_OPEN_FILES]; static double LoopControlVariablesTab[MAX_OPEN_FILES][3]; static char* LoopControlVariablesNameTab[MAX_OPEN_FILES]; static char yynameTab[MAX_OPEN_FILES][NAME_STR_L]; static char tmpstring[NAME_STR_L]; static char tmpstring2[NAME_STR_L], tmpstring3[NAME_STR_L]; static Symbol TheSymbol, *pSymbol; static Surface *STL_Surf; static Shape TheShape; static int i,j,k,flag,RecursionLevel=0,ImbricatedLoop = 0; static int Last_NumberOfPoints = 0; static double d, *pd; static ExtrudeParams extr; static List_T *ListOfDouble_L,*ListOfDouble2_L; static List_T *ListOfListOfDouble_L, *ListOfColor_L=NULL; static char *str; static void *pNumOpt, *pArrOpt; static char **pStrOpt, *pStrViewOpt; static unsigned int *pColOpt; static StringXString *pStrCat; static StringXNumber *pNumCat; static StringXArray *pArrCat; static StringXColor *pColCat; void yyerror (char *s); void vyyerror (char *fmt, ...); void skip_until (char *until); #line 65 "Gmsh.y" typedef union { char *c; int i; unsigned int u; double d; double v[5]; Shape s; List_T *l; } YYSTYPE; #include <stdio.h> #ifndef __cplusplus #ifndef __STDC__ #define const #endif #endif #define YYFINAL 1567 #define YYFLAG -32768 #define YYNTBASE 181 #define YYTRANSLATE(x) ((unsigned)(x) <= 416 ? yytranslate[x] : 259) static const short yytranslate[] = { 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 168, 2, 2, 2, 166, 2, 2, 173, 174, 164, 162, 178, 163, 177, 165, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 158, 2, 160, 152, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 175, 2, 176, 172, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 179, 2, 180, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 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, 153, 154, 155, 156, 157, 159, 161, 167, 169, 170, 171 }; #if YYDEBUG != 0 static const short yyprhs[] = { 0, 0, 2, 4, 6, 8, 30, 32, 33, 36, 38, 40, 42, 45, 48, 51, 54, 57, 60, 68, 74, 92, 102, 126, 158, 174, 186, 198, 214, 224, 238, 248, 260, 274, 284, 294, 306, 316, 328, 338, 350, 364, 378, 390, 404, 422, 432, 444, 456, 470, 482, 492, 493, 496, 498, 500, 502, 504, 506, 508, 510, 512, 514, 516, 518, 520, 523, 529, 537, 544, 553, 554, 557, 560, 563, 566, 569, 572, 575, 578, 581, 584, 587, 590, 592, 596, 597, 611, 613, 617, 618, 632, 634, 638, 639, 653, 655, 659, 660, 680, 682, 686, 687, 707, 709, 713, 714, 734, 736, 740, 741, 767, 769, 773, 774, 800, 802, 806, 807, 833, 835, 839, 840, 872, 874, 878, 879, 911, 913, 917, 918, 950, 955, 963, 967, 974, 978, 985, 990, 998, 1003, 1011, 1016, 1024, 1029, 1037, 1044, 1056, 1063, 1075, 1082, 1094, 1101, 1113, 1120, 1132, 1139, 1151, 1157, 1169, 1175, 1187, 1194, 1206, 1213, 1225, 1232, 1244, 1253, 1265, 1273, 1282, 1295, 1302, 1308, 1316, 1324, 1337, 1345, 1355, 1373, 1381, 1390, 1399, 1407, 1419, 1425, 1434, 1444, 1453, 1476, 1497, 1506, 1515, 1521, 1530, 1538, 1547, 1553, 1565, 1571, 1581, 1583, 1585, 1587, 1588, 1591, 1596, 1601, 1605, 1609, 1612, 1615, 1622, 1631, 1640, 1651, 1653, 1655, 1659, 1662, 1667, 1669, 1678, 1691, 1700, 1713, 1722, 1735, 1747, 1763, 1765, 1768, 1778, 1781, 1788, 1798, 1808, 1817, 1826, 1835, 1842, 1847, 1850, 1852, 1854, 1856, 1858, 1860, 1862, 1866, 1869, 1872, 1875, 1879, 1883, 1887, 1891, 1895, 1899, 1903, 1907, 1911, 1915, 1919, 1923, 1927, 1931, 1937, 1942, 1947, 1952, 1957, 1962, 1967, 1972, 1977, 1982, 1987, 1994, 1999, 2004, 2009, 2014, 2019, 2024, 2031, 2038, 2045, 2050, 2052, 2054, 2056, 2061, 2064, 2070, 2073, 2079, 2083, 2092, 2097, 2107, 2112, 2122, 2126, 2132, 2134, 2137, 2140, 2144, 2148, 2160, 2170, 2178, 2186, 2190, 2199, 2200, 2204, 2206, 2210, 2211, 2215, 2219, 2221, 2225, 2226, 2228, 2232, 2236, 2238, 2240, 2244, 2248, 2252, 2258, 2268, 2276, 2282, 2284, 2290, 2294, 2303, 2305, 2309, 2311, 2316 }; static const short yyrhs[] = { 183, 0, 182, 0, 188, 0, 139, 0, 142, 143, 244, 244, 244, 144, 145, 141, 244, 244, 244, 141, 244, 244, 244, 141, 244, 244, 244, 146, 147, 0, 140, 0, 0, 183, 184, 0, 185, 0, 187, 0, 186, 0, 1, 6, 0, 113, 6, 0, 114, 6, 0, 116, 6, 0, 115, 6, 0, 117, 6, 0, 118, 173, 249, 178, 5, 174, 6, 0, 119, 173, 249, 174, 6, 0, 120, 173, 5, 178, 5, 178, 249, 178, 249, 178, 5, 178, 5, 178, 5, 174, 6, 0, 3, 7, 97, 173, 5, 178, 247, 174, 6, 0, 3, 7, 96, 173, 5, 178, 244, 178, 253, 178, 243, 178, 243, 178, 243, 178, 253, 178, 253, 178, 243, 174, 6, 0, 3, 7, 95, 173, 5, 178, 244, 178, 244, 178, 251, 178, 243, 178, 243, 178, 243, 178, 243, 178, 253, 178, 253, 178, 253, 178, 253, 178, 243, 174, 6, 0, 3, 7, 103, 173, 5, 178, 3, 178, 3, 178, 3, 178, 243, 174, 6, 0, 3, 7, 107, 173, 5, 178, 3, 178, 243, 174, 6, 0, 3, 7, 124, 173, 5, 178, 3, 178, 243, 174, 6, 0, 3, 7, 105, 173, 5, 178, 164, 178, 164, 178, 244, 178, 243, 174, 6, 0, 3, 7, 108, 173, 5, 178, 253, 174, 6, 0, 3, 7, 109, 173, 5, 178, 253, 178, 3, 178, 243, 174, 6, 0, 3, 7, 104, 173, 5, 178, 3, 174, 6, 0, 3, 7, 110, 173, 5, 178, 3, 178, 244, 174, 6, 0, 3, 7, 112, 173, 5, 178, 3, 178, 3, 178, 3, 174, 6, 0, 3, 7, 111, 173, 5, 178, 247, 174, 6, 0, 3, 7, 106, 173, 5, 178, 3, 174, 6, 0, 3, 7, 37, 173, 5, 178, 3, 178, 3, 174, 6, 0, 3, 7, 122, 173, 5, 178, 253, 174, 6, 0, 3, 7, 123, 173, 5, 178, 253, 178, 3, 174, 6, 0, 3, 7, 121, 173, 5, 178, 3, 174, 6, 0, 3, 7, 125, 173, 5, 178, 3, 178, 244, 174, 6, 0, 3, 7, 126, 173, 5, 178, 3, 178, 244, 178, 244, 174, 6, 0, 3, 7, 133, 173, 5, 178, 3, 178, 244, 178, 244, 174, 6, 0, 3, 7, 127, 173, 5, 178, 3, 178, 244, 174, 6, 0, 3, 7, 137, 173, 5, 178, 3, 178, 244, 178, 244, 174, 6, 0, 3, 7, 128, 173, 5, 178, 3, 178, 253, 178, 253, 178, 243, 178, 243, 174, 6, 0, 3, 7, 129, 173, 5, 178, 253, 174, 6, 0, 3, 7, 130, 173, 131, 178, 243, 178, 3, 174, 6, 0, 3, 7, 132, 173, 5, 178, 253, 178, 243, 174, 6, 0, 3, 7, 134, 173, 5, 178, 5, 178, 3, 178, 3, 174, 6, 0, 3, 7, 135, 173, 5, 178, 5, 178, 3, 174, 6, 0, 3, 7, 136, 173, 3, 178, 3, 174, 6, 0, 0, 188, 189, 0, 191, 0, 190, 0, 229, 0, 230, 0, 231, 0, 234, 0, 235, 0, 238, 0, 241, 0, 242, 0, 237, 0, 236, 0, 1, 6, 0, 31, 173, 5, 174, 6, 0, 31, 173, 5, 178, 254, 174, 6, 0, 63, 5, 179, 192, 180, 6, 0, 63, 5, 4, 247, 179, 192, 180, 6, 0, 0, 192, 194, 0, 192, 197, 0, 192, 200, 0, 192, 203, 0, 192, 206, 0, 192, 209, 0, 192, 212, 0, 192, 215, 0, 192, 218, 0, 192, 221, 0, 192, 224, 0, 192, 227, 0, 244, 0, 193, 178, 244, 0, 0, 75, 173, 244, 178, 244, 178, 244, 174, 195, 179, 193, 180, 6, 0, 244, 0, 196, 178, 244, 0, 0, 76, 173, 244, 178, 244, 178, 244, 174, 198, 179, 196, 180, 6, 0, 244, 0, 199, 178, 244, 0, 0, 77, 173, 244, 178, 244, 178, 244, 174, 201, 179, 199, 180, 6, 0, 244, 0, 202, 178, 244, 0, 0, 72, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 204, 179, 202, 180, 6, 0, 244, 0, 205, 178, 244, 0, 0, 73, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 207, 179, 205, 180, 6, 0, 244, 0, 208, 178, 244, 0, 0, 74, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 210, 179, 208, 180, 6, 0, 244, 0, 211, 178, 244, 0, 0, 69, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 213, 179, 211, 180, 6, 0, 244, 0, 214, 178, 244, 0, 0, 70, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 216, 179, 214, 180, 6, 0, 244, 0, 217, 178, 244, 0, 0, 71, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 219, 179, 217, 180, 6, 0, 244, 0, 220, 178, 244, 0, 0, 66, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 222, 179, 220, 180, 6, 0, 244, 0, 223, 178, 244, 0, 0, 67, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 225, 179, 223, 180, 6, 0, 244, 0, 226, 178, 244, 0, 0, 68, 173, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 178, 244, 174, 228, 179, 226, 180, 6, 0, 4, 7, 244, 6, 0, 4, 175, 244, 176, 7, 244, 6, 0, 4, 169, 6, 0, 4, 175, 244, 176, 169, 6, 0, 4, 170, 6, 0, 4, 175, 244, 176, 170, 6, 0, 4, 148, 244, 6, 0, 4, 175, 244, 176, 148, 244, 6, 0, 4, 149, 244, 6, 0, 4, 175, 244, 176, 149, 244, 6, 0, 4, 150, 244, 6, 0, 4, 175, 244, 176, 150, 244, 6, 0, 4, 151, 244, 6, 0, 4, 175, 244, 176, 151, 244, 6, 0, 4, 177, 4, 7, 5, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 7, 5, 6, 0, 4, 177, 4, 7, 244, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 7, 244, 6, 0, 4, 177, 4, 148, 244, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 148, 244, 6, 0, 4, 177, 4, 149, 244, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 149, 244, 6, 0, 4, 177, 4, 150, 244, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 150, 244, 6, 0, 4, 177, 4, 151, 244, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 151, 244, 6, 0, 4, 177, 4, 169, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 169, 244, 6, 0, 4, 177, 4, 170, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 170, 244, 6, 0, 4, 177, 4, 7, 247, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 7, 247, 6, 0, 4, 177, 4, 148, 247, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 148, 247, 6, 0, 4, 177, 4, 149, 247, 6, 0, 4, 177, 63, 175, 244, 176, 177, 4, 149, 247, 6, 0, 4, 177, 84, 177, 4, 7, 255, 6, 0, 4, 177, 63, 175, 244, 176, 177, 84, 7, 256, 6, 0, 34, 173, 244, 174, 7, 247, 6, 0, 49, 34, 173, 244, 174, 7, 253, 6, 0, 64, 34, 253, 7, 179, 244, 178, 244, 178, 244, 180, 6, 0, 41, 42, 253, 7, 244, 6, 0, 34, 179, 244, 180, 6, 0, 37, 173, 244, 174, 7, 253, 6, 0, 39, 173, 244, 174, 7, 253, 6, 0, 64, 37, 253, 7, 179, 244, 178, 244, 178, 244, 180, 6, 0, 35, 173, 244, 174, 7, 253, 6, 0, 35, 173, 244, 174, 7, 253, 45, 247, 6, 0, 43, 173, 244, 174, 7, 179, 244, 178, 244, 178, 5, 178, 5, 178, 5, 180, 6, 0, 36, 173, 244, 174, 7, 253, 6, 0, 49, 37, 173, 244, 174, 7, 253, 6, 0, 37, 59, 173, 244, 174, 7, 253, 6, 0, 78, 173, 244, 174, 7, 253, 6, 0, 79, 173, 244, 174, 7, 253, 83, 253, 80, 244, 6, 0, 37, 179, 244, 180, 6, 0, 45, 38, 173, 244, 174, 7, 253, 6, 0, 138, 38, 173, 244, 174, 7, 244, 253, 6, 0, 46, 38, 173, 244, 174, 7, 253, 6, 0, 79, 38, 81, 82, 173, 244, 174, 7, 251, 83, 179, 253, 178, 253, 180, 80, 179, 244, 178, 244, 180, 6, 0, 79, 38, 173, 244, 174, 7, 251, 83, 179, 253, 178, 253, 180, 80, 179, 244, 178, 244, 180, 6, 0, 49, 38, 173, 244, 174, 7, 253, 6, 0, 38, 59, 173, 244, 174, 7, 253, 6, 0, 38, 179, 244, 180, 6, 0, 48, 40, 173, 244, 174, 7, 253, 6, 0, 40, 173, 244, 174, 7, 253, 6, 0, 49, 40, 173, 244, 174, 7, 253, 6, 0, 54, 247, 179, 232, 180, 0, 53, 179, 247, 178, 247, 178, 244, 180, 179, 232, 180, 0, 55, 247, 179, 232, 180, 0, 56, 179, 247, 178, 244, 180, 179, 232, 180, 0, 234, 0, 233, 0, 231, 0, 0, 233, 230, 0, 58, 179, 233, 180, 0, 61, 179, 233, 180, 0, 4, 258, 6, 0, 4, 244, 6, 0, 90, 6, 0, 33, 6, 0, 85, 173, 244, 8, 244, 174, 0, 85, 173, 244, 8, 244, 8, 244, 174, 0, 85, 4, 86, 179, 244, 8, 244, 180, 0, 85, 4, 86, 179, 244, 8, 244, 8, 244, 180, 0, 87, 0, 92, 0, 93, 4, 6, 0, 94, 4, 0, 88, 173, 244, 174, 0, 89, 0, 57, 34, 179, 244, 178, 247, 180, 6, 0, 57, 34, 179, 244, 178, 247, 178, 247, 178, 244, 180, 6, 0, 57, 37, 179, 244, 178, 247, 180, 6, 0, 57, 37, 179, 244, 178, 247, 178, 247, 178, 244, 180, 6, 0, 57, 38, 179, 244, 178, 247, 180, 6, 0, 57, 38, 179, 244, 178, 247, 178, 247, 178, 244, 180, 6, 0, 57, 38, 179, 244, 178, 247, 180, 179, 239, 180, 6, 0, 57, 38, 179, 244, 178, 247, 178, 247, 178, 244, 180, 179, 239, 180, 6, 0, 240, 0, 239, 240, 0, 65, 179, 253, 178, 253, 178, 253, 180, 6, 0, 60, 6, 0, 47, 37, 253, 7, 244, 6, 0, 47, 37, 253, 7, 244, 50, 52, 244, 6, 0, 47, 37, 253, 7, 244, 50, 51, 244, 6, 0, 47, 38, 179, 244, 180, 7, 253, 6, 0, 44, 38, 179, 244, 180, 7, 253, 6, 0, 47, 40, 179, 244, 180, 7, 253, 6, 0, 60, 38, 253, 7, 244, 6, 0, 60, 38, 253, 6, 0, 62, 6, 0, 98, 0, 99, 0, 100, 0, 101, 0, 102, 0, 245, 0, 173, 244, 174, 0, 163, 244, 0, 162, 244, 0, 168, 244, 0, 244, 163, 244, 0, 244, 162, 244, 0, 244, 164, 244, 0, 244, 165, 244, 0, 244, 166, 244, 0, 244, 172, 244, 0, 244, 158, 244, 0, 244, 160, 244, 0, 244, 159, 244, 0, 244, 161, 244, 0, 244, 155, 244, 0, 244, 156, 244, 0, 244, 154, 244, 0, 244, 153, 244, 0, 244, 152, 244, 8, 244, 0, 10, 173, 244, 174, 0, 11, 173, 244, 174, 0, 12, 173, 244, 174, 0, 13, 173, 244, 174, 0, 14, 173, 244, 174, 0, 15, 173, 244, 174, 0, 16, 173, 244, 174, 0, 17, 173, 244, 174, 0, 18, 173, 244, 174, 0, 20, 173, 244, 174, 0, 21, 173, 244, 178, 244, 174, 0, 22, 173, 244, 174, 0, 23, 173, 244, 174, 0, 24, 173, 244, 174, 0, 25, 173, 244, 174, 0, 26, 173, 244, 174, 0, 27, 173, 244, 174, 0, 28, 173, 244, 178, 244, 174, 0, 29, 173, 244, 178, 244, 174, 0, 30, 173, 244, 178, 244, 174, 0, 19, 173, 244, 174, 0, 3, 0, 9, 0, 4, 0, 4, 175, 244, 176, 0, 4, 169, 0, 4, 175, 244, 176, 169, 0, 4, 170, 0, 4, 175, 244, 176, 170, 0, 4, 177, 4, 0, 4, 177, 63, 175, 244, 176, 177, 4, 0, 4, 177, 4, 169, 0, 4, 177, 63, 175, 244, 176, 177, 4, 169, 0, 4, 177, 4, 170, 0, 4, 177, 63, 175, 244, 176, 177, 4, 170, 0, 244, 8, 244, 0, 244, 8, 244, 8, 244, 0, 248, 0, 163, 247, 0, 162, 247, 0, 247, 163, 247, 0, 247, 162, 247, 0, 179, 244, 178, 244, 178, 244, 178, 244, 178, 244, 180, 0, 179, 244, 178, 244, 178, 244, 178, 244, 180, 0, 179, 244, 178, 244, 178, 244, 180, 0, 173, 244, 178, 244, 178, 244, 174, 0, 4, 177, 4, 0, 4, 177, 63, 175, 244, 176, 177, 4, 0, 0, 173, 250, 174, 0, 5, 0, 250, 178, 5, 0, 0, 179, 252, 180, 0, 173, 252, 174, 0, 253, 0, 252, 178, 253, 0, 0, 244, 0, 4, 175, 176, 0, 179, 254, 180, 0, 244, 0, 246, 0, 4, 175, 176, 0, 254, 178, 244, 0, 254, 178, 246, 0, 254, 178, 4, 175, 176, 0, 179, 244, 178, 244, 178, 244, 178, 244, 180, 0, 179, 244, 178, 244, 178, 244, 180, 0, 179, 4, 178, 244, 180, 0, 4, 0, 4, 177, 84, 177, 4, 0, 179, 257, 180, 0, 4, 177, 63, 175, 244, 176, 177, 84, 0, 255, 0, 257, 178, 255, 0, 5, 0, 32, 173, 5, 174, 0, 32, 173, 5, 178, 254, 174, 0 }; #endif #if YYDEBUG != 0 static const short yyrline[] = { 0, 144, 146, 147, 154, 162, 176, 188, 190, 193, 195, 196, 197, 200, 206, 211, 212, 213, 216, 220, 223, 229, 234, 240, 248, 253, 257, 263, 268, 272, 277, 281, 284, 289, 293, 297, 301, 306, 310, 313, 317, 321, 325, 329, 333, 337, 340, 344, 347, 351, 354, 363, 367, 373, 375, 376, 377, 378, 379, 380, 381, 382, 383, 384, 385, 386, 389, 394, 423, 428, 434, 439, 440, 441, 442, 443, 444, 445, 446, 447, 448, 449, 450, 453, 456, 460, 466, 472, 475, 479, 485, 491, 494, 498, 504, 510, 513, 517, 525, 531, 534, 538, 546, 552, 555, 559, 567, 573, 576, 580, 592, 598, 601, 605, 617, 623, 626, 630, 642, 648, 651, 655, 668, 674, 677, 681, 694, 700, 703, 707, 720, 732, 748, 760, 769, 781, 789, 801, 809, 821, 829, 841, 849, 861, 873, 892, 905, 923, 940, 961, 978, 999, 1016, 1037, 1054, 1075, 1096, 1122, 1139, 1160, 1177, 1200, 1225, 1254, 1279, 1308, 1333, 1364, 1377, 1402, 1413, 1419, 1438, 1449, 1457, 1463, 1469, 1488, 1494, 1510, 1517, 1523, 1529, 1535, 1541, 1560, 1572, 1578, 1597, 1618, 1626, 1632, 1638, 1644, 1656, 1662, 1668, 1680, 1686, 1691, 1696, 1703, 1705, 1706, 1709, 1714, 1725, 1743, 1758, 1830, 1850, 1854, 1873, 1889, 1903, 1928, 1953, 1979, 1984, 1989, 1996, 2000, 2010, 2016, 2022, 2026, 2030, 2034, 2038, 2043, 2050, 2054, 2059, 2077, 2087, 2105, 2122, 2139, 2160, 2180, 2200, 2217, 2241, 2254, 2256, 2257, 2258, 2259, 2262, 2264, 2265, 2266, 2267, 2268, 2269, 2270, 2271, 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, 2314, 2319, 2323, 2335, 2353, 2365, 2383, 2395, 2415, 2436, 2460, 2481, 2505, 2526, 2551, 2558, 2571, 2578, 2582, 2586, 2590, 2595, 2600, 2604, 2608, 2612, 2644, 2681, 2685, 2690, 2694, 2699, 2703, 2707, 2713, 2719, 2725, 2729, 2735, 2750, 2757, 2763, 2772, 2784, 2788, 2796, 2809, 2814, 2818, 2823, 2828, 2847, 2852, 2873, 2882, 2888, 2893, 2897 }; #endif #if YYDEBUG != 0 || defined (YYERROR_VERBOSE) static const char * const yytname[] = { "$","error","$undefined.","tDOUBLE", "tSTRING","tBIGSTR","tEND","tAFFECT","tDOTS","tPi","tExp","tLog","tLog10","tSqrt", "tSin","tAsin","tCos","tAcos","tTan","tRand","tAtan","tAtan2","tSinh","tCosh", "tTanh","tFabs","tFloor","tCeil","tFmod","tModulo","tHypot","tPrintf","tSprintf", "tDraw","tPoint","tCircle","tEllipsis","tLine","tSurface","tSpline","tVolume", "tCharacteristic","tLength","tParametric","tElliptic","tPlane","tRuled","tTransfinite", "tComplex","tPhysical","tUsing","tBump","tProgression","tRotate","tTranslate", "tSymmetry","tDilate","tExtrude","tDuplicata","tLoop","tRecombine","tDelete", "tCoherence","tView","tAttractor","tLayers","tScalarTetrahedron","tVectorTetrahedron", "tTensorTetrahedron","tScalarTriangle","tVectorTriangle","tTensorTriangle","tScalarLine", "tVectorLine","tTensorLine","tScalarPoint","tVectorPoint","tTensorPoint","tBSpline", "tNurbs","tOrder","tWith","tBounds","tKnots","tColor","tFor","tIn","tEndFor", "tIf","tEndIf","tExit","tMerge","tReturn","tCall","tFunction","tB_SPLINE_SURFACE_WITH_KNOTS", "tB_SPLINE_CURVE_WITH_KNOTS","tCARTESIAN_POINT","tTRUE","tFALSE","tUNSPECIFIED", "tU","tV","tEDGE_CURVE","tVERTEX_POINT","tORIENTED_EDGE","tPLANE","tFACE_OUTER_BOUND", "tEDGE_LOOP","tADVANCED_FACE","tVECTOR","tDIRECTION","tAXIS2_PLACEMENT_3D","tISO", "tENDISO","tENDSEC","tDATA","tHEADER","tFILE_DESCRIPTION","tFILE_SCHEMA","tFILE_NAME", "tMANIFOLD_SOLID_BREP","tCLOSED_SHELL","tADVANCED_BREP_SHAPE_REPRESENTATION", "tFACE_BOUND","tCYLINDRICAL_SURFACE","tCONICAL_SURFACE","tCIRCLE","tTRIMMED_CURVE", "tGEOMETRIC_SET","tCOMPOSITE_CURVE_SEGMENT","tCONTINUOUS","tCOMPOSITE_CURVE", "tTOROIDAL_SURFACE","tPRODUCT_DEFINITION","tPRODUCT_DEFINITION_SHAPE","tSHAPE_DEFINITION_REPRESENTATION", "tELLIPSE","tTrimmed","tSolid","tEndSolid","tVertex","tFacet","tNormal","tOuter", "tLoopSTL","tEndLoop","tEndFacet","tAFFECTPLUS","tAFFECTMINUS","tAFFECTTIMES", "tAFFECTDIVIDE","'?'","tOR","tAND","tEQUAL","tNOTEQUAL","tAPPROXEQUAL","'<'", "tLESSOREQUAL","'>'","tGREATEROREQUAL","'+'","'-'","'*'","'/'","'%'","tCROSSPRODUCT", "'!'","tPLUSPLUS","tMINUSMINUS","UNARYPREC","'^'","'('","')'","'['","']'","'.'", "','","'{'","'}'","All","STLFormatItem","StepFormatItems","StepFormatItem","StepSpecial", "StepHeaderItem","StepDataItem","GeomFormatList","GeomFormat","Printf","View", "Views","ScalarPointValues","ScalarPoint","@1","VectorPointValues","VectorPoint", "@2","TensorPointValues","TensorPoint","@3","ScalarLineValues","ScalarLine", "@4","VectorLineValues","VectorLine","@5","TensorLineValues","TensorLine","@6", "ScalarTriangleValues","ScalarTriangle","@7","VectorTriangleValues","VectorTriangle", "@8","TensorTriangleValues","TensorTriangle","@9","ScalarTetrahedronValues", "ScalarTetrahedron","@10","VectorTetrahedronValues","VectorTetrahedron","@11", "TensorTetrahedronValues","TensorTetrahedron","@12","Affectation","Shape","Transform", "MultipleShape","ListOfShapes","Duplicata","Delete","Command","Loop","Extrude", "ExtrudeParameters","ExtrudeParameter","Transfini","Coherence","BoolExpr","FExpr", "FExpr_Single","FExpr_Range","VExpr","VExpr_Single","ListOfStrings","RecursiveListOfStrings", "ListOfListOfDouble","RecursiveListOfListOfDouble","ListOfDouble","RecursiveListOfDouble", "ColorExpr","ListOfColor","RecursiveListOfColor","StringExpr", NULL }; #endif static const short yyr1[] = { 0, 181, 181, 181, 182, 182, 182, 183, 183, 184, 184, 184, 184, 185, 185, 185, 185, 185, 186, 186, 186, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 187, 188, 188, 189, 189, 189, 189, 189, 189, 189, 189, 189, 189, 189, 189, 189, 190, 190, 191, 191, 192, 192, 192, 192, 192, 192, 192, 192, 192, 192, 192, 192, 192, 193, 193, 195, 194, 196, 196, 198, 197, 199, 199, 201, 200, 202, 202, 204, 203, 205, 205, 207, 206, 208, 208, 210, 209, 211, 211, 213, 212, 214, 214, 216, 215, 217, 217, 219, 218, 220, 220, 222, 221, 223, 223, 225, 224, 226, 226, 228, 227, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 230, 231, 231, 231, 231, 232, 232, 232, 233, 233, 234, 235, 236, 236, 236, 236, 237, 237, 237, 237, 237, 237, 237, 237, 237, 237, 238, 238, 238, 238, 238, 238, 238, 238, 239, 239, 240, 240, 241, 241, 241, 241, 241, 241, 241, 241, 242, 243, 243, 243, 243, 243, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 244, 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 245, 246, 246, 247, 247, 247, 247, 247, 248, 248, 248, 248, 248, 248, 249, 249, 250, 250, 251, 251, 251, 252, 252, 253, 253, 253, 253, 254, 254, 254, 254, 254, 254, 255, 255, 255, 255, 255, 256, 256, 257, 257, 258, 258, 258 }; static const short yyr2[] = { 0, 1, 1, 1, 1, 21, 1, 0, 2, 1, 1, 1, 2, 2, 2, 2, 2, 2, 7, 5, 17, 9, 23, 31, 15, 11, 11, 15, 9, 13, 9, 11, 13, 9, 9, 11, 9, 11, 9, 11, 13, 13, 11, 13, 17, 9, 11, 11, 13, 11, 9, 0, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 5, 7, 6, 8, 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 3, 0, 13, 1, 3, 0, 13, 1, 3, 0, 13, 1, 3, 0, 19, 1, 3, 0, 19, 1, 3, 0, 19, 1, 3, 0, 25, 1, 3, 0, 25, 1, 3, 0, 25, 1, 3, 0, 31, 1, 3, 0, 31, 1, 3, 0, 31, 4, 7, 3, 6, 3, 6, 4, 7, 4, 7, 4, 7, 4, 7, 6, 11, 6, 11, 6, 11, 6, 11, 6, 11, 6, 11, 5, 11, 5, 11, 6, 11, 6, 11, 6, 11, 8, 11, 7, 8, 12, 6, 5, 7, 7, 12, 7, 9, 17, 7, 8, 8, 7, 11, 5, 8, 9, 8, 22, 20, 8, 8, 5, 8, 7, 8, 5, 11, 5, 9, 1, 1, 1, 0, 2, 4, 4, 3, 3, 2, 2, 6, 8, 8, 10, 1, 1, 3, 2, 4, 1, 8, 12, 8, 12, 8, 12, 11, 15, 1, 2, 9, 2, 6, 9, 9, 8, 8, 8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 3, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 5, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 6, 4, 4, 4, 4, 4, 4, 6, 6, 6, 4, 1, 1, 1, 4, 2, 5, 2, 5, 3, 8, 4, 9, 4, 9, 3, 5, 1, 2, 2, 3, 3, 11, 9, 7, 7, 3, 8, 0, 3, 1, 3, 0, 3, 3, 1, 3, 0, 1, 3, 3, 1, 1, 3, 3, 3, 5, 9, 7, 5, 1, 5, 3, 8, 1, 3, 1, 4, 6 }; static const short yydefact[] = { 51, 4, 6, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 9, 11, 10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 216, 0, 221, 0, 217, 0, 0, 0, 52, 54, 53, 55, 56, 57, 58, 59, 64, 63, 60, 61, 62, 289, 291, 290, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 248, 12, 0, 13, 14, 16, 15, 17, 316, 316, 0, 65, 344, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 211, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 305, 0, 0, 0, 0, 0, 204, 325, 204, 242, 0, 325, 325, 0, 0, 0, 0, 0, 0, 210, 0, 219, 0, 293, 295, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 251, 250, 252, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 133, 135, 0, 0, 0, 0, 209, 0, 0, 208, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 291, 0, 326, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 307, 306, 0, 0, 0, 0, 204, 204, 0, 0, 0, 0, 0, 0, 0, 0, 70, 0, 0, 0, 0, 0, 0, 0, 0, 0, 218, 0, 0, 297, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 249, 0, 266, 265, 263, 264, 259, 261, 260, 262, 251, 250, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 318, 0, 0, 0, 0, 131, 0, 137, 139, 141, 143, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 254, 253, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 291, 329, 330, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 314, 0, 0, 0, 309, 308, 203, 0, 202, 201, 0, 0, 0, 0, 0, 206, 205, 241, 0, 207, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 220, 0, 292, 299, 301, 0, 268, 269, 270, 271, 272, 273, 274, 275, 276, 288, 277, 0, 279, 280, 281, 282, 283, 284, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 317, 0, 0, 19, 0, 345, 0, 0, 0, 0, 0, 0, 0, 0, 291, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 157, 159, 0, 0, 66, 0, 0, 173, 325, 325, 0, 325, 185, 0, 193, 325, 325, 327, 0, 0, 0, 328, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 197, 199, 0, 0, 0, 0, 0, 70, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 0, 0, 325, 0, 0, 325, 0, 0, 0, 294, 296, 0, 0, 0, 0, 0, 267, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 325, 0, 0, 0, 0, 325, 325, 0, 0, 0, 0, 0, 325, 0, 325, 0, 0, 0, 0, 0, 319, 0, 316, 0, 0, 0, 0, 0, 0, 134, 136, 0, 145, 0, 147, 161, 149, 163, 151, 165, 153, 155, 0, 0, 0, 0, 0, 0, 325, 0, 325, 0, 0, 331, 303, 291, 332, 333, 172, 0, 325, 325, 325, 234, 0, 325, 325, 325, 325, 325, 325, 325, 0, 0, 0, 0, 0, 0, 0, 0, 240, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 68, 0, 0, 0, 0, 320, 0, 0, 0, 212, 0, 0, 278, 285, 286, 287, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 243, 244, 245, 246, 247, 0, 0, 0, 0, 0, 0, 0, 18, 0, 346, 132, 138, 140, 142, 144, 297, 0, 0, 338, 0, 0, 67, 169, 177, 0, 180, 0, 174, 0, 175, 195, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 204, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 183, 0, 325, 325, 0, 325, 0, 0, 325, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 316, 0, 0, 0, 0, 291, 0, 167, 0, 182, 192, 304, 334, 0, 238, 186, 188, 0, 0, 237, 239, 194, 170, 181, 191, 196, 0, 0, 313, 0, 312, 0, 0, 222, 0, 224, 0, 226, 0, 69, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 320, 0, 323, 0, 0, 0, 0, 214, 213, 0, 298, 0, 0, 0, 0, 21, 0, 30, 0, 34, 0, 28, 0, 0, 33, 0, 38, 36, 0, 0, 0, 0, 0, 0, 45, 0, 0, 0, 0, 0, 50, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 178, 0, 236, 235, 204, 315, 0, 200, 0, 0, 0, 0, 0, 0, 230, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 322, 325, 321, 325, 0, 0, 187, 300, 302, 0, 0, 320, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 311, 0, 0, 0, 233, 325, 0, 231, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 324, 0, 0, 215, 0, 35, 0, 0, 0, 0, 25, 0, 31, 0, 37, 26, 39, 0, 42, 0, 46, 47, 0, 0, 49, 0, 0, 0, 146, 148, 162, 150, 164, 152, 166, 154, 156, 158, 160, 0, 342, 0, 168, 339, 337, 0, 0, 198, 0, 0, 0, 0, 0, 228, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 325, 184, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 298, 0, 0, 340, 0, 0, 310, 223, 225, 227, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 85, 89, 93, 171, 176, 0, 0, 0, 0, 0, 0, 0, 29, 32, 40, 0, 41, 48, 43, 0, 0, 343, 0, 336, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 24, 27, 0, 0, 0, 335, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 83, 0, 87, 0, 91, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 44, 20, 341, 179, 232, 0, 0, 0, 0, 0, 0, 0, 0, 0, 84, 86, 88, 90, 92, 94, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 97, 101, 105, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 190, 0, 0, 0, 0, 0, 0, 0, 0, 0, 95, 0, 99, 0, 103, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 189, 0, 22, 0, 0, 0, 0, 0, 0, 96, 98, 100, 102, 104, 106, 325, 0, 0, 0, 109, 113, 117, 0, 0, 0, 0, 0, 0, 0, 325, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 107, 0, 111, 0, 115, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 108, 110, 112, 114, 116, 118, 0, 121, 125, 129, 23, 0, 0, 0, 0, 0, 0, 0, 119, 0, 123, 0, 127, 0, 0, 0, 0, 0, 0, 120, 122, 124, 126, 128, 130, 0, 0, 0 }; static const short yydefgoto[] = { 1565, 4, 5, 18, 19, 20, 21, 6, 63, 64, 65, 486, 1341, 641, 1289, 1343, 642, 1290, 1345, 643, 1291, 1449, 644, 1422, 1451, 645, 1423, 1453, 646, 1424, 1510, 647, 1496, 1512, 648, 1497, 1514, 649, 1498, 1547, 650, 1541, 1549, 651, 1542, 1551, 652, 1543, 66, 481, 471, 472, 473, 474, 70, 71, 72, 73, 1055, 1056, 74, 75, 820, 295, 105, 449, 311, 163, 262, 411, 896, 988, 989, 450, 840, 1118, 1189, 129 }; static const short yypact[] = { 432, -32768,-32768, -115,-32768, 44, 2780, 1830, 50, 52, 104, 159, 164, 170, 172, -73, -52, -17,-32768,-32768,-32768, -32768, 201, 1572, 51, 226, -87, 82, 97, -37, -38, 105, 110, 260, 138, 285, 295, 320, 272, 319, 370, 191, 94, 94, 202, 357, 214, 337, 219, 400, 406, 323, 255, -30, 2,-32768, 261,-32768, 419,-32768, 434, 437, 417,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768, 254,-32768, 291, 302, 338, 348, 362, 369, 394, 396, 402, 403, 407, 418, 433, 435, 436, 443, 444, 445, 446, 447, 448, 1830, 1830, 1830, 1830, 1664,-32768,-32768, 2818,-32768,-32768,-32768, -32768,-32768, 449, 449, 462,-32768,-32768, 1830, 450, 1830, 1830, 1830, 1830, 537, 590, 1830, 19, 1029, 601, 568, -32768, 1830, 1830, 1830, 1830, 451, 1830, 1830, 452, 1830, 1830, 1830, 778, 1830, 466, 453, 455, 778, 469, 471, 456, 457, 458, 478, 479, 94, 476, 94, 94, 1830, 1830, -133,-32768, -100, 94, 477, 481, 482,-32768, 778, -32768,-32768, -2, 778, 778, 1830, -68, 1830, 526, 1830, 1830,-32768, 649,-32768, 489,-32768,-32768, 1830, 10, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 491, 491, 491, 5757, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1664, 494, 495, 496, 501, 502, 525, 529, 530, 531, 554, 555, 556, 557, 558, 559, 561, 563, 564, 565, 566, 569, 570, 571, 572, 577, 578, 579, 580, 581, 582, 735, 591, 594, 592, 1117, 736, 1162, 1368, 1552, 1599, -32768,-32768, 5582, 111, 596, 595,-32768, 1830, 1830,-32768, -6, 5780, 2862, 5803, 5826, 1830, 5849, 2885, 1830, 2908, 5872, 5895, 273, 1877, 7229, 766, 5918, 1830, 1830, 1830, 767, 1830, 1830, 1830, 1830, 1830, 1830, 1830, -93, 13, -32768,-32768, 3341, 3362, 94, 94, 424, 424, -91, 1830, 1830, 1830, 2711, 31, 2728, 94,-32768, 770, 772, 5941, 698, 1830, 5964, 604, 1311, 5987,-32768, 1830, 5607, 315, 610, 6010, 6033, 6056, 6079, 6102, 6125, 6148, 6171, 6194, 6217, 6240, 3383, 6263, 6286, 6309, 6332, 6355, 6378, 3404, 3425, 3446,-32768, 2465, 1278, 423, 439, 439, 155, 155, 155, 155, -138, -27, 491, 491, 491, 491, 2931, 781, 804, 805, 806, 807, 808, 809, 810, 811, 812, 813, 814, 816, 817, 818, 819, 820, 821, 822, 823, 826, 828, 831, 706, 833, 834, 836, 837, 840, 842,-32768, 116, 843, 846, 844,-32768, 148,-32768,-32768,-32768,-32768, 115, 667, 984, 984, 1830, 1830, 847, 848, 1830, 851, 281, 281, 850, 1877, 853, 856, 859, 860, 6401, 861, 864, 6424, 865, 866, 867, 326, 282, 2499,-32768, -130, 1830, 869, 2946, 6447, 6470, 1830, 2969, 2992, 6493, 6516, 6539, 6562, 6585, 94,-32768, 682, 1830, 1830,-32768,-32768, -32768, 692, 2841,-32768, 697, 1830, 3467, 3488, 3509,-32768, -32768,-32768, 1830,-32768, -98, 567, 699, 700, 873, 708, 6608, 875, 1830, 1830,-32768, 6631, 331,-32768,-32768, 1830, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768, 1830,-32768,-32768,-32768,-32768,-32768,-32768, 1830, 1830, 1830, 1830, 740, 709, 710, 711, 712, 713, 714, 715, 716, 718, 720, 721, 723, 724, 725, 726, 727, 728, 730, 731, 732, 733, 734, 739, 741, 742, 744, 745, 746, 748, 750,-32768, 881, 755,-32768, 752,-32768, 1877, 1830, 1830, 1830, 1830, 1830, 907, 912, 293, 925, 984, 984, 1830, 1855, 4, 1870, 43, 1958, 68, 1973, 1988, -32768,-32768, 5632, 926,-32768, 150, 94,-32768, 778, 778, 927, 778,-32768, 928,-32768, 778, 778,-32768, 1606, 1830, 1905,-32768, 2031, 753, 929, 930, 931, 894, 935, 936, 938, 940, 941, 942, 943, -79, 1830, 3530, 3551,-32768, -32768, 3015, 94, 94, 94, 2046,-32768, 780, 783, 785, 786, 787, 788, 789, 790, 791, 792, 845, 858, 948, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768, 1830, 1830, 778, 1830, 971, 778, 2557, 944, 972,-32768,-32768, 5657, 6654, 6677, 6700, 6723, 7229, 839, 978, 1830, 1830, 94, 979, 980, 825, 981, 982, 778, 778, 987, 94, 989, 1012, 778, 778, 1013, 1014, 1016, 1017, 1033, 778, 408, 778, 1034, 1027, 1035, 1036, 1038, -32768, 1032, 449, 231, 2068, 2083, 2098, 2149, 2164,-32768, -32768, 14,-32768, 3314,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768, 874, 0, 1055, 106, 9, 1058, 778, 1059, 778, 1061, 1062,-32768, 2572, 296, 2499,-32768,-32768, 1830, 778, 778, 778,-32768, 39, 778, 778, 778, 778, 778, 778, 778, 1830, 5682, 1830, 1830, 863, -127, -123, -120, -32768, 1188, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830,-32768, 3572, 3593, 1064, 6746, -50, 988, 1830, 1830,-32768, 1830, 895,-32768,-32768,-32768,-32768, 1830, 897, 3614, 3635, -96, 899, 904, 905, 908, 906, 911, 910, 913, 112, 915, 916, 920, 923, 933, 934, 937, 946, 947, 939,-32768,-32768,-32768,-32768,-32768, 960, 962, 963, 965, 966, 945, 970,-32768, 973,-32768,-32768, -32768,-32768,-32768,-32768, 315, 914, 22, 909, 1933, 1108, -32768,-32768,-32768, 94,-32768, 1114,-32768, 1115,-32768,-32768, 1830, 1634, 3656, 1116, 1143, 1144, 1830, 1830, 1147, 1148, 1149, 1150, 1152, 1153, 1154, 3038, 985, 6769, 1044, 424, 94, 1155, 94, 1160, 94, 3, 1161, 3677, 3698, 3719, 3740, 3761, 3782, 3803, 3824, 3845, 3866, 3887, 3908, 1830, 1830,-32768, 1165, 778, 778, 1086, 778, 364, 6792, 224, 1169, 1664, 1171, 1830, 778, 1170, 1172, 1174, 1047, 1208, 408, 1211, 1175, 1830, 1212, 1216, 1214, 1215, 1220, 408, 1830, 1830, 1830, 778, 1222, 1226, 408, 1830, 1243, 1244, 1242, 1830, 449, 1830, 251, 1245, 1166, 196, 3929,-32768, 114,-32768,-32768, 7229,-32768, 1830,-32768,-32768,-32768, 2207, 2259,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 1070, 1247, -32768, 1830,-32768, 1087, -74,-32768, -61,-32768, -54,-32768, 15,-32768, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 3950, 3971, -50, 252,-32768, 154, 1095, 1204, 1830,-32768,-32768, 1279, 334, 1664, 1112, 3992, 1109,-32768, 1110,-32768, 1113,-32768, 1118,-32768, 1119, 6815, -32768, 1120,-32768,-32768, 1121, 1122, 6838, 4013, 6861, 1133, -32768, 1138, 1156, 4034, 1151, 1157,-32768, 4055, 1158, 5707, 696, 984, 984, 1830, 1830, 1830, 1830, 1, 1163, 1830, 1830,-32768, 4076,-32768,-32768, 424,-32768, 2804,-32768, 1830, 1830, 1830, 1284, 1159, -41,-32768, 4097, 4118, 4139, 4160, 4181, 4202, 4223, 4244, 4265, 4286, 4307, 4328, 1830, 1830, 1210,-32768, 778,-32768, 778, 1830, 3061,-32768,-32768,-32768, 2435, 1288, -50, 408, 1329, 1830, 1327, 408, 1331, 1332, 1333, 1337, 1338, 1830, 1339, 778, 1340, 1341, 1830, 1345, 1343, 1830, 1355, 1185, 1358, 2274, 126, 2289, 141, 2325, 145, 2340, 2368, 2383, 2398, 1189, 0, 1359, 1365, 3084, 4349, 1366, 1190, 1830,-32768, 3107, 3130, 3153,-32768, 778, 1367,-32768, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 3176, 3199, 1193,-32768, 1197, 2450, -32768, 1830,-32768, 1198, 1199, 1200, 4370,-32768, 1205,-32768, 1206,-32768,-32768,-32768, 6884,-32768, 1207,-32768,-32768, 6907, 1209,-32768, 6930, 1223, 1378,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768, 1323,-32768, 189,-32768, -32768,-32768, 1830, 1224,-32768, 3222, 1381, 1382, 25, 1225, -32768, 4391, 4412, 4433, 4454, 4475, 4496, 4517, 4538, 4559, 6953, 6976, 6999, 1386, 1387, 778, 778,-32768, 1664, 408, 408, 408, 408, 1388, 1398, 1399, 408, 1400, 1401, 1403, 1405, 334, 1236, 0,-32768, 2833, 1407,-32768,-32768,-32768, -32768, 15, 778, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830,-32768,-32768,-32768,-32768,-32768, 1235, 1234, 1664, 1237, 1238, 1246, 1248,-32768,-32768,-32768, 1239,-32768,-32768, -32768, 1241, 1830,-32768, 1830,-32768, 1257, -40, 1267, 4580, 4601, 4622, 4643, 4664, 4685, 4706, 4727, 4748, 1268, 1269, 1270, 778, 1380, 2525, 408, 408, 1415, 1440, 408, 1453, 5732, 3245, 1457, 1462, 778, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1298, 1303, 1830, 1306, 1307,-32768,-32768, 1312, 1313, 1314,-32768, 1308,-32768, 1309, 4769, 4790, 4811, 4832, 4853, 4874, 4895, 4916, 4937, 278, 7229, 294, 7229, 303, 7229, 1410, 1830, 1664, 408, 778, 1486, 1493, 1416, 1495, 1496, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1497, 1830, 1498, 1830, 1499, 1328, 4958, 1664, 1330, 1336,-32768,-32768,-32768,-32768, -32768, 4979, 5000, 5021, 5042, 5063, 5084, 7022, 7045, 7068, 7229,-32768, 7229,-32768, 7229,-32768, 1830, 1830, 5105, 408, 778, 1830, 1830, 1830, 1830, 1830, 1830,-32768,-32768,-32768, 5120, 3268, 1362, 1347, 1357, 5141, 5162, 5183, 5204, 5225, 5246, 1363, 1364, 1370, 1830, 1500,-32768, 778, 408, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 3291,-32768, 1369, 1342, 5267, 5288, 5309, 5330, 5351, 5372, 312, 7229, 317, 7229, 318, 7229, 1512, 778, 1513, 1830, 1830, 1830, 1830, 1830, 1830, 1830, 1530, 1830, 1535, 1830, 1538,-32768, 1373,-32768, 5393, 5414, 5435, 7091, 7114, 7137, 7229,-32768, 7229,-32768, 7229,-32768, 778, 1830, 1830, 1830,-32768,-32768, -32768, 1374, 5456, 5477, 5498, 1375, 1376, 1377, 778, 1830, 1830, 1830, 1830, 1830, 1830, 1383, 5519, 5540, 5561, 353, 7229, 354, 7229, 359, 7229, 408, 1830, 1830, 1830, 1830, 1539, 1830, 1547, 1830, 1554, 1389, 7160, 7183, 7206, 7229, -32768, 7229,-32768, 7229,-32768, 1556,-32768,-32768,-32768,-32768, 1385, 1390, 1391, 1830, 1830, 1830, 360, 7229, 382, 7229, 388, 7229, 1830, 1559, 1830, 1560, 1830, 1561, 7229,-32768, 7229,-32768, 7229,-32768, 1568, 1571,-32768 }; static const short yypgoto[] = {-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 951,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 1566, 1567, -311, -21, 1597,-32768,-32768,-32768,-32768, 332, -1052,-32768, -32768, -859, -7,-32768, 1005, -10,-32768, -113,-32768, -976, 717, 484, -422, -1090,-32768,-32768,-32768 }; #define YYLAST 7401 static const short yytable[] = { 104, 263, 326, 1132, 838, 1116, 179, 475, 177, 970, 716, 1071, 586, 331, 340, 843, 128, 465, 835, 1053, 1053, 139, 136, 274, 1054, 1054, 935, 1188, 7, 315, 316, 1241, 162, 164, 229, 315, 316, 482, 483, 315, 316, -254, 315, 316, -1, 8, 317, 9, 601, 718, 602, 871, 1007, 872, 844, 873, 106, 874, 875, 107, 876, 1016, 315, 316, 315, 316, 315, 316, 1023, 315, 316, 315, 316, 341, 720, 1053, 466, 836, 906, 318, 1054, 627, 275, 315, 316, 464, 132, 476, 315, 316, 857, 858, 133, 211, 212, 213, 214, 230, 157, 753, 113, 315, 316, 276, 1050, 332, 936, 1154, 315, 316, 108, 265, 842, 267, 268, 269, 270, 1051, 422, 273, 1042, 114, 561, 894, 1052, 282, 283, 284, 285, 895, 287, 288, 1178, 290, 291, 292, 137, 297, 704, 1131, 1304, 140, 138, 178, 1274, 229, 309, 1180, 323, 312, 325, 1182, -253, 313, 314, 319, 115, 10, 11, 12, 13, 14, 15, 16, 17, 109, 315, 316, 433, 330, 110, 333, 434, 335, 336, 180, 111, 327, 112, 839, 1117, 339, 971, 342, 343, 344, 345, 346, 347, 348, 349, 350, 351, 352, 353, 354, 355, 356, 357, 358, 359, 360, 361, 362, 1242, 315, 316, 116, 364, 365, 366, 367, 368, 369, 370, 371, 372, 373, 374, 375, 376, 377, 378, 379, 130, 1155, 1132, 76, 293, 1159, 315, 316, 131, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 134, 158, 159, 1031, 423, 424, 425, 426, 562, 563, 564, 565, 160, 315, 316, 135, 431, 432, 161, 315, 316, 315, 316, 141, 439, 427, 428, 442, 142, 566, 567, 915, 448, 315, 316, 554, 453, 454, 455, 555, 457, 458, 459, 460, 461, 462, 463, 143, 315, 316, 469, 470, 315, 316, 148, 149, 144, 150, 477, 478, 479, 485, 278, 279, 226, 227, 228, 559, 145, 725, 491, 560, 229, 601, 76, 77, 496, 1073, 146, 1074, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 174, 147, 151, 175, 1261, 1262, 1263, 1264, 186, 187, 1234, 1268, 1235, 156, 188, 993, 189, 1040, 170, 215, 216, 217, 218, 219, 165, 220, 221, 222, 223, 224, 225, 226, 227, 228, 166, 102, 169, 167, 168, 229, 103, 171, 1032, 1033, 1034, 1035, 294, 152, 829, 172, 153, 154, 601, 155, 173, 574, 576, 578, 573, 575, 577, 579, 580, 1036, 1037, 583, 186, 187, 182, 1072, 448, 176, 188, 1073, 189, -7, -7, 181, -7, 1321, 1322, 183, 339, 1325, 184, 186, 187, 603, 226, 227, 228, 446, 608, 189, 186, 187, 229, 616, 185, 1366, 599, 1367, 189, 618, 619, 186, 187, 190, 186, 187, 264, 188, 622, 712, 852, 1368, 189, 1369, 191, 626, 41, 42, 43, 44, 1370, 46, 1371, 498, 499, 659, 660, 100, 101, 1464, 1375, 1465, 664, 102, 1466, 1468, 1467, 1469, 103, 662, 663, 598, 1079, 1080, 665, 815, 816, 817, 818, 819, 192, 666, 667, 668, 669, 215, 216, 217, 218, 219, 193, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1520, 1522, 1521, 1523, 194, 229, 1524, 1553, 1525, 1554, 1414, 195, 271, 994, -7, -7, -7, -7, -7, -7, -7, -7, 448, 705, 706, 707, 708, 709, 964, 1555, 312, 1556, 211, 212, 714, 1557, 196, 1558, 197, 1442, 1, 2, 281, 3, 198, 199, 726, 218, 219, 200, 220, 221, 222, 223, 278, 279, 226, 227, 228, 828, 201, 339, 735, 737, 229, 272, 220, 221, 222, 223, 278, 279, 226, 227, 228, 202, 280, 203, 204, 754, 229, 334, 758, 759, 760, 205, 206, 207, 208, 209, 210, 261, 266, 286, 289, 299, 296, 300, 304, 305, 306, 301, 628, 629, 630, 631, 632, 633, 634, 635, 636, 637, 638, 639, 298, 776, 777, 302, 779, 303, 307, 308, 310, 324, 337, 320, 1526, 328, 329, 321, 322, 338, 229, 795, 793, 794, 380, 381, 382, 76, 568, 569, 804, 383, 384, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 385, 76, 568, 1105, 386, 387, 388, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 389, 390, 391, 392, 393, 394, 853, 395, 1123, 396, 397, 398, 399, 410, 416, 400, 401, 402, 403, 866, 640, 868, 869, 404, 405, 406, 407, 408, 409, 878, 879, 880, 881, 882, 883, 884, 885, 886, 887, 888, 889, 413, 412, 414, 429, 430, 451, 456, 898, 899, 487, 900, 488, 490, 76, 293, 493, 902, 500, 524, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 525, 526, 527, 528, 529, 530, 531, 532, 533, 534, 535, 1029, 536, 537, 538, 539, 540, 541, 542, 543, 570, 571, 544, 939, 545, 941, 102, 546, 547, 548, 549, 572, 550, 551, 552, 944, 339, 161, 553, 556, 558, 950, 951, 557, 581, 582, 584, 585, 617, 570, 571, 587, 965, 588, 967, 102, 969, 589, 590, 592, 572, 593, 595, 620, 596, 597, 161, 604, 621, 653, 654, 655, 656, 658, 985, 986, 670, 701, 671, 672, 673, 674, 675, 676, 677, 678, 998, 679, 1000, 680, 681, 744, 682, 683, 684, 685, 686, 687, 1010, 688, 689, 690, 691, 692, 710, 1017, 1018, 1019, 693, 711, 694, 695, 1024, 696, 697, 698, 1028, 699, 1030, 700, 702, 703, 713, 740, 724, 729, 731, 741, 742, 743, 1043, 100, 101, 746, 747, 745, 748, 102, 749, 750, 751, 752, 103, 783, 763, 775, 1048, 764, 294, 765, 766, 767, 768, 769, 770, 771, 772, 1057, 1058, 1059, 1060, 1061, 1062, 1063, 1064, 1065, 1066, 1067, 1068, 780, 785, 791, 792, 796, 797, 799, 800, 1077, 76, 568, 798, 803, 1081, 805, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 806, 809, 810, 773, 811, 812, 1107, 1109, 1111, 1106, 1108, 1110, 1112, 1113, 1114, 1115, 774, 823, 1120, 1121, 277, 813, 822, 827, 825, 824, 826, 870, 1126, 1127, 1128, 215, 216, 217, 218, 219, 837, 220, 221, 222, 223, 278, 279, 226, 227, 228, 841, 1145, 1146, 845, 847, 229, 849, 850, 1150, 892, 897, 901, 727, 728, 903, 730, 907, 908, 1157, 732, 733, 910, 909, 911, 912, 937, 1165, 913, 934, 917, 914, 1170, 916, 918, 1173, 215, 216, 217, 218, 219, 919, 220, 221, 222, 223, 278, 279, 226, 227, 228, 920, 921, 925, 940, 922, 229, 1196, 784, 931, 942, 943, 947, 415, 923, 924, 1202, 1203, 1204, 1205, 1206, 1207, 1208, 1209, 1210, 1211, 1212, 1213, 926, 778, 927, 928, 781, 929, 930, 1219, 570, 571, 932, 948, 949, 933, 102, 952, 953, 954, 955, 572, 956, 957, 958, 966, 960, 161, 801, 802, 968, 972, 417, 991, 807, 808, 987, 997, 999, 1003, 1002, 814, 1009, 821, 1004, 215, 216, 217, 218, 219, 1236, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1005, 1260, 846, 1006, 848, 229, 1008, 1011, 1012, 1013, 1014, 962, 1015, 963, 854, 855, 856, 1021, 1022, 859, 860, 861, 862, 863, 864, 865, 1280, 1281, 1282, 1283, 1284, 1285, 1286, 1287, 1288, 1025, 1026, 1027, 1046, 1039, 1047, 1038, 1294, 628, 629, 630, 631, 632, 633, 634, 635, 636, 637, 638, 639, 1301, 1049, 1302, 215, 216, 217, 218, 219, 1075, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1076, 1078, 1082, 1084, 1085, 229, 1129, 1086, 1087, 1147, 1153, 1091, 1092, 1088, 1090, 1332, 1333, 1334, 1335, 1336, 1337, 1338, 1339, 1340, 1342, 1344, 1346, 1096, 1097, 1349, 215, 216, 217, 218, 219, 494, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1100, 1098, 1101, 1156, 1158, 229, 1161, 1103, 1160, 1130, 1162, 1119, 1373, 1374, 1163, 1164, 1166, 1168, 1169, 1171, 1172, 1382, 1383, 1384, 1385, 1386, 1387, 1388, 1389, 1390, 1391, 1174, 1393, 1175, 1395, 1176, 1190, 1187, 1399, 877, 1191, 1195, 1194, 1216, 1201, 418, 1217, 1220, 1221, 1222, 1224, 1225, 992, 1232, 1229, 996, 1227, 1233, 1239, 1240, 1001, 1411, 1412, 1256, 1257, 1265, 1416, 1417, 1418, 1419, 1420, 1421, 1231, 1237, 1243, 1266, 1267, 1269, 1270, 1020, 1271, 1272, 1273, 1277, 1292, 1293, 1295, 1296, 1299, 1439, 1300, 1297, 1323, 1298, 1443, 1444, 1445, 1446, 1447, 1448, 1450, 1452, 1454, 217, 218, 219, 1303, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1305, 1324, 1315, 1316, 1317, 229, 1473, 1474, 1475, 1476, 1477, 1478, 1479, 1326, 1481, 1319, 1483, 1329, 215, 216, 217, 218, 219, 1330, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1347, 1493, 1494, 1495, 1348, 229, 1350, 1351, 1352, 1353, 1355, 1356, 1372, 1354, 1377, 1507, 1508, 1509, 1511, 1513, 1515, 1378, 1379, 1380, 1381, 1392, 1394, 1396, 1440, 1397, 1400, 1427, 1527, 1528, 1529, 1530, 1401, 1532, 1457, 1534, 1470, 1472, 215, 216, 217, 218, 219, 1428, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1429, 1480, 1548, 1550, 1552, 229, 1482, 1436, 1437, 1484, 1531, 1559, 1456, 1561, 1438, 1563, 1485, 1499, 1533, 1503, 1504, 1505, 1148, 419, 1149, 1535, 1516, 1540, 1536, 1544, 1560, 1562, 1564, 1566, 1545, 1546, 1567, 67, 68, 1278, 76, 77, 117, 762, 118, 1167, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 69, 119, 420, 738, 0, 0, 76, 77, 0, 990, 0, 1200, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 76, 77, 0, 0, 0, 0, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 0, 0, 76, 77, 0, 0, 0, 0, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 0, 0, 0, 0, 0, 1258, 1259, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 120, 121, 122, 123, 229, 0, 0, 1279, 0, 0, 0, 0, 0, 0, 100, 101, 0, 0, 0, 0, 102, 124, 125, 0, 0, 103, 0, 126, 0, 127, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 100, 101, 0, 229, 0, 0, 102, 0, 1318, 0, 0, 103, 0, 0, 734, 0, 0, 0, 0, 0, 0, 1331, 0, 0, 0, 0, 0, 0, 100, 101, 0, 0, 0, 0, 102, 0, 0, 0, 0, 103, 0, 0, 945, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 224, 225, 226, 227, 228, 0, 102, 76, 77, 1376, 229, 103, 0, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 715, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 717, 0, 0, 0, 76, 447, 0, 0, 0, 1415, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 76, 736, 0, 0, 1441, 0, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 76, 938, 0, 0, 1471, 0, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 719, 0, 0, 0, 0, 1492, 0, 0, 0, 0, 0, 0, 0, 0, 0, 721, 0, 0, 0, 1506, 0, 0, 0, 0, 0, 0, 0, 0, 100, 101, 722, 0, 0, 0, 102, 0, 0, 0, 0, 103, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 739, 0, 100, 101, 0, 229, 0, 0, 102, 0, 0, 0, 0, 103, 0, 761, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 100, 101, 0, 0, 0, 0, 102, 830, 0, 0, 0, 103, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 831, 0, 0, 0, 0, 0, 100, 101, 0, 0, 0, 0, 102, 0, 0, 832, 0, 103, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 833, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 834, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1044, 0, 0, 0, 0, 229, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1045, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1177, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1179, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1181, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1183, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1184, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1185, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1186, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1218, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 522, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 600, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 782, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 1152, 0, 0, 0, 851, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1320, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 26, 27, 28, 29, 30, 31, 32, 33, 0, 34, 0, 36, 37, 0, 39, 40, 0, 26, 27, 28, 29, 30, 31, 32, 33, 0, 34, 0, 36, 37, 51, 39, 40, 0, 0, -3, 22, 0, 0, 23, 0, 0, 0, 0, 52, 53, 0, 51, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 52, 53, 0, 0, 0, 24, 0, 25, 26, 27, 28, 29, 30, 31, 32, 33, 0, 34, 35, 36, 37, 38, 39, 40, 0, 0, 0, 41, 42, 43, 44, 45, 46, 0, 47, 48, 49, 50, 51, 0, 0, 0, 0, 62, 0, 0, 0, 0, 0, 231, 0, 0, 52, 53, 0, 0, 0, 0, 0, 54, 62, 55, 56, 57, 58, 0, 59, 60, 61, 26, 27, 28, 29, 30, 31, 32, 33, 0, 34, 0, 36, 37, 0, 39, 40, 480, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 51, 0, 0, 484, 0, 0, 0, 0, 232, 233, 234, 0, 0, 62, 52, 53, 235, 236, 237, 238, 239, 240, 241, 242, 243, 244, 0, 0, 0, 0, 0, 0, 0, 0, 245, 246, 247, 248, 249, 250, 251, 252, 253, 254, 0, 255, 256, 257, 258, 259, 260, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 62, 0, 0, 1124, 0, 1125, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 0, 0, 1275, 0, 1276, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 436, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 441, 220, 221, 222, 223, 278, 279, 226, 227, 228, 523, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 443, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 605, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 609, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 610, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 757, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 959, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1151, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1192, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1197, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1198, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1199, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1214, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1215, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1238, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1328, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1426, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 215, 216, 217, 218, 219, 1455, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 363, 0, 0, 0, 467, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 467, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 468, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 512, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 519, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 520, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 521, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 623, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 624, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 625, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 755, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 756, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 890, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 891, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 904, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 905, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 946, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 973, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 974, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 975, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 976, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 977, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 978, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 979, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 980, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 981, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 982, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 983, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 984, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1041, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1069, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1070, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1083, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1094, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1099, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1102, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1122, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1133, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1134, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1135, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1136, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1137, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1138, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1139, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1140, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1141, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1142, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1143, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1144, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1193, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1223, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1244, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1245, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1246, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1247, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1248, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1249, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1250, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1251, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1252, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1306, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1307, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1308, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1309, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1310, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1311, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1312, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1313, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1314, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1357, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1358, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1359, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1360, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1361, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1362, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1363, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1364, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1365, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1398, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1402, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1403, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1404, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1405, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1406, 220, 221, 222, 223, 278, 279, 226, 227, 228, 1413, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1407, 220, 221, 222, 223, 278, 279, 226, 227, 228, 215, 216, 217, 218, 219, 229, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1425, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1430, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1431, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1432, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1433, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1434, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1435, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1458, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1459, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1460, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1461, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1462, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1463, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1486, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1487, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1488, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1500, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1501, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1502, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1517, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1518, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 215, 216, 217, 218, 219, 1519, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 421, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 497, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 723, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 786, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 867, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 1104, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 0, 0, 1327, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 363, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 435, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 437, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 438, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 440, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 444, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 445, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 452, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 489, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 492, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 495, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 501, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 502, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 503, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 504, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 505, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 506, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 507, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 508, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 509, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 510, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 511, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 513, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 514, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 515, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 516, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 517, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 518, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 591, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 594, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 606, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 607, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 611, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 612, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 613, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 614, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 615, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 657, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 661, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 787, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 788, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 789, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 790, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 893, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 961, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 995, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1089, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1093, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1095, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1226, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1228, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1230, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1253, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1254, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1255, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1408, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1409, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1410, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1489, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1490, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1491, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1537, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1538, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229, 0, 1539, 215, 216, 217, 218, 219, 0, 220, 221, 222, 223, 278, 279, 226, 227, 228, 0, 0, 0, 0, 0, 229 }; static const short yycheck[] = { 7, 114, 4, 1055, 4, 4, 4, 318, 38, 6, 6, 987, 434, 81, 4, 6, 23, 4, 4, 60, 60, 59, 59, 4, 65, 65, 4, 1117, 143, 162, 163, 6, 42, 43, 172, 162, 163, 6, 7, 162, 163, 179, 162, 163, 0, 1, 179, 3, 178, 6, 180, 178, 911, 180, 45, 178, 6, 180, 178, 7, 180, 920, 162, 163, 162, 163, 162, 163, 927, 162, 163, 162, 163, 63, 6, 60, 63, 63, 174, 179, 65, 179, 63, 162, 163, 178, 173, 178, 162, 163, 51, 52, 179, 100, 101, 102, 103, 104, 4, 178, 173, 162, 163, 84, 178, 173, 84, 1083, 162, 163, 6, 118, 6, 120, 121, 122, 123, 178, 7, 126, 6, 173, 7, 173, 178, 132, 133, 134, 135, 179, 137, 138, 6, 140, 141, 142, 173, 144, 560, 180, 180, 179, 179, 173, 1234, 172, 156, 6, 169, 159, 171, 6, 179, 160, 161, 165, 173, 113, 114, 115, 116, 117, 118, 119, 120, 6, 162, 163, 174, 176, 6, 178, 178, 180, 181, 173, 6, 179, 6, 179, 179, 188, 179, 190, 191, 192, 193, 194, 195, 196, 197, 198, 199, 200, 201, 202, 203, 204, 205, 206, 207, 208, 209, 210, 179, 162, 163, 6, 215, 216, 217, 218, 219, 220, 221, 222, 223, 224, 225, 226, 227, 228, 229, 230, 173, 1084, 1278, 3, 4, 1088, 162, 163, 6, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 173, 162, 163, 7, 148, 149, 150, 151, 148, 149, 150, 151, 173, 162, 163, 173, 278, 279, 179, 162, 163, 162, 163, 173, 286, 169, 170, 289, 173, 169, 170, 174, 294, 162, 163, 174, 298, 299, 300, 178, 302, 303, 304, 305, 306, 307, 308, 42, 162, 163, 315, 316, 162, 163, 37, 38, 173, 40, 320, 321, 322, 326, 162, 163, 164, 165, 166, 174, 38, 174, 332, 178, 172, 178, 3, 4, 338, 178, 38, 180, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 34, 38, 40, 37, 1220, 1221, 1222, 1223, 169, 170, 178, 1227, 180, 179, 175, 8, 177, 178, 38, 152, 153, 154, 155, 156, 179, 158, 159, 160, 161, 162, 163, 164, 165, 166, 34, 168, 179, 37, 38, 172, 173, 179, 148, 149, 150, 151, 179, 34, 174, 6, 37, 38, 178, 40, 5, 422, 423, 424, 422, 423, 424, 425, 426, 169, 170, 429, 169, 170, 6, 174, 434, 173, 175, 178, 177, 0, 1, 173, 3, 1295, 1296, 4, 446, 1299, 4, 169, 170, 451, 164, 165, 166, 175, 456, 177, 169, 170, 172, 464, 38, 178, 175, 180, 177, 467, 468, 169, 170, 173, 169, 170, 5, 175, 476, 177, 175, 178, 177, 180, 173, 483, 53, 54, 55, 56, 178, 58, 180, 169, 170, 493, 494, 162, 163, 178, 1350, 180, 500, 168, 178, 178, 180, 180, 173, 169, 170, 176, 169, 170, 512, 98, 99, 100, 101, 102, 173, 519, 520, 521, 522, 152, 153, 154, 155, 156, 173, 158, 159, 160, 161, 162, 163, 164, 165, 166, 178, 178, 180, 180, 173, 172, 178, 178, 180, 180, 1400, 173, 6, 180, 113, 114, 115, 116, 117, 118, 119, 120, 560, 561, 562, 563, 564, 565, 870, 178, 571, 180, 570, 571, 572, 178, 173, 180, 173, 1429, 139, 140, 5, 142, 173, 173, 587, 155, 156, 173, 158, 159, 160, 161, 162, 163, 164, 165, 166, 703, 173, 599, 600, 601, 172, 6, 158, 159, 160, 161, 162, 163, 164, 165, 166, 173, 6, 173, 173, 617, 172, 86, 623, 624, 625, 173, 173, 173, 173, 173, 173, 173, 173, 173, 173, 173, 143, 173, 173, 173, 173, 148, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 179, 653, 654, 179, 656, 179, 173, 173, 177, 170, 6, 179, 1516, 174, 175, 179, 179, 173, 172, 674, 672, 673, 173, 173, 173, 3, 4, 5, 683, 173, 173, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 173, 3, 4, 5, 173, 173, 173, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 173, 173, 173, 173, 173, 173, 740, 173, 1046, 173, 173, 173, 173, 5, 5, 173, 173, 173, 173, 753, 180, 755, 756, 173, 173, 173, 173, 173, 173, 763, 764, 765, 766, 767, 768, 769, 770, 771, 772, 773, 774, 174, 178, 178, 175, 177, 7, 7, 782, 783, 7, 785, 7, 82, 3, 4, 179, 791, 175, 5, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 933, 5, 5, 5, 5, 5, 5, 5, 5, 162, 163, 5, 839, 5, 844, 168, 5, 131, 5, 5, 173, 5, 5, 3, 851, 852, 179, 5, 5, 5, 857, 858, 6, 6, 6, 4, 6, 175, 162, 163, 7, 871, 6, 873, 168, 875, 7, 7, 7, 173, 6, 6, 180, 7, 7, 179, 7, 180, 179, 179, 7, 173, 7, 890, 891, 145, 5, 178, 178, 178, 178, 178, 178, 178, 178, 902, 178, 904, 178, 178, 6, 178, 178, 178, 178, 178, 178, 914, 178, 178, 178, 178, 178, 6, 921, 922, 923, 178, 6, 178, 178, 928, 178, 178, 178, 932, 178, 934, 178, 174, 178, 6, 179, 7, 7, 7, 7, 7, 7, 946, 162, 163, 7, 7, 50, 7, 168, 7, 7, 7, 7, 173, 8, 173, 6, 962, 173, 179, 173, 173, 173, 173, 173, 173, 173, 173, 973, 974, 975, 976, 977, 978, 979, 980, 981, 982, 983, 984, 7, 7, 141, 3, 3, 3, 3, 3, 993, 3, 4, 164, 3, 998, 3, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 3, 3, 3, 173, 3, 3, 1031, 1032, 1033, 1031, 1032, 1033, 1034, 1035, 1036, 1037, 173, 5, 1040, 1041, 6, 3, 3, 6, 3, 5, 3, 179, 1050, 1051, 1052, 152, 153, 154, 155, 156, 177, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, 1069, 1070, 6, 6, 172, 6, 6, 1076, 6, 83, 177, 589, 590, 178, 592, 178, 174, 1086, 596, 597, 174, 178, 178, 174, 177, 1094, 178, 175, 174, 178, 1099, 178, 174, 1102, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, 178, 178, 174, 6, 178, 172, 1124, 174, 174, 6, 6, 6, 6, 178, 178, 1133, 1134, 1135, 1136, 1137, 1138, 1139, 1140, 1141, 1142, 1143, 1144, 178, 655, 178, 178, 658, 178, 178, 1152, 162, 163, 178, 6, 6, 178, 168, 6, 6, 6, 6, 173, 6, 6, 6, 6, 177, 179, 680, 681, 6, 6, 6, 83, 686, 687, 7, 4, 3, 3, 6, 693, 3, 695, 6, 152, 153, 154, 155, 156, 1193, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 164, 1219, 729, 6, 731, 172, 6, 6, 3, 6, 6, 178, 3, 180, 741, 742, 743, 6, 3, 746, 747, 748, 749, 750, 751, 752, 1244, 1245, 1246, 1247, 1248, 1249, 1250, 1251, 1252, 3, 3, 6, 179, 84, 4, 7, 1260, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 1273, 180, 1275, 152, 153, 154, 155, 156, 179, 158, 159, 160, 161, 162, 163, 164, 165, 166, 80, 6, 174, 178, 178, 172, 6, 178, 174, 83, 6, 174, 174, 178, 178, 1306, 1307, 1308, 1309, 1310, 1311, 1312, 1313, 1314, 1315, 1316, 1317, 178, 174, 1320, 152, 153, 154, 155, 156, 8, 158, 159, 160, 161, 162, 163, 164, 165, 166, 178, 174, 174, 3, 6, 172, 3, 178, 6, 179, 6, 177, 1348, 1349, 6, 6, 6, 6, 6, 3, 6, 1357, 1358, 1359, 1360, 1361, 1362, 1363, 1364, 1365, 1366, 5, 1368, 177, 1370, 6, 6, 177, 1374, 180, 4, 180, 5, 179, 6, 6, 178, 178, 178, 178, 174, 174, 897, 4, 174, 900, 178, 63, 6, 6, 905, 1397, 1398, 6, 6, 6, 1402, 1403, 1404, 1405, 1406, 1407, 178, 178, 178, 6, 6, 6, 6, 924, 6, 5, 175, 5, 178, 180, 178, 178, 178, 1425, 178, 174, 6, 174, 1430, 1431, 1432, 1433, 1434, 1435, 1436, 1437, 1438, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, 178, 6, 179, 179, 179, 172, 1458, 1459, 1460, 1461, 1462, 1463, 1464, 5, 1466, 80, 1468, 5, 152, 153, 154, 155, 156, 6, 158, 159, 160, 161, 162, 163, 164, 165, 166, 180, 1486, 1487, 1488, 179, 172, 178, 178, 174, 174, 180, 180, 80, 177, 6, 1500, 1501, 1502, 1503, 1504, 1505, 6, 84, 6, 6, 6, 6, 6, 6, 179, 178, 147, 1517, 1518, 1519, 1520, 178, 1522, 174, 1524, 6, 6, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, 178, 6, 1544, 1545, 1546, 172, 6, 179, 179, 6, 6, 1553, 178, 1555, 179, 1557, 178, 178, 6, 179, 179, 179, 1073, 6, 1075, 6, 178, 6, 174, 179, 6, 6, 6, 0, 179, 179, 0, 6, 6, 1242, 3, 4, 5, 627, 7, 1096, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 6, 32, 6, 601, -1, -1, 3, 4, -1, 895, -1, 1130, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 3, 4, -1, -1, -1, -1, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, -1, -1, 3, 4, -1, -1, -1, -1, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, -1, -1, -1, -1, -1, 1216, 1217, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, 148, 149, 150, 151, 172, -1, -1, 1243, -1, -1, -1, -1, -1, -1, 162, 163, -1, -1, -1, -1, 168, 169, 170, -1, -1, 173, -1, 175, -1, 177, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, 162, 163, -1, 172, -1, -1, 168, -1, 1292, -1, -1, 173, -1, -1, 176, -1, -1, -1, -1, -1, -1, 1305, -1, -1, -1, -1, -1, -1, 162, 163, -1, -1, -1, -1, 168, -1, -1, -1, -1, 173, -1, -1, 176, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, 168, 3, 4, 1351, 172, 173, -1, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 6, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, 3, 4, -1, -1, -1, 1401, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 3, 4, -1, -1, 1428, -1, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 3, 4, -1, -1, 1456, -1, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 6, -1, -1, -1, -1, 1485, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, 1499, -1, -1, -1, -1, -1, -1, -1, -1, 162, 163, 6, -1, -1, -1, 168, -1, -1, -1, -1, 173, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, 162, 163, -1, 172, -1, -1, 168, -1, -1, -1, -1, 173, -1, 6, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 162, 163, -1, -1, -1, -1, 168, 6, -1, -1, -1, 173, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, 162, 163, -1, -1, -1, -1, 168, -1, -1, 6, -1, 173, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, -1, -1, -1, 172, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 6, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 6, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 8, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 8, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 8, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, 141, -1, -1, -1, 8, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 141, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 34, 35, 36, 37, 38, 39, 40, 41, -1, 43, -1, 45, 46, -1, 48, 49, -1, 34, 35, 36, 37, 38, 39, 40, 41, -1, 43, -1, 45, 46, 64, 48, 49, -1, -1, 0, 1, -1, -1, 4, -1, -1, -1, -1, 78, 79, -1, 64, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 78, 79, -1, -1, -1, 31, -1, 33, 34, 35, 36, 37, 38, 39, 40, 41, -1, 43, 44, 45, 46, 47, 48, 49, -1, -1, -1, 53, 54, 55, 56, 57, 58, -1, 60, 61, 62, 63, 64, -1, -1, -1, -1, 138, -1, -1, -1, -1, -1, 37, -1, -1, 78, 79, -1, -1, -1, -1, -1, 85, 138, 87, 88, 89, 90, -1, 92, 93, 94, 34, 35, 36, 37, 38, 39, 40, 41, -1, 43, -1, 45, 46, -1, 48, 49, 180, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 64, -1, -1, 180, -1, -1, -1, -1, 95, 96, 97, -1, -1, 138, 78, 79, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, -1, -1, -1, -1, -1, -1, -1, -1, 121, 122, 123, 124, 125, 126, 127, 128, 129, 130, -1, 132, 133, 134, 135, 136, 137, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 138, -1, -1, 178, -1, 180, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, -1, -1, 178, -1, 180, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, 144, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, 152, 153, 154, 155, 156, 180, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, -1, -1, -1, 178, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, 146, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, 152, 153, 154, 155, 156, 172, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, 152, 153, 154, 155, 156, 178, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, -1, -1, 176, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172, -1, 174, 152, 153, 154, 155, 156, -1, 158, 159, 160, 161, 162, 163, 164, 165, 166, -1, -1, -1, -1, -1, 172 }; /* -*-C-*- Note some compilers choke on comments on `#line' lines. */ #line 3 "/usr/lib/bison.simple" /* This file comes from bison-1.28. */ /* Skeleton output parser for bison, Copyright (C) 1984, 1989, 1990 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* As a special exception, when this file is copied by Bison into a Bison output file, you may use that output file without restriction. This special exception was added by the Free Software Foundation in version 1.24 of Bison. */ /* This is the parser code that is written into each bison parser when the %semantic_parser declaration is not specified in the grammar. It was written by Richard Stallman by simplifying the hairy parser used when %semantic_parser is specified. */ #ifndef YYSTACK_USE_ALLOCA #ifdef alloca #define YYSTACK_USE_ALLOCA #else /* alloca not defined */ #ifdef __GNUC__ #define YYSTACK_USE_ALLOCA #define alloca __builtin_alloca #else /* not GNU C. */ #if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi) || (defined (__sun) && defined (__i386)) #define YYSTACK_USE_ALLOCA #include <alloca.h> #else /* not sparc */ /* We think this test detects Watcom and Microsoft C. */ /* This used to test MSDOS, but that is a bad idea since that symbol is in the user namespace. */ #if (defined (_MSDOS) || defined (_MSDOS_)) && !defined (__TURBOC__) #if 0 /* No need for malloc.h, which pollutes the namespace; instead, just don't use alloca. */ #include <malloc.h> #endif #else /* not MSDOS, or __TURBOC__ */ #if defined(_AIX) /* I don't know what this was needed for, but it pollutes the namespace. So I turned it off. rms, 2 May 1997. */ /* #include <malloc.h> */ #pragma alloca #define YYSTACK_USE_ALLOCA #else /* not MSDOS, or __TURBOC__, or _AIX */ #if 0 #ifdef __hpux /* haible@ilog.fr says this works for HPUX 9.05 and up, and on HPUX 10. Eventually we can turn this on. */ #define YYSTACK_USE_ALLOCA #define alloca __builtin_alloca #endif /* __hpux */ #endif #endif /* not _AIX */ #endif /* not MSDOS, or __TURBOC__ */ #endif /* not sparc */ #endif /* not GNU C */ #endif /* alloca not defined */ #endif /* YYSTACK_USE_ALLOCA not defined */ #ifdef YYSTACK_USE_ALLOCA #define YYSTACK_ALLOC alloca #else #define YYSTACK_ALLOC malloc #endif /* Note: there must be only one dollar sign in this file. It is replaced by the list of actions, each action as one case of the switch. */ #define yyerrok (yyerrstatus = 0) #define yyclearin (yychar = YYEMPTY) #define YYEMPTY -2 #define YYEOF 0 #define YYACCEPT goto yyacceptlab #define YYABORT goto yyabortlab #define YYERROR goto yyerrlab1 /* Like YYERROR except do call yyerror. This remains here temporarily to ease the transition to the new meaning of YYERROR, for GCC. Once GCC version 2 has supplanted version 1, this can go. */ #define YYFAIL goto yyerrlab #define YYRECOVERING() (!!yyerrstatus) #define YYBACKUP(token, value) \ do \ if (yychar == YYEMPTY && yylen == 1) \ { yychar = (token), yylval = (value); \ yychar1 = YYTRANSLATE (yychar); \ YYPOPSTACK; \ goto yybackup; \ } \ else \ { yyerror ("syntax error: cannot back up"); YYERROR; } \ while (0) #define YYTERROR 1 #define YYERRCODE 256 #ifndef YYPURE #define YYLEX yylex() #endif #ifdef YYPURE #ifdef YYLSP_NEEDED #ifdef YYLEX_PARAM #define YYLEX yylex(&yylval, &yylloc, YYLEX_PARAM) #else #define YYLEX yylex(&yylval, &yylloc) #endif #else /* not YYLSP_NEEDED */ #ifdef YYLEX_PARAM #define YYLEX yylex(&yylval, YYLEX_PARAM) #else #define YYLEX yylex(&yylval) #endif #endif /* not YYLSP_NEEDED */ #endif /* If nonreentrant, generate the variables here */ #ifndef YYPURE int yychar; /* the lookahead symbol */ YYSTYPE yylval; /* the semantic value of the */ /* lookahead symbol */ #ifdef YYLSP_NEEDED YYLTYPE yylloc; /* location data for the lookahead */ /* symbol */ #endif int yynerrs; /* number of parse errors so far */ #endif /* not YYPURE */ #if YYDEBUG != 0 int yydebug; /* nonzero means print parse trace */ /* Since this is uninitialized, it does not stop multiple parsers from coexisting. */ #endif /* YYINITDEPTH indicates the initial size of the parser's stacks */ #ifndef YYINITDEPTH #define YYINITDEPTH 200 #endif /* YYMAXDEPTH is the maximum size the stacks can grow to (effective only if the built-in stack extension method is used). */ #if YYMAXDEPTH == 0 #undef YYMAXDEPTH #endif #ifndef YYMAXDEPTH #define YYMAXDEPTH 10000 #endif /* Define __yy_memcpy. Note that the size argument should be passed with type unsigned int, because that is what the non-GCC definitions require. With GCC, __builtin_memcpy takes an arg of type size_t, but it can handle unsigned int. */ #if __GNUC__ > 1 /* GNU C and GNU C++ define this. */ #define __yy_memcpy(TO,FROM,COUNT) __builtin_memcpy(TO,FROM,COUNT) #else /* not GNU C or C++ */ #ifndef __cplusplus /* This is the most reliable way to avoid incompatibilities in available built-in functions on various systems. */ static void __yy_memcpy (to, from, count) char *to; char *from; unsigned int count; { register char *f = from; register char *t = to; register int i = count; while (i-- > 0) *t++ = *f++; } #else /* __cplusplus */ /* This is the most reliable way to avoid incompatibilities in available built-in functions on various systems. */ static void __yy_memcpy (char *to, char *from, unsigned int count) { register char *t = to; register char *f = from; register int i = count; while (i-- > 0) *t++ = *f++; } #endif #endif #line 217 "/usr/lib/bison.simple" /* The user can define YYPARSE_PARAM as the name of an argument to be passed into yyparse. The argument should have type void *. It should actually point to an object. Grammar actions can access the variable by casting it to the proper pointer type. */ #ifdef YYPARSE_PARAM #ifdef __cplusplus #define YYPARSE_PARAM_ARG void *YYPARSE_PARAM #define YYPARSE_PARAM_DECL #else /* not __cplusplus */ #define YYPARSE_PARAM_ARG YYPARSE_PARAM #define YYPARSE_PARAM_DECL void *YYPARSE_PARAM; #endif /* not __cplusplus */ #else /* not YYPARSE_PARAM */ #define YYPARSE_PARAM_ARG #define YYPARSE_PARAM_DECL #endif /* not YYPARSE_PARAM */ /* Prevent warning if -Wstrict-prototypes. */ #ifdef __GNUC__ #ifdef YYPARSE_PARAM int yyparse (void *); #else int yyparse (void); #endif #endif int yyparse(YYPARSE_PARAM_ARG) YYPARSE_PARAM_DECL { register int yystate; register int yyn; register short *yyssp; register YYSTYPE *yyvsp; int yyerrstatus; /* number of tokens to shift before error messages enabled */ int yychar1 = 0; /* lookahead token as an internal (translated) token number */ short yyssa[YYINITDEPTH]; /* the state stack */ YYSTYPE yyvsa[YYINITDEPTH]; /* the semantic value stack */ short *yyss = yyssa; /* refer to the stacks thru separate pointers */ YYSTYPE *yyvs = yyvsa; /* to allow yyoverflow to reallocate them elsewhere */ #ifdef YYLSP_NEEDED YYLTYPE yylsa[YYINITDEPTH]; /* the location stack */ YYLTYPE *yyls = yylsa; YYLTYPE *yylsp; #define YYPOPSTACK (yyvsp--, yyssp--, yylsp--) #else #define YYPOPSTACK (yyvsp--, yyssp--) #endif int yystacksize = YYINITDEPTH; int yyfree_stacks = 0; #ifdef YYPURE int yychar; YYSTYPE yylval; int yynerrs; #ifdef YYLSP_NEEDED YYLTYPE yylloc; #endif #endif YYSTYPE yyval; /* the variable used to return */ /* semantic values from the action */ /* routines */ int yylen; #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Starting parse\n"); #endif yystate = 0; yyerrstatus = 0; yynerrs = 0; yychar = YYEMPTY; /* Cause a token to be read. */ /* Initialize stack pointers. Waste one element of value and location stack so that they stay on the same level as the state stack. The wasted elements are never initialized. */ yyssp = yyss - 1; yyvsp = yyvs; #ifdef YYLSP_NEEDED yylsp = yyls; #endif /* Push a new state, which is found in yystate . */ /* In all cases, when you get here, the value and location stacks have just been pushed. so pushing a state here evens the stacks. */ yynewstate: *++yyssp = yystate; if (yyssp >= yyss + yystacksize - 1) { /* Give user a chance to reallocate the stack */ /* Use copies of these so that the &'s don't force the real ones into memory. */ YYSTYPE *yyvs1 = yyvs; short *yyss1 = yyss; #ifdef YYLSP_NEEDED YYLTYPE *yyls1 = yyls; #endif /* Get the current used size of the three stacks, in elements. */ int size = yyssp - yyss + 1; #ifdef yyoverflow /* Each stack pointer address is followed by the size of the data in use in that stack, in bytes. */ #ifdef YYLSP_NEEDED /* This used to be a conditional around just the two extra args, but that might be undefined if yyoverflow is a macro. */ yyoverflow("parser stack overflow", &yyss1, size * sizeof (*yyssp), &yyvs1, size * sizeof (*yyvsp), &yyls1, size * sizeof (*yylsp), &yystacksize); #else yyoverflow("parser stack overflow", &yyss1, size * sizeof (*yyssp), &yyvs1, size * sizeof (*yyvsp), &yystacksize); #endif yyss = yyss1; yyvs = yyvs1; #ifdef YYLSP_NEEDED yyls = yyls1; #endif #else /* no yyoverflow */ /* Extend the stack our own way. */ if (yystacksize >= YYMAXDEPTH) { yyerror("parser stack overflow"); if (yyfree_stacks) { free (yyss); free (yyvs); #ifdef YYLSP_NEEDED free (yyls); #endif } return 2; } yystacksize *= 2; if (yystacksize > YYMAXDEPTH) yystacksize = YYMAXDEPTH; #ifndef YYSTACK_USE_ALLOCA yyfree_stacks = 1; #endif yyss = (short *) YYSTACK_ALLOC (yystacksize * sizeof (*yyssp)); __yy_memcpy ((char *)yyss, (char *)yyss1, size * (unsigned int) sizeof (*yyssp)); yyvs = (YYSTYPE *) YYSTACK_ALLOC (yystacksize * sizeof (*yyvsp)); __yy_memcpy ((char *)yyvs, (char *)yyvs1, size * (unsigned int) sizeof (*yyvsp)); #ifdef YYLSP_NEEDED yyls = (YYLTYPE *) YYSTACK_ALLOC (yystacksize * sizeof (*yylsp)); __yy_memcpy ((char *)yyls, (char *)yyls1, size * (unsigned int) sizeof (*yylsp)); #endif #endif /* no yyoverflow */ yyssp = yyss + size - 1; yyvsp = yyvs + size - 1; #ifdef YYLSP_NEEDED yylsp = yyls + size - 1; #endif #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Stack size increased to %d\n", yystacksize); #endif if (yyssp >= yyss + yystacksize - 1) YYABORT; } #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Entering state %d\n", yystate); #endif goto yybackup; yybackup: /* Do appropriate processing given the current state. */ /* Read a lookahead token if we need one and don't already have one. */ /* yyresume: */ /* First try to decide what to do without reference to lookahead token. */ yyn = yypact[yystate]; if (yyn == YYFLAG) goto yydefault; /* Not known => get a lookahead token if don't already have one. */ /* yychar is either YYEMPTY or YYEOF or a valid token in external form. */ if (yychar == YYEMPTY) { #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Reading a token: "); #endif yychar = YYLEX; } /* Convert token to internal form (in yychar1) for indexing tables with */ if (yychar <= 0) /* This means end of input. */ { yychar1 = 0; yychar = YYEOF; /* Don't call YYLEX any more */ #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Now at end of input.\n"); #endif } else { yychar1 = YYTRANSLATE(yychar); #if YYDEBUG != 0 if (yydebug) { fprintf (stderr, "Next token is %d (%s", yychar, yytname[yychar1]); /* Give the individual parser a way to print the precise meaning of a token, for further debugging info. */ #ifdef YYPRINT YYPRINT (stderr, yychar, yylval); #endif fprintf (stderr, ")\n"); } #endif } yyn += yychar1; if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1) goto yydefault; yyn = yytable[yyn]; /* yyn is what to do for this token type in this state. Negative => reduce, -yyn is rule number. Positive => shift, yyn is new state. New state is final state => don't bother to shift, just return success. 0, or most negative number => error. */ if (yyn < 0) { if (yyn == YYFLAG) goto yyerrlab; yyn = -yyn; goto yyreduce; } else if (yyn == 0) goto yyerrlab; if (yyn == YYFINAL) YYACCEPT; /* Shift the lookahead token. */ #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]); #endif /* Discard the token being shifted unless it is eof. */ if (yychar != YYEOF) yychar = YYEMPTY; *++yyvsp = yylval; #ifdef YYLSP_NEEDED *++yylsp = yylloc; #endif /* count tokens shifted since error; after three, turn off error status. */ if (yyerrstatus) yyerrstatus--; yystate = yyn; goto yynewstate; /* Do the default action for the current state. */ yydefault: yyn = yydefact[yystate]; if (yyn == 0) goto yyerrlab; /* Do a reduction. yyn is the number of a rule to reduce with. */ yyreduce: yylen = yyr2[yyn]; if (yylen > 0) yyval = yyvsp[1-yylen]; /* implement default value of the action */ #if YYDEBUG != 0 if (yydebug) { int i; fprintf (stderr, "Reducing via rule %d (line %d), ", yyn, yyrline[yyn]); /* Print the symbols being reduced, and their result. */ for (i = yyprhs[yyn]; yyrhs[i] > 0; i++) fprintf (stderr, "%s ", yytname[yyrhs[i]]); fprintf (stderr, " -> %s\n", yytname[yyr1[yyn]]); } #endif switch (yyn) { case 4: #line 156 "Gmsh.y" { Msg(PARSER_INFO,"STL File Format"); STL_Surf = Create_Surface(1,MSH_SURF_STL,1); STL_Surf->STL = new STL_Data; return 1; ; break;} case 5: #line 170 "Gmsh.y" { STL_Surf->STL->Add_Facet( yyvsp[-12].d, yyvsp[-11].d, yyvsp[-10].d, yyvsp[-8].d, yyvsp[-7].d, yyvsp[-6].d, yyvsp[-4].d, yyvsp[-3].d, yyvsp[-2].d); return 1; ; break;} case 6: #line 177 "Gmsh.y" { Msg(PARSER_INFO,"STL File Format Read"); Tree_Add(THEM->Surfaces, &STL_Surf); return 1; ; break;} case 9: #line 194 "Gmsh.y" { return 1; ; break;} case 10: #line 195 "Gmsh.y" { return 1; ; break;} case 11: #line 196 "Gmsh.y" { return 1; ; break;} case 12: #line 197 "Gmsh.y" { yyerrok ; return 1; ; break;} case 13: #line 202 "Gmsh.y" { Msg(PARSER_INFO,"Step Iso-10303-21 File Format"); Create_Step_Solid_BRep(); ; break;} case 14: #line 207 "Gmsh.y" { Msg(PARSER_INFO,"Step Iso-10303-21 File Format Read"); Resolve_BREP (); ; break;} case 18: #line 218 "Gmsh.y" { ; break;} case 19: #line 221 "Gmsh.y" { ; break;} case 20: #line 225 "Gmsh.y" { ; break;} case 21: #line 231 "Gmsh.y" { Add_Cartesian_Point((int)yyvsp[-8].d,yyvsp[-4].c,yyvsp[-2].v[0],yyvsp[-2].v[1],yyvsp[-2].v[2]); ; break;} case 22: #line 237 "Gmsh.y" { Add_BSpline_Curve_With_Knots ((int)yyvsp[-22].d, yyvsp[-18].c, (int) yyvsp[-16].d, yyvsp[-14].l, yyvsp[-6].l, yyvsp[-4].l, 0., 1.); ; break;} case 23: #line 244 "Gmsh.y" { Add_BSpline_Surface_With_Knots ((int)yyvsp[-30].d, yyvsp[-26].c, (int) yyvsp[-24].d, (int) yyvsp[-22].d, yyvsp[-20].l, yyvsp[-10].l, yyvsp[-8].l, yyvsp[-6].l, yyvsp[-4].l, 0., 1., 0., 1. ); ; break;} case 24: #line 250 "Gmsh.y" { Add_Edge_Curve ((int)yyvsp[-14].d, yyvsp[-10].c , (int)yyvsp[-8].d , (int)yyvsp[-6].d, (int)yyvsp[-4].d); ; break;} case 25: #line 254 "Gmsh.y" { Add_Face_Outer_Bound((int)yyvsp[-10].d,yyvsp[-6].c,(int)yyvsp[-4].d,yyvsp[-2].i,1); ; break;} case 26: #line 258 "Gmsh.y" { /* La je dois voir la norme ! Face_Bound : trou externe a la surface ! */ Msg(PARSER_INFO,"Found a Face Bound"); Add_Face_Outer_Bound((int)yyvsp[-10].d,yyvsp[-6].c,(int)yyvsp[-4].d,yyvsp[-2].i,0); ; break;} case 27: #line 265 "Gmsh.y" { Add_Oriented_Edge((int)yyvsp[-14].d,yyvsp[-10].c,(int)yyvsp[-4].d,yyvsp[-2].i); ; break;} case 28: #line 269 "Gmsh.y" { Add_Edge_Loop((int)yyvsp[-8].d,yyvsp[-4].c,yyvsp[-2].l); ; break;} case 29: #line 274 "Gmsh.y" { Add_Advanced_Face((int)yyvsp[-12].d,yyvsp[-8].c,yyvsp[-6].l,(int)yyvsp[-4].d,yyvsp[-2].i); ; break;} case 30: #line 278 "Gmsh.y" { Add_Vertex_Point((int)yyvsp[-8].d,yyvsp[-4].c,(int)yyvsp[-2].d); ; break;} case 31: #line 282 "Gmsh.y" { ; break;} case 32: #line 286 "Gmsh.y" { Add_Axis2_Placement3D ( (int)yyvsp[-12].d, (int)yyvsp[-4].d, (int)yyvsp[-2].d, (int)yyvsp[-6].d); ; break;} case 33: #line 290 "Gmsh.y" { Add_Direction((int)yyvsp[-8].d , yyvsp[-4].c, yyvsp[-2].v[0], yyvsp[-2].v[1], yyvsp[-2].v[2]); ; break;} case 34: #line 294 "Gmsh.y" { Add_Plane((int)yyvsp[-8].d,yyvsp[-4].c,(int)yyvsp[-2].d); ; break;} case 35: #line 298 "Gmsh.y" { Add_Line ((int)yyvsp[-10].d, yyvsp[-6].c , (int) yyvsp[-4].d, (int)yyvsp[-2].d); ; break;} case 36: #line 302 "Gmsh.y" { Msg(PARSER_INFO,"Found a Closed shell"); Add_Closed_Shell((int)yyvsp[-8].d, yyvsp[-4].c , yyvsp[-2].l); ; break;} case 37: #line 308 "Gmsh.y" { ; break;} case 38: #line 311 "Gmsh.y" { ; break;} case 39: #line 314 "Gmsh.y" { Add_Cylinder ((int)yyvsp[-10].d, yyvsp[-6].c , (int)yyvsp[-4].d, yyvsp[-2].d); ; break;} case 40: #line 318 "Gmsh.y" { Add_Cone ((int)yyvsp[-12].d, yyvsp[-8].c , (int)yyvsp[-6].d, yyvsp[-4].d,yyvsp[-2].d); ; break;} case 41: #line 322 "Gmsh.y" { Add_Torus ((int)yyvsp[-12].d, yyvsp[-8].c , (int)yyvsp[-6].d, yyvsp[-4].d,yyvsp[-2].d); ; break;} case 42: #line 326 "Gmsh.y" { Add_Circle((int) yyvsp[-10].d, yyvsp[-6].c, (int) yyvsp[-4].d, yyvsp[-2].d); ; break;} case 43: #line 330 "Gmsh.y" { Add_Ellipsis((int) yyvsp[-12].d, yyvsp[-8].c, (int) yyvsp[-6].d, yyvsp[-4].d, yyvsp[-2].d); ; break;} case 44: #line 335 "Gmsh.y" { ; break;} case 45: #line 338 "Gmsh.y" { ; break;} case 46: #line 342 "Gmsh.y" { ; break;} case 47: #line 345 "Gmsh.y" { ; break;} case 48: #line 349 "Gmsh.y" { ; break;} case 49: #line 352 "Gmsh.y" { ; break;} case 50: #line 355 "Gmsh.y" { ; break;} case 51: #line 365 "Gmsh.y" { ; break;} case 52: #line 368 "Gmsh.y" { Msg(PARSER_INFO,"Gmsh File Format Read"); ; break;} case 53: #line 374 "Gmsh.y" { return 1; ; break;} case 54: #line 375 "Gmsh.y" { return 1; ; break;} case 55: #line 376 "Gmsh.y" { return 1; ; break;} case 56: #line 377 "Gmsh.y" { return 1; ; break;} case 57: #line 378 "Gmsh.y" { return 1; ; break;} case 58: #line 379 "Gmsh.y" { return 1; ; break;} case 59: #line 380 "Gmsh.y" { return 1; ; break;} case 60: #line 381 "Gmsh.y" { return 1; ; break;} case 61: #line 382 "Gmsh.y" { return 1; ; break;} case 62: #line 383 "Gmsh.y" { return 1; ; break;} case 63: #line 384 "Gmsh.y" { return 1; ; break;} case 64: #line 385 "Gmsh.y" { return 1; ; break;} case 65: #line 386 "Gmsh.y" { yyerrok; return 1;; break;} case 66: #line 391 "Gmsh.y" { fprintf(stderr, yyvsp[-2].c); ; break;} case 67: #line 395 "Gmsh.y" { for(i = 0 ; i<List_Nbr(ListOfDouble_L) ; i++){ if(!i){ str = strtok(yyvsp[-4].c, "%"); fprintf(stderr, str); } str = strtok(NULL, "%"); if(str){ strcpy(tmpstring, "%"); strcat(tmpstring, str); fprintf(stderr, tmpstring, *(double*)List_Pointer(ListOfDouble_L,i)); } else{ fprintf(stderr, "\n"); vyyerror("Missing %d Parameter(s) in Printf Format", List_Nbr(ListOfDouble_L)-i); break ; } } if(!yyerrorstate) fprintf(stderr, "\n"); ; break;} case 68: #line 425 "Gmsh.y" { EndView(1, Force_ViewNumber,yyname,yyvsp[-4].c,0.,0.,0.); ; break;} case 69: #line 429 "Gmsh.y" { EndView(1, Force_ViewNumber,yyname,yyvsp[-6].c,yyvsp[-4].v[0],yyvsp[-4].v[1],yyvsp[-4].v[2]); ; break;} case 70: #line 436 "Gmsh.y" { BeginView(1); ; break;} case 83: #line 455 "Gmsh.y" { List_Add(ActualView->SP, &yyvsp[0].d) ; ; break;} case 84: #line 457 "Gmsh.y" { List_Add(ActualView->SP, &yyvsp[0].d) ; ; break;} case 85: #line 462 "Gmsh.y" { List_Add(ActualView->SP, &yyvsp[-5].d); List_Add(ActualView->SP, &yyvsp[-3].d); List_Add(ActualView->SP, &yyvsp[-1].d); ; break;} case 86: #line 467 "Gmsh.y" { ActualView->NbSP++ ; ; break;} case 87: #line 474 "Gmsh.y" { List_Add(ActualView->VP, &yyvsp[0].d) ; ; break;} case 88: #line 476 "Gmsh.y" { List_Add(ActualView->VP, &yyvsp[0].d) ; ; break;} case 89: #line 481 "Gmsh.y" { List_Add(ActualView->VP, &yyvsp[-5].d); List_Add(ActualView->VP, &yyvsp[-3].d); List_Add(ActualView->VP, &yyvsp[-1].d); ; break;} case 90: #line 486 "Gmsh.y" { ActualView->NbVP++ ; ; break;} case 91: #line 493 "Gmsh.y" { List_Add(ActualView->TP, &yyvsp[0].d) ; ; break;} case 92: #line 495 "Gmsh.y" { List_Add(ActualView->TP, &yyvsp[0].d) ; ; break;} case 93: #line 500 "Gmsh.y" { List_Add(ActualView->TP, &yyvsp[-5].d); List_Add(ActualView->TP, &yyvsp[-3].d); List_Add(ActualView->TP, &yyvsp[-1].d); ; break;} case 94: #line 505 "Gmsh.y" { ActualView->NbTP++ ; ; break;} case 95: #line 512 "Gmsh.y" { List_Add(ActualView->SL, &yyvsp[0].d) ; ; break;} case 96: #line 514 "Gmsh.y" { List_Add(ActualView->SL, &yyvsp[0].d) ; ; break;} case 97: #line 520 "Gmsh.y" { List_Add(ActualView->SL, &yyvsp[-11].d); List_Add(ActualView->SL, &yyvsp[-5].d); List_Add(ActualView->SL, &yyvsp[-9].d); List_Add(ActualView->SL, &yyvsp[-3].d); List_Add(ActualView->SL, &yyvsp[-7].d); List_Add(ActualView->SL, &yyvsp[-1].d); ; break;} case 98: #line 526 "Gmsh.y" { ActualView->NbSL++ ; ; break;} case 99: #line 533 "Gmsh.y" { List_Add(ActualView->VL, &yyvsp[0].d) ; ; break;} case 100: #line 535 "Gmsh.y" { List_Add(ActualView->VL, &yyvsp[0].d) ; ; break;} case 101: #line 541 "Gmsh.y" { List_Add(ActualView->SL, &yyvsp[-11].d); List_Add(ActualView->SL, &yyvsp[-5].d); List_Add(ActualView->SL, &yyvsp[-9].d); List_Add(ActualView->SL, &yyvsp[-3].d); List_Add(ActualView->SL, &yyvsp[-7].d); List_Add(ActualView->SL, &yyvsp[-1].d); ; break;} case 102: #line 547 "Gmsh.y" { ActualView->NbVL++ ; ; break;} case 103: #line 554 "Gmsh.y" { List_Add(ActualView->TL, &yyvsp[0].d) ; ; break;} case 104: #line 556 "Gmsh.y" { List_Add(ActualView->TL, &yyvsp[0].d) ; ; break;} case 105: #line 562 "Gmsh.y" { List_Add(ActualView->SL, &yyvsp[-11].d); List_Add(ActualView->SL, &yyvsp[-5].d); List_Add(ActualView->SL, &yyvsp[-9].d); List_Add(ActualView->SL, &yyvsp[-3].d); List_Add(ActualView->SL, &yyvsp[-7].d); List_Add(ActualView->SL, &yyvsp[-1].d); ; break;} case 106: #line 568 "Gmsh.y" { ActualView->NbTL++ ; ; break;} case 107: #line 575 "Gmsh.y" { List_Add(ActualView->ST, &yyvsp[0].d) ; ; break;} case 108: #line 577 "Gmsh.y" { List_Add(ActualView->ST, &yyvsp[0].d) ; ; break;} case 109: #line 584 "Gmsh.y" { List_Add(ActualView->ST, &yyvsp[-17].d); List_Add(ActualView->ST, &yyvsp[-11].d); List_Add(ActualView->ST, &yyvsp[-5].d); List_Add(ActualView->ST, &yyvsp[-15].d); List_Add(ActualView->ST, &yyvsp[-9].d); List_Add(ActualView->ST, &yyvsp[-3].d); List_Add(ActualView->ST, &yyvsp[-13].d); List_Add(ActualView->ST, &yyvsp[-7].d); List_Add(ActualView->ST, &yyvsp[-1].d); ; break;} case 110: #line 593 "Gmsh.y" { ActualView->NbST++ ; ; break;} case 111: #line 600 "Gmsh.y" { List_Add(ActualView->VT, &yyvsp[0].d) ; ; break;} case 112: #line 602 "Gmsh.y" { List_Add(ActualView->VT, &yyvsp[0].d) ; ; break;} case 113: #line 609 "Gmsh.y" { List_Add(ActualView->VT, &yyvsp[-17].d); List_Add(ActualView->VT, &yyvsp[-11].d); List_Add(ActualView->VT, &yyvsp[-5].d); List_Add(ActualView->VT, &yyvsp[-15].d); List_Add(ActualView->VT, &yyvsp[-9].d); List_Add(ActualView->VT, &yyvsp[-3].d); List_Add(ActualView->VT, &yyvsp[-13].d); List_Add(ActualView->VT, &yyvsp[-7].d); List_Add(ActualView->VT, &yyvsp[-1].d); ; break;} case 114: #line 618 "Gmsh.y" { ActualView->NbVT++ ; ; break;} case 115: #line 625 "Gmsh.y" { List_Add(ActualView->TT, &yyvsp[0].d) ; ; break;} case 116: #line 627 "Gmsh.y" { List_Add(ActualView->TT, &yyvsp[0].d) ; ; break;} case 117: #line 634 "Gmsh.y" { List_Add(ActualView->TT, &yyvsp[-17].d); List_Add(ActualView->TT, &yyvsp[-11].d); List_Add(ActualView->TT, &yyvsp[-5].d); List_Add(ActualView->TT, &yyvsp[-15].d); List_Add(ActualView->TT, &yyvsp[-9].d); List_Add(ActualView->TT, &yyvsp[-3].d); List_Add(ActualView->TT, &yyvsp[-13].d); List_Add(ActualView->TT, &yyvsp[-7].d); List_Add(ActualView->TT, &yyvsp[-1].d); ; break;} case 118: #line 643 "Gmsh.y" { ActualView->NbTT++ ; ; break;} case 119: #line 650 "Gmsh.y" { List_Add(ActualView->SS, &yyvsp[0].d) ; ; break;} case 120: #line 652 "Gmsh.y" { List_Add(ActualView->SS, &yyvsp[0].d) ; ; break;} case 121: #line 660 "Gmsh.y" { List_Add(ActualView->SS, &yyvsp[-23].d); List_Add(ActualView->SS, &yyvsp[-17].d); List_Add(ActualView->SS, &yyvsp[-11].d); List_Add(ActualView->SS, &yyvsp[-5].d); List_Add(ActualView->SS, &yyvsp[-21].d); List_Add(ActualView->SS, &yyvsp[-15].d); List_Add(ActualView->SS, &yyvsp[-9].d); List_Add(ActualView->SS, &yyvsp[-3].d); List_Add(ActualView->SS, &yyvsp[-19].d); List_Add(ActualView->SS, &yyvsp[-13].d); List_Add(ActualView->SS, &yyvsp[-7].d); List_Add(ActualView->SS, &yyvsp[-1].d); ; break;} case 122: #line 669 "Gmsh.y" { ActualView->NbSS++ ; ; break;} case 123: #line 676 "Gmsh.y" { List_Add(ActualView->VS, &yyvsp[0].d) ; ; break;} case 124: #line 678 "Gmsh.y" { List_Add(ActualView->VS, &yyvsp[0].d) ; ; break;} case 125: #line 686 "Gmsh.y" { List_Add(ActualView->VS, &yyvsp[-23].d); List_Add(ActualView->VS, &yyvsp[-17].d); List_Add(ActualView->VS, &yyvsp[-11].d); List_Add(ActualView->VS, &yyvsp[-5].d); List_Add(ActualView->VS, &yyvsp[-21].d); List_Add(ActualView->VS, &yyvsp[-15].d); List_Add(ActualView->VS, &yyvsp[-9].d); List_Add(ActualView->VS, &yyvsp[-3].d); List_Add(ActualView->VS, &yyvsp[-19].d); List_Add(ActualView->VS, &yyvsp[-13].d); List_Add(ActualView->VS, &yyvsp[-7].d); List_Add(ActualView->VS, &yyvsp[-1].d); ; break;} case 126: #line 695 "Gmsh.y" { ActualView->NbVS++ ; ; break;} case 127: #line 702 "Gmsh.y" { List_Add(ActualView->TS, &yyvsp[0].d) ; ; break;} case 128: #line 704 "Gmsh.y" { List_Add(ActualView->TS, &yyvsp[0].d) ; ; break;} case 129: #line 712 "Gmsh.y" { List_Add(ActualView->TS, &yyvsp[-23].d); List_Add(ActualView->TS, &yyvsp[-17].d); List_Add(ActualView->TS, &yyvsp[-11].d); List_Add(ActualView->TS, &yyvsp[-5].d); List_Add(ActualView->TS, &yyvsp[-21].d); List_Add(ActualView->TS, &yyvsp[-15].d); List_Add(ActualView->TS, &yyvsp[-9].d); List_Add(ActualView->TS, &yyvsp[-3].d); List_Add(ActualView->TS, &yyvsp[-19].d); List_Add(ActualView->TS, &yyvsp[-13].d); List_Add(ActualView->TS, &yyvsp[-7].d); List_Add(ActualView->TS, &yyvsp[-1].d); ; break;} case 130: #line 721 "Gmsh.y" { ActualView->NbTS++ ; ; break;} case 131: #line 737 "Gmsh.y" { TheSymbol.Name = yyvsp[-3].c; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))){ TheSymbol.val = List_Create(1,1,sizeof(double)); List_Put(TheSymbol.val, 0, &yyvsp[-1].d); List_Add(Symbol_L, &TheSymbol); } else{ List_Write(pSymbol->val, 0, &yyvsp[-1].d); } ; break;} case 132: #line 749 "Gmsh.y" { TheSymbol.Name = yyvsp[-6].c; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))){ TheSymbol.val = List_Create(5,5,sizeof(double)); List_Put(TheSymbol.val, (int)yyvsp[-4].d, &yyvsp[-1].d); List_Add(Symbol_L, &TheSymbol); } else{ List_Put(pSymbol->val, (int)yyvsp[-4].d, &yyvsp[-1].d); } ; break;} case 133: #line 761 "Gmsh.y" { TheSymbol.Name = yyvsp[-2].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-2].c) ; else{ *(double*)List_Pointer_Fast(pSymbol->val, 0) += 1.0 ; } ; break;} case 134: #line 770 "Gmsh.y" { TheSymbol.Name = yyvsp[-5].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-5].c) ; else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-3].d))) *pd += 1.0 ; else vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-5].c, (int)yyvsp[-3].d) ; } ; break;} case 135: #line 782 "Gmsh.y" { TheSymbol.Name = yyvsp[-2].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-2].c) ; else *(double*)List_Pointer_Fast(pSymbol->val, 0) -= 1. ; ; break;} case 136: #line 790 "Gmsh.y" { TheSymbol.Name = yyvsp[-5].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-5].c) ; else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-3].d))) *pd -= 1.0 ; else vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-5].c, (int)yyvsp[-3].d) ; } ; break;} case 137: #line 802 "Gmsh.y" { TheSymbol.Name = yyvsp[-3].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-3].c) ; else *(double*)List_Pointer_Fast(pSymbol->val, 0) += yyvsp[-1].d ; ; break;} case 138: #line 810 "Gmsh.y" { TheSymbol.Name = yyvsp[-6].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-6].c) ; else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-4].d))) *pd += yyvsp[-1].d ; else vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-6].c, (int)yyvsp[-4].d) ; } ; break;} case 139: #line 822 "Gmsh.y" { TheSymbol.Name = yyvsp[-3].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-3].c) ; else *(double*)List_Pointer_Fast(pSymbol->val, 0) -= yyvsp[-1].d ; ; break;} case 140: #line 830 "Gmsh.y" { TheSymbol.Name = yyvsp[-6].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-6].c) ; else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-4].d))) *pd -= yyvsp[-1].d ; else vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-6].c, (int)yyvsp[-4].d) ; } ; break;} case 141: #line 842 "Gmsh.y" { TheSymbol.Name = yyvsp[-3].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-3].c) ; else *(double*)List_Pointer_Fast(pSymbol->val, 0) *= yyvsp[-1].d ; ; break;} case 142: #line 850 "Gmsh.y" { TheSymbol.Name = yyvsp[-6].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-6].c) ; else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-4].d))) *pd *= yyvsp[-1].d ; else vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-6].c, (int)yyvsp[-4].d) ; } ; break;} case 143: #line 862 "Gmsh.y" { if(!yyvsp[-1].d) vyyerror("Division by Zero in '%s /= %g'", yyvsp[-3].c, yyvsp[-1].d); else{ TheSymbol.Name = yyvsp[-3].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-3].c) ; else *(double*)List_Pointer_Fast(pSymbol->val, 0) /= yyvsp[-1].d ; } ; break;} case 144: #line 874 "Gmsh.y" { if(!yyvsp[-1].d) vyyerror("Division by Zero in '%s[%d] /= %g'", yyvsp[-6].c, (int)yyvsp[-4].d, yyvsp[-1].d); else{ TheSymbol.Name = yyvsp[-6].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) vyyerror("Unknown Variable '%s'", yyvsp[-6].c) ; else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-4].d))) *pd /= yyvsp[-1].d ; else vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-6].c, (int)yyvsp[-4].d) ; } } ; break;} case 145: #line 893 "Gmsh.y" { if(!(pStrCat = Get_StringOptionCategory(yyvsp[-5].c))) vyyerror("Unknown String Option Class '%s'", yyvsp[-5].c); else{ if(!(pStrOpt = Get_StringOption(yyvsp[-3].c, pStrCat))) vyyerror("Unknown String Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ *pStrOpt = yyvsp[-1].c ; } } ; break;} case 146: #line 906 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pStrViewOpt = Get_StringViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown String Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ strcpy(pStrViewOpt, yyvsp[-1].c) ; } } ; break;} case 147: #line 924 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-5].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-3].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt = yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt = (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt = (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt = (int)yyvsp[-1].d ; break ; } } } ; break;} case 148: #line 941 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt = yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt = (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt = (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt = (int)yyvsp[-1].d ; break ; } } } ; break;} case 149: #line 962 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-5].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-3].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt += yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt += (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt += (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt += (int)yyvsp[-1].d ; break ; } } } ; break;} case 150: #line 979 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt += yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt += (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt += (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt += (int)yyvsp[-1].d ; break ; } } } ; break;} case 151: #line 1000 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-5].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-3].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt -= yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt -= (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt -= (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt -= (int)yyvsp[-1].d ; break ; } } } ; break;} case 152: #line 1017 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt -= yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt -= (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt -= (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt -= (int)yyvsp[-1].d ; break ; } } } ; break;} case 153: #line 1038 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-5].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-3].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt *= yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt *= (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt *= (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt *= (int)yyvsp[-1].d ; break ; } } } ; break;} case 154: #line 1055 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt *= yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt *= (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt *= (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt *= (int)yyvsp[-1].d ; break ; } } } ; break;} case 155: #line 1076 "Gmsh.y" { if(!yyvsp[-1].d) vyyerror("Division by Zero in '%s.%s /= %g'", yyvsp[-5].c, yyvsp[-3].c, yyvsp[-1].d); else{ if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-5].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-3].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt /= yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt /= (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt /= (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt /= (int)yyvsp[-1].d ; break ; } } } } ; break;} case 156: #line 1097 "Gmsh.y" { if(!yyvsp[-1].d) vyyerror("Division by Zero in '%s.View[%d].%s /= %g'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c, yyvsp[-1].d); else{ if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt /= yyvsp[-1].d ; break ; case GMSH_FLOAT : *(float*)pNumOpt /= (float)yyvsp[-1].d ; break ; case GMSH_LONG : *(long*)pNumOpt /= (long)yyvsp[-1].d ; break ; case GMSH_INT : *(int*)pNumOpt /= (int)yyvsp[-1].d ; break ; } } } } ; break;} case 157: #line 1123 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-4].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-4].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-2].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-4].c, yyvsp[-2].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt += 1. ; break ; case GMSH_FLOAT : *(float*)pNumOpt += 1. ; break ; case GMSH_LONG : *(long*)pNumOpt += 1 ; break ; case GMSH_INT : *(int*)pNumOpt += 1 ; break ; } } } ; break;} case 158: #line 1140 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt += 1. ; break ; case GMSH_FLOAT : *(float*)pNumOpt += 1. ; break ; case GMSH_LONG : *(long*)pNumOpt += 1 ; break ; case GMSH_INT : *(int*)pNumOpt += 1 ; break ; } } } ; break;} case 159: #line 1161 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-4].c))) vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-4].c); else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-2].c, pNumCat, &i))) vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-4].c, yyvsp[-2].c); else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt -= 1. ; break ; case GMSH_FLOAT : *(float*)pNumOpt -= 1. ; break ; case GMSH_LONG : *(long*)pNumOpt -= 1 ; break ; case GMSH_INT : *(int*)pNumOpt -= 1 ; break ; } } } ; break;} case 160: #line 1178 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : *(double*)pNumOpt -= 1. ; break ; case GMSH_FLOAT : *(float*)pNumOpt -= 1. ; break ; case GMSH_LONG : *(long*)pNumOpt -= 1 ; break ; case GMSH_INT : *(int*)pNumOpt -= 1 ; break ; } } } ; break;} case 161: #line 1201 "Gmsh.y" { if(!(pArrCat = Get_ArrayOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Array Option Class '%s'", yyvsp[-5].c); else{ if(!(pArrOpt = Get_ArrayOption(yyvsp[-3].c, pArrCat, &i))) vyyerror("Unknown Array Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<4; j++) ((double*)pArrOpt)[j] = yyvsp[-1].v[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<4; j++) ((float*)pArrOpt)[j] = (float)yyvsp[-1].v[j] ; break ; case GMSH_LONG : for(j=0 ; j<4; j++) ((long*)pArrOpt)[j] = (long)yyvsp[-1].v[j] ; break ; case GMSH_INT : for(j=0 ; j<4; j++) ((int*)pArrOpt)[j] = (int)yyvsp[-1].v[j] ; break ; } } } ; break;} case 162: #line 1226 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pArrOpt = Get_ArrayViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Array Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<3; j++) ((double*)pArrOpt)[j] = yyvsp[-1].v[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<3; j++) ((float*)pArrOpt)[j] = (float)yyvsp[-1].v[j] ; break ; case GMSH_LONG : for(j=0 ; j<3; j++) ((long*)pArrOpt)[j] = (long)yyvsp[-1].v[j] ; break ; case GMSH_INT : for(j=0 ; j<3; j++) ((int*)pArrOpt)[j] = (int)yyvsp[-1].v[j] ; break ; } } } ; break;} case 163: #line 1255 "Gmsh.y" { if(!(pArrCat = Get_ArrayOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Array Option Class '%s'", yyvsp[-5].c); else{ if(!(pArrOpt = Get_ArrayOption(yyvsp[-3].c, pArrCat, &i))) vyyerror("Unknown Array Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<4; j++) ((double*)pArrOpt)[j] += yyvsp[-1].v[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<4; j++) ((float*)pArrOpt)[j] += (float)yyvsp[-1].v[j] ; break ; case GMSH_LONG : for(j=0 ; j<4; j++) ((long*)pArrOpt)[j] += (long)yyvsp[-1].v[j] ; break ; case GMSH_INT : for(j=0 ; j<4; j++) ((int*)pArrOpt)[j] += (int)yyvsp[-1].v[j] ; break ; } } } ; break;} case 164: #line 1280 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pArrOpt = Get_ArrayViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Array Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<3; j++) ((double*)pArrOpt)[j] += yyvsp[-1].v[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<3; j++) ((float*)pArrOpt)[j] += (float)yyvsp[-1].v[j] ; break ; case GMSH_LONG : for(j=0 ; j<3; j++) ((long*)pArrOpt)[j] += (long)yyvsp[-1].v[j] ; break ; case GMSH_INT : for(j=0 ; j<3; j++) ((int*)pArrOpt)[j] += (int)yyvsp[-1].v[j] ; break ; } } } ; break;} case 165: #line 1309 "Gmsh.y" { if(!(pArrCat = Get_ArrayOptionCategory(yyvsp[-5].c))) vyyerror("Unknown Array Option Class '%s'", yyvsp[-5].c); else{ if(!(pArrOpt = Get_ArrayOption(yyvsp[-3].c, pArrCat, &i))) vyyerror("Unknown Array Option '%s.%s'", yyvsp[-5].c, yyvsp[-3].c); else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<4; j++) ((double*)pArrOpt)[j] -= yyvsp[-1].v[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<4; j++) ((float*)pArrOpt)[j] -= (float)yyvsp[-1].v[j] ; break ; case GMSH_LONG : for(j=0 ; j<4; j++) ((long*)pArrOpt)[j] -= (long)yyvsp[-1].v[j] ; break ; case GMSH_INT : for(j=0 ; j<4; j++) ((int*)pArrOpt)[j] -= (int)yyvsp[-1].v[j] ; break ; } } } ; break;} case 166: #line 1334 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ if(!(pArrOpt = Get_ArrayViewOption((int)yyvsp[-6].d, yyvsp[-3].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else vyyerror("Unknown Array Option '%s.View[%d].%s'", yyvsp[-10].c, (int)yyvsp[-6].d, yyvsp[-3].c); } else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<3; j++) ((double*)pArrOpt)[j] -= yyvsp[-1].v[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<3; j++) ((float*)pArrOpt)[j] -= (float)yyvsp[-1].v[j] ; break ; case GMSH_LONG : for(j=0 ; j<3; j++) ((long*)pArrOpt)[j] -= (long)yyvsp[-1].v[j] ; break ; case GMSH_INT : for(j=0 ; j<3; j++) ((int*)pArrOpt)[j] -= (int)yyvsp[-1].v[j] ; break ; } } } ; break;} case 167: #line 1365 "Gmsh.y" { if(!(pColCat = Get_ColorOptionCategory(yyvsp[-7].c))) vyyerror("Unknown Color Option Class '%s'", yyvsp[-7].c); else{ if(!(pColOpt = Get_ColorOption(yyvsp[-3].c, pColCat))) vyyerror("Unknown Color Option '%s.%s'", yyvsp[-7].c, yyvsp[-3].c); else{ *pColOpt = yyvsp[-1].u ; } } ; break;} case 168: #line 1378 "Gmsh.y" { if(strcmp(yyvsp[-10].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-10].c); else{ ColorTable *ct = Get_ColorTableViewOption((int)yyvsp[-6].d); if(!ct) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-6].d); else{ ct->size = List_Nbr(yyvsp[-1].l); if(ct->size > COLORTABLE_NBMAX_COLOR) vyyerror("Too Many (%d>%d) Colors in Post.View[%d].Color", ct->size, COLORTABLE_NBMAX_COLOR, (int)yyvsp[-6].d); else for(i=0 ; i<ct->size ; i++) List_Read(yyvsp[-1].l, i, &ct->table[i]); } } ; break;} case 169: #line 1407 "Gmsh.y" { Cdbpts101((int)yyvsp[-4].d,yyvsp[-1].v[0],yyvsp[-1].v[1],yyvsp[-1].v[2],yyvsp[-1].v[3],yyvsp[-1].v[4]); yyval.s.Type = MSH_POINT; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 170: #line 1414 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_PHYSICAL_POINT,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_PHYSICAL_POINT; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 171: #line 1420 "Gmsh.y" { Vertex *v; Attractor *a; double p; int ip; for(int i=0;i<List_Nbr(yyvsp[-9].l);i++){ List_Read(yyvsp[-9].l,i,&p); ip = (int)p; v = FindVertex(ip,THEM); if(!v) vyyerror("Unkown Point %d", ip); else{ a = Create_Attractor(List_Nbr(THEM->Metric->Attractors)+1, yyvsp[-6].d,yyvsp[-4].d,yyvsp[-2].d,v,NULL,NULL); List_Add(THEM->Metric->Attractors,&a); } } ; break;} case 172: #line 1439 "Gmsh.y" { for(i=0;i<List_Nbr(yyvsp[-3].l);i++){ List_Read(yyvsp[-3].l,i,&d); Vertex *v = FindVertex((int)d,THEM); if(!v) vyyerror("Unkown Point %d", (int)d); else v->lc = yyvsp[-1].d; } ; break;} case 173: #line 1450 "Gmsh.y" { yyval.s.Type = MSH_POINT; yyval.s.Num = (int)yyvsp[-2].d; ; break;} case 174: #line 1458 "Gmsh.y" { Cdbseg101((int)yyvsp[-4].d,MSH_SEGM_LINE,1,yyvsp[-1].l,NULL,-1,-1,0.,1.,NULL,NULL,NULL); yyval.s.Type = MSH_SEGM_LINE; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 175: #line 1464 "Gmsh.y" { Cdbseg101((int)yyvsp[-4].d,MSH_SEGM_SPLN,3,yyvsp[-1].l,NULL,-1,-1,0.,1.,NULL,NULL,NULL); yyval.s.Type = MSH_SEGM_SPLN; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 176: #line 1470 "Gmsh.y" { Curve *c; Attractor *a; double p; int ip; for(int i=0;i<List_Nbr(yyvsp[-9].l);i++){ List_Read(yyvsp[-9].l,i,&p); ip = (int)p; c = FindCurve(ip,THEM); if(!c) vyyerror("Unkown Curve %d", ip); else{ a = Create_Attractor(List_Nbr(THEM->Metric->Attractors)+1, yyvsp[-6].d,yyvsp[-4].d,yyvsp[-2].d,NULL,c,NULL); List_Add(THEM->Metric->Attractors,&a); } } ; break;} case 177: #line 1489 "Gmsh.y" { Cdbseg101((int)yyvsp[-4].d,MSH_SEGM_CIRC,2,yyvsp[-1].l,NULL,-1,-1,0.,1.,NULL,NULL,NULL); yyval.s.Type = MSH_SEGM_CIRC ; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 178: #line 1495 "Gmsh.y" { List_T *temp; int i,j; double d; temp = List_Create(List_Nbr(yyvsp[-3].l),1,sizeof(int)); for(i=0;i<List_Nbr(yyvsp[-3].l);i++){ List_Read(yyvsp[-3].l,i,&d); j = (int)d; List_Add(temp,&j); } AddCircleInDataBase ((int) yyvsp[-6].d, MSH_SEGM_CIRC, temp, yyvsp[-1].v); List_Delete(temp); yyval.s.Type = MSH_SEGM_CIRC ; yyval.s.Num = (int)yyvsp[-6].d; ; break;} case 179: #line 1512 "Gmsh.y" { Cdbseg101((int)yyvsp[-14].d,MSH_SEGM_PARAMETRIC,2,NULL,NULL,-1,-1,yyvsp[-10].d,yyvsp[-8].d,yyvsp[-6].c,yyvsp[-4].c,yyvsp[-2].c); yyval.s.Type = MSH_SEGM_PARAMETRIC ; yyval.s.Num = (int)yyvsp[-14].d; ; break;} case 180: #line 1518 "Gmsh.y" { Cdbseg101((int)yyvsp[-4].d,MSH_SEGM_ELLI,2,yyvsp[-1].l,NULL,-1,-1,0.,1.,NULL,NULL,NULL); yyval.s.Type = MSH_SEGM_ELLI ; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 181: #line 1524 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_PHYSICAL_LINE,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_PHYSICAL_LINE; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 182: #line 1530 "Gmsh.y" { yyval.s.Type = MSH_SEGM_LOOP; Cdbz101((int)yyvsp[-4].d,yyval.s.Type,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 183: #line 1536 "Gmsh.y" { Cdbseg101((int)yyvsp[-4].d,MSH_SEGM_BSPLN,2,yyvsp[-1].l,NULL,-1,-1,0.,1.,NULL,NULL,NULL); yyval.s.Type = MSH_SEGM_BSPLN; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 184: #line 1542 "Gmsh.y" { List_T *Temp; int i; double d; if((int)yyvsp[-1].d + 1 + List_Nbr(yyvsp[-5].l) != List_Nbr(yyvsp[-3].l)){ vyyerror("Wrong Definition of Nurbs Curve %d: " "[Degree]%d + 1 + [NbPts]%d != [NbKnots]%d", (int)yyvsp[-8].d, (int)yyvsp[-1].d, List_Nbr(yyvsp[-5].l), List_Nbr(yyvsp[-3].l)); } Temp = List_Create(List_Nbr(yyvsp[-5].l),1,sizeof(int)); for(i=0;i<List_Nbr(yyvsp[-5].l);i++) { List_Read(yyvsp[-5].l,i,&d); j = (int)d; List_Add(Temp,&j); } AddCurveInDataBase ((int)yyvsp[-8].d,MSH_SEGM_NURBS,(int)yyvsp[-1].d,Temp,yyvsp[-3].l,-1,-1,0.,1.); List_Delete(Temp); ; break;} case 185: #line 1561 "Gmsh.y" { yyval.s.Num = (int)yyvsp[-2].d; Curve *c = FindCurve(yyval.s.Num,THEM); if(!c) vyyerror("Unkown Curve %d", yyval.s.Num); else yyval.s.Type = c->Typ; ; break;} case 186: #line 1573 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_SURF_PLAN,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_SURF_PLAN; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 187: #line 1579 "Gmsh.y" { Surface *s,*support; support = FindSurface((int)yyvsp[-2].d,THEM); if(!support) vyyerror("Unkown Surface %d", (int)yyvsp[-2].d); else{ Cdbz101((int)yyvsp[-5].d,MSH_SURF_PLAN,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); s = FindSurface((int)yyvsp[-5].d,THEM); if(!s) vyyerror("Unkown Surface %d", (int)yyvsp[-5].d); else{ s->Typ = MSH_SURF_TRIMMED; s->Support = support; yyval.s.Type = MSH_SURF_TRIMMED; yyval.s.Num = (int)yyvsp[-5].d; } } ; break;} case 188: #line 1598 "Gmsh.y" { List_Read(yyvsp[-1].l,0,&d); i = (int)d; EdgeLoop *el = FindEdgeLoop(i,THEM); if(!el) vyyerror("Unkown Loop %d", i); else{ j = List_Nbr(el->Curves); if(j==4) yyval.s.Type = MSH_SURF_REGL; else if(j==3) yyval.s.Type = MSH_SURF_TRIC; else vyyerror("Wrong Definition of Ruled Surface %d: " "%d Borders Instead of 3 or 4", (int)yyvsp[-4].d, j); Cdbz101((int)yyvsp[-4].d,yyval.s.Type,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Num = (int)yyvsp[-4].d; } ; break;} case 189: #line 1621 "Gmsh.y" { CreateNurbsSurface ( (int) yyvsp[-16].d , (int)yyvsp[-4].d , (int)yyvsp[-2].d , yyvsp[-13].l, yyvsp[-10].l, yyvsp[-8].l); yyval.s.Type = MSH_SURF_NURBS; yyval.s.Num = (int)yyvsp[-16].d; ; break;} case 190: #line 1629 "Gmsh.y" { CreateNurbsSurfaceSupport ((int)yyvsp[-16].d, (int) yyvsp[-4].d , (int) yyvsp[-2].d , yyvsp[-13].l, yyvsp[-10].l, yyvsp[-8].l); ; break;} case 191: #line 1633 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_PHYSICAL_SURFACE,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_PHYSICAL_SURFACE; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 192: #line 1639 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_SURF_LOOP,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_SURF_LOOP; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 193: #line 1645 "Gmsh.y" { yyval.s.Num = (int)yyvsp[-2].d; Surface *s = FindSurface(yyval.s.Num,THEM); if(!s) vyyerror("Unknown Surface %d", yyval.s.Num); else yyval.s.Type = s->Typ; ; break;} case 194: #line 1657 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_VOLUME,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_VOLUME; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 195: #line 1663 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_VOLUME,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_VOLUME; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 196: #line 1669 "Gmsh.y" { Cdbz101((int)yyvsp[-4].d,MSH_PHYSICAL_VOLUME,0,0,0,0,0,NULL,yyvsp[-1].l,NULL); yyval.s.Type = MSH_PHYSICAL_VOLUME; yyval.s.Num = (int)yyvsp[-4].d; ; break;} case 197: #line 1682 "Gmsh.y" { TranslateShapes (yyvsp[-3].v[0],yyvsp[-3].v[1],yyvsp[-3].v[2],yyvsp[-1].l,1); yyval.l = yyvsp[-1].l; ; break;} case 198: #line 1687 "Gmsh.y" { RotateShapes(yyvsp[-8].v[0],yyvsp[-8].v[1],yyvsp[-8].v[2],yyvsp[-6].v[0],yyvsp[-6].v[1],yyvsp[-6].v[2],yyvsp[-4].d,yyvsp[-1].l); yyval.l = yyvsp[-1].l; ; break;} case 199: #line 1692 "Gmsh.y" { SymmetryShapes(yyvsp[-3].v[0],yyvsp[-3].v[1],yyvsp[-3].v[2],yyvsp[-3].v[3],yyvsp[-1].l,1); yyval.l = yyvsp[-1].l; ; break;} case 200: #line 1697 "Gmsh.y" { DilatShapes(yyvsp[-6].v[0],yyvsp[-6].v[1],yyvsp[-6].v[2],yyvsp[-4].d,yyvsp[-1].l,1); yyval.l = yyvsp[-1].l; ; break;} case 201: #line 1704 "Gmsh.y" { yyval.l = yyvsp[0].l; ; break;} case 202: #line 1705 "Gmsh.y" { yyval.l = yyvsp[0].l; ; break;} case 203: #line 1706 "Gmsh.y" { yyval.l = yyvsp[0].l; ; break;} case 204: #line 1711 "Gmsh.y" { yyval.l = List_Create(3,3,sizeof(Shape)); ; break;} case 205: #line 1715 "Gmsh.y" { List_Add(yyval.l,&yyvsp[0].s); yyval.l = yyvsp[-1].l; ; break;} case 206: #line 1727 "Gmsh.y" { yyval.l = List_Create(3,3,sizeof(Shape)); for(i=0;i<List_Nbr(yyvsp[-1].l);i++){ List_Read (yyvsp[-1].l,i,&TheShape); CopyShape(TheShape.Type,TheShape.Num,&j); TheShape.Num = j; List_Add(yyval.l,&TheShape); } ; break;} case 207: #line 1745 "Gmsh.y" { for(i=0;i<List_Nbr(yyvsp[-1].l);i++){ List_Read (yyvsp[-1].l,i,&TheShape); DeleteShape(TheShape.Type,TheShape.Num); } ; break;} case 208: #line 1760 "Gmsh.y" { if(!strcmp(yyvsp[-2].c, "Include")){ yyinTab[RecursionLevel++] = yyin; strcpy(tmpstring, ThePathForIncludes); if((yyin = fopen(strcat(tmpstring,yyvsp[-1].c),"r"))){ strcpy(yynameTab[RecursionLevel-1],yyname); yylinenoTab[RecursionLevel-1]=yylineno; yylineno=1; strcpy(yyname,yyvsp[-1].c); while(!feof(yyin)){ yyparse(); } fclose(yyin); yyin = yyinTab[--RecursionLevel]; strcpy(yyname,yynameTab[RecursionLevel]); yylineno = yylinenoTab[RecursionLevel]; } else{ vyyerror("Unknown File '%s'", yyvsp[-1].c) ; yyin = yyinTab[--RecursionLevel]; } } else if(!strcmp(yyvsp[-2].c, "Print")){ if(!CTX.interactive){ // we're in interactive mode char ext[6]; strcpy(ext,yyvsp[-1].c+(strlen(yyvsp[-1].c)-4)); Replot(); extern void CreateImage (char *name, FILE *fp); FILE *fp = 0; if(!strcmp(ext,".gif")){ fp = fopen(yyvsp[-1].c,"wb"); CTX.print.type = PRINT_GL2GIF; } else if(!strcmp(ext,".eps")){ fp = fopen(yyvsp[-1].c,"w"); CTX.print.type = PRINT_GL2PS_RECURSIVE; } else if(!strcmp(ext,".xpm")){ fp = fopen(yyvsp[-1].c,"wb"); CTX.print.type = PRINT_XDUMP; CTX.print.format = FORMAT_XPM; } if(fp){ CreateImage(yyvsp[-1].c,fp); fclose(fp); } else{ vyyerror("Unable to Open File '%s'", yyvsp[-1].c); } } } else if(!strcmp(yyvsp[-2].c, "Merge")){ FILE *ff = yyin; MergeProblem(yyvsp[-1].c); yyin = ff; } else if(!strcmp(yyvsp[-2].c, "Save")){ Print_Mesh(THEM, yyvsp[-1].c, CTX.mesh.format); } else vyyerror("Unknown Command '%s'", yyvsp[-2].c); ; break;} case 209: #line 1831 "Gmsh.y" { if(!strcmp(yyvsp[-2].c, "Sleep")){ extern long Get_AnimTime(); long sleep_time = Get_AnimTime(); while(1){ if(Get_AnimTime() - sleep_time > (long)(yyvsp[-1].d*1.e6)) break; } } else if(!strcmp(yyvsp[-2].c, "Mesh")){ Maillage_Dimension_0(THEM); mai3d(THEM,(int)yyvsp[-1].d); } else vyyerror("Unknown Command '%s'", yyvsp[-2].c); ; break;} case 210: #line 1851 "Gmsh.y" { exit(0); ; break;} case 211: #line 1855 "Gmsh.y" { if(!CTX.interactive){ // we're in interactive mode if(Tree_Nbr(THEM->Points) != Last_NumberOfPoints){ Last_NumberOfPoints = Tree_Nbr(THEM->Points); Replot(); } else{ Init(); Draw(); } } ; break;} case 212: #line 1876 "Gmsh.y" { FILE* ff; if(RecursionLevel) ff = yyinTab[RecursionLevel-1]; else ff = yyin; // here, we seek remember the position in yyin LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-3].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-1].d ; LoopControlVariablesTab[ImbricatedLoop][2] = 1.0 ; LoopControlVariablesNameTab[ImbricatedLoop] = "" ; fgetpos( ff, &yyposImbricatedLoopsTab[ImbricatedLoop++]); ; break;} case 213: #line 1890 "Gmsh.y" { FILE* ff; if(RecursionLevel) ff = yyinTab[RecursionLevel-1]; else ff = yyin; // here, we seek remember the position in yyin LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-5].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-3].d ; LoopControlVariablesTab[ImbricatedLoop][2] = yyvsp[-1].d ; LoopControlVariablesNameTab[ImbricatedLoop] = "" ; fgetpos( ff, &yyposImbricatedLoopsTab[ImbricatedLoop++]); ; break;} case 214: #line 1904 "Gmsh.y" { FILE* ff; if(RecursionLevel) ff = yyinTab[RecursionLevel-1]; else ff = yyin; // here, we seek remember the position in yyin LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-3].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-1].d ; LoopControlVariablesTab[ImbricatedLoop][2] = 1.0 ; LoopControlVariablesNameTab[ImbricatedLoop] = yyvsp[-6].c ; TheSymbol.Name = yyvsp[-6].c; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))){ TheSymbol.val = List_Create(1,1,sizeof(double)); List_Put(TheSymbol.val, 0, &yyvsp[-3].d); List_Add(Symbol_L, &TheSymbol); } else{ List_Write(pSymbol->val, 0, &yyvsp[-3].d); } fgetpos( ff, &yyposImbricatedLoopsTab[ImbricatedLoop++]); ; break;} case 215: #line 1929 "Gmsh.y" { FILE* ff; if(RecursionLevel) ff = yyinTab[RecursionLevel-1]; else ff = yyin; // here, we seek remember the position in yyin LoopControlVariablesTab[ImbricatedLoop][0] = yyvsp[-5].d ; LoopControlVariablesTab[ImbricatedLoop][1] = yyvsp[-3].d ; LoopControlVariablesTab[ImbricatedLoop][2] = yyvsp[-1].d ; LoopControlVariablesNameTab[ImbricatedLoop] = yyvsp[-8].c ; TheSymbol.Name = yyvsp[-8].c; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))){ TheSymbol.val = List_Create(1,1,sizeof(double)); List_Put(TheSymbol.val, 0, &yyvsp[-5].d); List_Add(Symbol_L, &TheSymbol); } else{ List_Write(pSymbol->val, 0, &yyvsp[-5].d); } fgetpos( ff, &yyposImbricatedLoopsTab[ImbricatedLoop++]); ; break;} case 216: #line 1954 "Gmsh.y" { if(LoopControlVariablesTab[ImbricatedLoop-1][1] > LoopControlVariablesTab[ImbricatedLoop-1][0]){ FILE* ff; if(RecursionLevel) ff = yyinTab[RecursionLevel-1]; else ff = yyin; LoopControlVariablesTab[ImbricatedLoop-1][0] += LoopControlVariablesTab[ImbricatedLoop-1][2]; if(strlen(LoopControlVariablesNameTab[ImbricatedLoop-1])){ TheSymbol.Name = LoopControlVariablesNameTab[ImbricatedLoop-1]; pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols); *(double*)List_Pointer_Fast(pSymbol->val, 0) += LoopControlVariablesTab[ImbricatedLoop-1][2] ; } fsetpos( yyin, &yyposImbricatedLoopsTab[ImbricatedLoop-1]); } else{ ImbricatedLoop--; } ; break;} case 217: #line 1980 "Gmsh.y" { if(!FunctionManager::Instance()->leaveFunction(&yyin,yylineno)) vyyerror("Error while exiting function"); ; break;} case 218: #line 1985 "Gmsh.y" { if(!FunctionManager::Instance()->enterFunction(yyvsp[-1].c,&yyin,yylineno)) vyyerror("Unknown Function %s",yyvsp[-1].c); ; break;} case 219: #line 1990 "Gmsh.y" { // skip everything until return is found if(!FunctionManager::Instance()->createFunction(yyvsp[0].c,yyin,yylineno)) vyyerror("Redefinition of function %s",yyvsp[0].c); skip_until("Return"); ; break;} case 220: #line 1997 "Gmsh.y" { if(!yyvsp[-1].d) skip_until("EndIf"); ; break;} case 221: #line 2001 "Gmsh.y" { ; break;} case 222: #line 2012 "Gmsh.y" { Curve *pc, *prc; Extrude_ProtudePoint(1,(int)yyvsp[-4].d,yyvsp[-2].v[0],yyvsp[-2].v[1],yyvsp[-2].v[2],0.,0.,0.,0.,&pc,&prc,NULL); ; break;} case 223: #line 2017 "Gmsh.y" { Curve *pc, *prc; Extrude_ProtudePoint(0,(int)yyvsp[-8].d,yyvsp[-6].v[0],yyvsp[-6].v[1],yyvsp[-6].v[2],yyvsp[-4].v[0],yyvsp[-4].v[1],yyvsp[-4].v[2],yyvsp[-2].d, &pc,&prc,NULL); ; break;} case 224: #line 2023 "Gmsh.y" { Extrude_ProtudeCurve(1,(int)yyvsp[-4].d,yyvsp[-2].v[0],yyvsp[-2].v[1],yyvsp[-2].v[2],0.,0.,0.,0.,NULL); ; break;} case 225: #line 2027 "Gmsh.y" { Extrude_ProtudeCurve(0,(int)yyvsp[-8].d,yyvsp[-6].v[0],yyvsp[-6].v[1],yyvsp[-6].v[2],yyvsp[-4].v[0],yyvsp[-4].v[1],yyvsp[-4].v[2],yyvsp[-2].d,NULL); ; break;} case 226: #line 2031 "Gmsh.y" { Extrude_ProtudeSurface(1,(int)yyvsp[-4].d,yyvsp[-2].v[0],yyvsp[-2].v[1],yyvsp[-2].v[2],0.,0.,0.,0.,0,NULL); ; break;} case 227: #line 2035 "Gmsh.y" { Extrude_ProtudeSurface(0,(int)yyvsp[-8].d,yyvsp[-6].v[0],yyvsp[-6].v[1],yyvsp[-6].v[2],yyvsp[-4].v[0],yyvsp[-4].v[1],yyvsp[-4].v[2],yyvsp[-2].d,0,NULL); ; break;} case 228: #line 2039 "Gmsh.y" { int vol = NEWREG(); Extrude_ProtudeSurface(1,(int)yyvsp[-7].d,yyvsp[-5].v[0],yyvsp[-5].v[1],yyvsp[-5].v[2],0.,0.,0.,0.,vol,&extr); ; break;} case 229: #line 2044 "Gmsh.y" { int vol = NEWREG(); Extrude_ProtudeSurface(0,(int)yyvsp[-11].d,yyvsp[-9].v[0],yyvsp[-9].v[1],yyvsp[-9].v[2],yyvsp[-7].v[0],yyvsp[-7].v[1],yyvsp[-7].v[2],yyvsp[-5].d,vol,&extr); ; break;} case 230: #line 2052 "Gmsh.y" { ; break;} case 231: #line 2055 "Gmsh.y" { ; break;} case 232: #line 2061 "Gmsh.y" { double d; int j; extr.mesh.NbLayer = List_Nbr(yyvsp[-6].l); extr.mesh.ExtrudeMesh = true; for(int i=0;i<List_Nbr(yyvsp[-6].l);i++){ List_Read(yyvsp[-6].l,i,&d); j = (int)d; extr.mesh.NbElmLayer[i] = j; List_Read(yyvsp[-4].l,i,&d); j = (int)d; extr.mesh.ZonLayer[i] = j; List_Read(yyvsp[-2].l,i,&d); extr.mesh.hLayer[i] = d; } ; break;} case 233: #line 2078 "Gmsh.y" { extr.mesh.Recombine = true; ; break;} case 234: #line 2089 "Gmsh.y" { Curve *c; for(i=0;i<List_Nbr(yyvsp[-3].l);i++){ List_Read(yyvsp[-3].l,i,&d); j = (int)fabs(d); c = FindCurve(j,THEM); if(!c) vyyerror("Unkown Curve %d", j); else{ c->Method = TRANSFINI; c->ipar[0] = (int)yyvsp[-1].d; c->ipar[1] = sign(d); c->dpar[0] = 1.0; } } ; break;} case 235: #line 2106 "Gmsh.y" { Curve *c; for(i=0;i<List_Nbr(yyvsp[-6].l);i++){ List_Read(yyvsp[-6].l,i,&d); j = (int)fabs(d); c = FindCurve(j,THEM); if(!c) vyyerror("Unkown Curve %d", j); else{ c->Method = TRANSFINI; c->ipar[0] = (int)yyvsp[-4].d; c->ipar[1] = sign(d); /* Progresion : code 1 ou -1 */ c->dpar[0] = fabs(yyvsp[-1].d); } } ; break;} case 236: #line 2123 "Gmsh.y" { Curve *c; for(i=0;i<List_Nbr(yyvsp[-6].l);i++){ List_Read(yyvsp[-6].l,i,&d); j = (int)fabs(d); c = FindCurve(j,THEM); if(!c) vyyerror("Unkown Curve %d", j); else{ c->Method = TRANSFINI; c->ipar[0] = (int)yyvsp[-4].d; c->ipar[1] = 2*sign(d); /* Bump : code 2 ou -2 */ c->dpar[0] = fabs(yyvsp[-1].d); } } ; break;} case 237: #line 2140 "Gmsh.y" { Surface *s = FindSurface((int)yyvsp[-4].d,THEM); if(!s) vyyerror("Unkown Surface %d", (int)yyvsp[-4].d); else{ s->Method = TRANSFINI; k = List_Nbr(yyvsp[-1].l); if(k!=3 && k!=4){ vyyerror("Wrong Definition of Transfinite Surface %d: " "%d Points Instead of 3 or 4" , yyvsp[-4].d, k) ; } else{ for(i=0;i<k;i++){ List_Read(yyvsp[-1].l,i,&d); j = (int)fabs(d); s->ipar[i] = j; } } } ; break;} case 238: #line 2161 "Gmsh.y" { Surface *s = FindSurface((int)yyvsp[-4].d,THEM); if(!s) vyyerror("Unkown Surface %d", (int)yyvsp[-4].d); else{ s->Method = ELLIPTIC; k = List_Nbr(yyvsp[-1].l); if(k != 4) vyyerror("Wrong Definition of Elliptic Surface %d: " "%d Points Instead of 4" , yyvsp[-4].d, k) ; else{ for(i=0;i<k;i++){ List_Read(yyvsp[-1].l,i,&d); j = (int)fabs(d); s->ipar[i] = j; } } } ; break;} case 239: #line 2181 "Gmsh.y" { Volume *v = FindVolume((int)yyvsp[-4].d,THEM); if(!v) vyyerror("Unkown Volume %d", (int)yyvsp[-4].d); else{ v->Method = TRANSFINI; k = List_Nbr(yyvsp[-1].l); if(k!=6 && k!=8) vyyerror("Wrong Definition of Transfinite Volume %d: " "%d Points Instead of 6 or 8" , yyvsp[-4].d, k) ; else{ for(i=0;i<k;i++){ List_Read(yyvsp[-1].l,i,&d); j = (int)fabs(d); v->ipar[i] = j; } } } ; break;} case 240: #line 2201 "Gmsh.y" { Surface *s; for(i=0;i<List_Nbr(yyvsp[-3].l);i++){ List_Read(yyvsp[-3].l,i,&d); j = (int)d; s = FindSurface(j,THEM); if(!s){ /* Allow generic lists, even if the surfaces don't exist vyyerror("Unkown Surface %d", j); */ } else{ s->Recombine = 1; s->RecombineAngle = yyvsp[-1].d; } } ; break;} case 241: #line 2218 "Gmsh.y" { Surface *s; for(i=0;i<List_Nbr(yyvsp[-1].l);i++){ List_Read(yyvsp[-1].l,i,&d); j = (int)d; s = FindSurface(j,THEM); if(!s){ /* Allow generic lists, even if the surfaces don't exist vyyerror("Unkown Surface %d", j); */ } else{ s->Recombine = 1; s->RecombineAngle = 30.; } } ; break;} case 242: #line 2243 "Gmsh.y" { Coherence_PS(); ; break;} case 243: #line 2255 "Gmsh.y" {yyval.i = 1;; break;} case 244: #line 2256 "Gmsh.y" {yyval.i = 0;; break;} case 245: #line 2257 "Gmsh.y" {yyval.i = -1;; break;} case 246: #line 2258 "Gmsh.y" {yyval.i = -1;; break;} case 247: #line 2259 "Gmsh.y" {yyval.i = -1;; break;} case 248: #line 2263 "Gmsh.y" { yyval.d = yyvsp[0].d; ; break;} case 249: #line 2264 "Gmsh.y" { yyval.d = yyvsp[-1].d ; ; break;} case 250: #line 2265 "Gmsh.y" { yyval.d = -yyvsp[0].d ; ; break;} case 251: #line 2266 "Gmsh.y" { yyval.d = yyvsp[0].d; ; break;} case 252: #line 2267 "Gmsh.y" { yyval.d = !yyvsp[0].d ; ; break;} case 253: #line 2268 "Gmsh.y" { yyval.d = yyvsp[-2].d - yyvsp[0].d ; ; break;} case 254: #line 2269 "Gmsh.y" { yyval.d = yyvsp[-2].d + yyvsp[0].d ; ; break;} case 255: #line 2270 "Gmsh.y" { yyval.d = yyvsp[-2].d * yyvsp[0].d ; ; break;} case 256: #line 2272 "Gmsh.y" { if(!yyvsp[0].d) vyyerror("Division by Zero in '%g / %g'", yyvsp[-2].d, yyvsp[0].d); else yyval.d = yyvsp[-2].d / yyvsp[0].d ; ; break;} case 257: #line 2278 "Gmsh.y" { yyval.d = (int)yyvsp[-2].d % (int)yyvsp[0].d ; ; break;} case 258: #line 2279 "Gmsh.y" { yyval.d = pow(yyvsp[-2].d,yyvsp[0].d) ; ; break;} case 259: #line 2280 "Gmsh.y" { yyval.d = yyvsp[-2].d < yyvsp[0].d ; ; break;} case 260: #line 2281 "Gmsh.y" { yyval.d = yyvsp[-2].d > yyvsp[0].d ; ; break;} case 261: #line 2282 "Gmsh.y" { yyval.d = yyvsp[-2].d <= yyvsp[0].d ; ; break;} case 262: #line 2283 "Gmsh.y" { yyval.d = yyvsp[-2].d >= yyvsp[0].d ; ; break;} case 263: #line 2284 "Gmsh.y" { yyval.d = yyvsp[-2].d == yyvsp[0].d ; ; break;} case 264: #line 2285 "Gmsh.y" { yyval.d = yyvsp[-2].d != yyvsp[0].d ; ; break;} case 265: #line 2286 "Gmsh.y" { yyval.d = yyvsp[-2].d && yyvsp[0].d ; ; break;} case 266: #line 2287 "Gmsh.y" { yyval.d = yyvsp[-2].d || yyvsp[0].d ; ; break;} case 267: #line 2288 "Gmsh.y" { yyval.d = yyvsp[-4].d? yyvsp[-2].d : yyvsp[0].d ; ; break;} case 268: #line 2289 "Gmsh.y" { yyval.d = exp(yyvsp[-1].d); ; break;} case 269: #line 2290 "Gmsh.y" { yyval.d = log(yyvsp[-1].d); ; break;} case 270: #line 2291 "Gmsh.y" { yyval.d = log10(yyvsp[-1].d); ; break;} case 271: #line 2292 "Gmsh.y" { yyval.d = sqrt(yyvsp[-1].d); ; break;} case 272: #line 2293 "Gmsh.y" { yyval.d = sin(yyvsp[-1].d); ; break;} case 273: #line 2294 "Gmsh.y" { yyval.d = asin(yyvsp[-1].d); ; break;} case 274: #line 2295 "Gmsh.y" { yyval.d = cos(yyvsp[-1].d); ; break;} case 275: #line 2296 "Gmsh.y" { yyval.d = acos(yyvsp[-1].d); ; break;} case 276: #line 2297 "Gmsh.y" { yyval.d = tan(yyvsp[-1].d); ; break;} case 277: #line 2298 "Gmsh.y" { yyval.d = atan(yyvsp[-1].d); ; break;} case 278: #line 2299 "Gmsh.y" { yyval.d = atan2(yyvsp[-3].d,yyvsp[-1].d); ; break;} case 279: #line 2300 "Gmsh.y" { yyval.d = sinh(yyvsp[-1].d); ; break;} case 280: #line 2301 "Gmsh.y" { yyval.d = cosh(yyvsp[-1].d); ; break;} case 281: #line 2302 "Gmsh.y" { yyval.d = tanh(yyvsp[-1].d); ; break;} case 282: #line 2303 "Gmsh.y" { yyval.d = fabs(yyvsp[-1].d); ; break;} case 283: #line 2304 "Gmsh.y" { yyval.d = floor(yyvsp[-1].d); ; break;} case 284: #line 2305 "Gmsh.y" { yyval.d = ceil(yyvsp[-1].d); ; break;} case 285: #line 2306 "Gmsh.y" { yyval.d = fmod(yyvsp[-3].d,yyvsp[-1].d); ; break;} case 286: #line 2307 "Gmsh.y" { yyval.d = fmod(yyvsp[-3].d,yyvsp[-1].d); ; break;} case 287: #line 2308 "Gmsh.y" { yyval.d = sqrt(yyvsp[-3].d*yyvsp[-3].d+yyvsp[-1].d*yyvsp[-1].d); ; break;} case 288: #line 2309 "Gmsh.y" { yyval.d = yyvsp[-1].d*(double)rand()/(double)RAND_MAX; ; break;} case 289: #line 2318 "Gmsh.y" { yyval.d = yyvsp[0].d; ; break;} case 290: #line 2319 "Gmsh.y" { yyval.d = 3.141592653589793; ; break;} case 291: #line 2324 "Gmsh.y" { TheSymbol.Name = yyvsp[0].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[0].c) ; yyval.d = 0. ; } else{ yyval.d = *(double*)List_Pointer_Fast(pSymbol->val, 0) ; } Free(yyvsp[0].c); ; break;} case 292: #line 2336 "Gmsh.y" { TheSymbol.Name = yyvsp[-3].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-3].c) ; yyval.d = 0. ; } else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-1].d))) yyval.d = *pd ; else{ vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-3].c, (int)yyvsp[-1].d) ; yyval.d = 0. ; } } Free(yyvsp[-3].c); ; break;} case 293: #line 2354 "Gmsh.y" { TheSymbol.Name = yyvsp[-1].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-1].c) ; yyval.d = 0. ; } else{ yyval.d = (*(double*)List_Pointer_Fast(pSymbol->val, 0) += 1.0) ; } Free(yyvsp[-1].c); ; break;} case 294: #line 2366 "Gmsh.y" { TheSymbol.Name = yyvsp[-4].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-4].c) ; yyval.d = 0. ; } else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-2].d))) yyval.d = (*pd += 1.0) ; else{ vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-4].c, (int)yyvsp[-2].d) ; yyval.d = 0. ; } } Free(yyvsp[-4].c); ; break;} case 295: #line 2384 "Gmsh.y" { TheSymbol.Name = yyvsp[-1].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-1].c) ; yyval.d = 0. ; } else{ yyval.d = (*(double*)List_Pointer_Fast(pSymbol->val, 0) -= 1.0) ; } Free(yyvsp[-1].c); ; break;} case 296: #line 2396 "Gmsh.y" { TheSymbol.Name = yyvsp[-4].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-4].c) ; yyval.d = 0. ; } else{ if((pd = (double*)List_Pointer_Test(pSymbol->val, (int)yyvsp[-2].d))) yyval.d = (*pd -= 1.0) ; else{ vyyerror("Uninitialized Variable '%s[%d]'", yyvsp[-4].c, (int)yyvsp[-2].d) ; yyval.d = 0. ; } } Free(yyvsp[-4].c); ; break;} case 297: #line 2416 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-2].c))){ vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-2].c); yyval.d = 0. ; } else{ if(!(pNumOpt = Get_NumberOption(yyvsp[0].c, pNumCat, &i))){ vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-2].c, yyvsp[0].c); yyval.d = 0. ; } else{ switch(i){ case GMSH_DOUBLE : yyval.d = *(double*)pNumOpt ; break ; case GMSH_FLOAT : yyval.d = (double)(*(float*)pNumOpt) ; break ; case GMSH_LONG : yyval.d = (double)(*(long*)pNumOpt) ; break ; case GMSH_INT : yyval.d = (double)(*(int*)pNumOpt) ; break ; } } } ; break;} case 298: #line 2437 "Gmsh.y" { if(strcmp(yyvsp[-7].c, "PostProcessing")){ vyyerror("Unknown View Option Class '%s'", yyvsp[-7].c); yyval.d = 0. ; } else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-3].d, yyvsp[0].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-3].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-7].c, (int)yyvsp[-3].d, yyvsp[0].c); yyval.d = 0. ; } else{ switch(i){ case GMSH_DOUBLE : yyval.d = *(double*)pNumOpt ; break ; case GMSH_FLOAT : yyval.d = (double)(*(float*)pNumOpt) ; break ; case GMSH_LONG : yyval.d = (double)(*(long*)pNumOpt) ; break ; case GMSH_INT : yyval.d = (double)(*(int*)pNumOpt) ; break ; } } } ; break;} case 299: #line 2461 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-3].c))){ vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-3].c); yyval.d = 0. ; } else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-1].c, pNumCat, &i))){ vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-3].c, yyvsp[-1].c); yyval.d = 0. ; } else{ switch(i){ case GMSH_DOUBLE : yyval.d = (*(double*)pNumOpt += 1.) ; break ; case GMSH_FLOAT : yyval.d = (double)(*(float*)pNumOpt += 1.) ; break ; case GMSH_LONG : yyval.d = (double)(*(long*)pNumOpt += 1) ; break ; case GMSH_INT : yyval.d = (double)(*(int*)pNumOpt += 1) ; break ; } } } ; break;} case 300: #line 2482 "Gmsh.y" { if(strcmp(yyvsp[-8].c, "PostProcessing")){ vyyerror("Unknown View Option Class '%s'", yyvsp[-8].c); yyval.d = 0. ; } else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-4].d, yyvsp[-1].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-4].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-8].c, (int)yyvsp[-4].d, yyvsp[-1].c); yyval.d = 0. ; } else{ switch(i){ case GMSH_DOUBLE : yyval.d = (*(double*)pNumOpt += 1.) ; break ; case GMSH_FLOAT : yyval.d = (double)(*(float*)pNumOpt += 1.) ; break ; case GMSH_LONG : yyval.d = (double)(*(long*)pNumOpt += 1) ; break ; case GMSH_INT : yyval.d = (double)(*(int*)pNumOpt += 1) ; break ; } } } ; break;} case 301: #line 2506 "Gmsh.y" { if(!(pNumCat = Get_NumberOptionCategory(yyvsp[-3].c))){ vyyerror("Unknown Numeric Option Class '%s'", yyvsp[-3].c); yyval.d = 0. ; } else{ if(!(pNumOpt = Get_NumberOption(yyvsp[-1].c, pNumCat, &i))){ vyyerror("Unknown Numeric Option '%s.%s'", yyvsp[-3].c, yyvsp[-1].c); yyval.d = 0. ; } else{ switch(i){ case GMSH_DOUBLE : yyval.d = (*(double*)pNumOpt -= 1.) ; break ; case GMSH_FLOAT : yyval.d = (double)(*(float*)pNumOpt -= 1.) ; break ; case GMSH_LONG : yyval.d = (double)(*(long*)pNumOpt -= 1) ; break ; case GMSH_INT : yyval.d = (double)(*(int*)pNumOpt -= 1) ; break ; } } } ; break;} case 302: #line 2527 "Gmsh.y" { if(strcmp(yyvsp[-8].c, "PostProcessing")){ vyyerror("Unknown View Option Class '%s'", yyvsp[-8].c); yyval.d = 0. ; } else{ if(!(pNumOpt = Get_NumberViewOption((int)yyvsp[-4].d, yyvsp[-1].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-4].d); else vyyerror("Unknown Numeric Option '%s.View[%d].%s'", yyvsp[-8].c, (int)yyvsp[-4].d, yyvsp[-1].c); yyval.d = 0. ; } else{ switch(i){ case GMSH_DOUBLE : yyval.d = (*(double*)pNumOpt -= 1.) ; break ; case GMSH_FLOAT : yyval.d = (double)(*(float*)pNumOpt -= 1.) ; break ; case GMSH_LONG : yyval.d = (double)(*(long*)pNumOpt -= 1) ; break ; case GMSH_INT : yyval.d = (double)(*(int*)pNumOpt -= 1) ; break ; } } } ; break;} case 303: #line 2553 "Gmsh.y" { ListOfDouble2_L = List_Create(2,1,sizeof(double)) ; for(d=yyvsp[-2].d ; (yyvsp[-2].d<yyvsp[0].d)?(d<=yyvsp[0].d):(d>=yyvsp[0].d) ; (yyvsp[-2].d<yyvsp[0].d)?(d+=1.):(d-=1.)) List_Add(ListOfDouble2_L, &d) ; ; break;} case 304: #line 2559 "Gmsh.y" { ListOfDouble2_L = List_Create(2,1,sizeof(double)) ; if(!yyvsp[0].d || (yyvsp[-4].d<yyvsp[-2].d && yyvsp[0].d<0) || (yyvsp[-4].d>yyvsp[-2].d && yyvsp[0].d>0)){ vyyerror("Wrong Increment in '%g:%g:%g'", yyvsp[-4].d, yyvsp[-2].d, yyvsp[0].d) ; List_Add(ListOfDouble2_L, &(yyvsp[-4].d)) ; } else for(d=yyvsp[-4].d ; (yyvsp[0].d>0)?(d<=yyvsp[-2].d):(d>=yyvsp[-2].d) ; d+=yyvsp[0].d) List_Add(ListOfDouble2_L, &d) ; ; break;} case 305: #line 2573 "Gmsh.y" { memcpy(yyval.v, yyvsp[0].v, 5*sizeof(double)) ; //??? Avec ce qui suit, bison se plante sur DEC //for(i=0 ; i<5 ; i++) $$[i] = $1[i]; ; break;} case 306: #line 2579 "Gmsh.y" { for(i=0 ; i<5 ; i++) yyval.v[i] = -yyvsp[0].v[i] ; ; break;} case 307: #line 2583 "Gmsh.y" { for(i=0 ; i<5 ; i++) yyval.v[i] = yyvsp[0].v[i]; ; break;} case 308: #line 2587 "Gmsh.y" { for(i=0 ; i<5 ; i++) yyval.v[i] = yyvsp[-2].v[i] - yyvsp[0].v[i] ; ; break;} case 309: #line 2591 "Gmsh.y" { for(i=0 ; i<5 ; i++) yyval.v[i] = yyvsp[-2].v[i] + yyvsp[0].v[i] ; ; break;} case 310: #line 2597 "Gmsh.y" { yyval.v[0]=yyvsp[-9].d; yyval.v[1]=yyvsp[-7].d; yyval.v[2]=yyvsp[-5].d; yyval.v[3]=yyvsp[-3].d; yyval.v[4]=yyvsp[-1].d; ; break;} case 311: #line 2601 "Gmsh.y" { yyval.v[0]=yyvsp[-7].d; yyval.v[1]=yyvsp[-5].d; yyval.v[2]=yyvsp[-3].d; yyval.v[3]=yyvsp[-1].d; yyval.v[4]=1.0; ; break;} case 312: #line 2605 "Gmsh.y" { yyval.v[0]=yyvsp[-5].d; yyval.v[1]=yyvsp[-3].d; yyval.v[2]=yyvsp[-1].d; yyval.v[3]=0.0; yyval.v[4]=1.0; ; break;} case 313: #line 2609 "Gmsh.y" { yyval.v[0]=yyvsp[-5].d; yyval.v[1]=yyvsp[-3].d; yyval.v[2]=yyvsp[-1].d; yyval.v[3]=0.0; yyval.v[4]=1.0; ; break;} case 314: #line 2613 "Gmsh.y" { if(!(pArrCat = Get_ArrayOptionCategory(yyvsp[-2].c))){ vyyerror("Unknown Array Option Class '%s'", yyvsp[-2].c); yyval.v[0]=yyval.v[1]=yyval.v[2]=yyval.v[3]= 0.0 ; yyval.v[4]= 1.0 ; } else{ if(!(pArrOpt = Get_ArrayOption(yyvsp[0].c, pArrCat, &i))){ vyyerror("Unknown Array Option '%s.%s'", yyvsp[-2].c, yyvsp[0].c); yyval.v[0]=yyval.v[1]=yyval.v[2]=yyval.v[3]= 0.0 ; yyval.v[4]= 1.0 ; } else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<4 ; j++) yyval.v[j] = ((double*)pArrOpt)[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<4 ; j++) yyval.v[j] = (double)((float*)pArrOpt)[j] ; break ; case GMSH_LONG : for(j=0 ; j<4 ; j++) yyval.v[j] = (double)((int*)pArrOpt)[j] ; break ; case GMSH_INT : for(j=0 ; j<4 ; j++) yyval.v[j] = (double)((int*)pArrOpt)[j] ; break ; } yyval.v[4] = 1. ; } } ; break;} case 315: #line 2645 "Gmsh.y" { if(strcmp(yyvsp[-7].c, "PostProcessing")){ vyyerror("Unknown View Option Class '%s'", yyvsp[-7].c); yyval.v[0]=yyval.v[1]=yyval.v[2]=yyval.v[3]= 0.0 ; yyval.v[4]= 1.0 ; } else{ if(!(pArrOpt = Get_ArrayViewOption((int)yyvsp[-3].d, yyvsp[0].c, &i))){ if(i < 0) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-3].d); else vyyerror("Unknown Array Option '%s.View[%d].%s'", yyvsp[-7].c, (int)yyvsp[-3].d, yyvsp[0].c); yyval.v[0]=yyval.v[1]=yyval.v[2]=yyval.v[3]= 0.0 ; yyval.v[4]= 1.0 ; } else{ switch(i){ case GMSH_DOUBLE : for(j=0 ; j<3 ; j++) yyval.v[j] = ((double*)pArrOpt)[j] ; break ; case GMSH_FLOAT : for(j=0 ; j<3 ; j++) yyval.v[j] = (double)((float*)pArrOpt)[j] ; break ; case GMSH_LONG : for(j=0 ; j<3 ; j++) yyval.v[j] = (double)((int*)pArrOpt)[j] ; break ; case GMSH_INT : for(j=0 ; j<3 ; j++) yyval.v[j] = (double)((int*)pArrOpt)[j] ; break ; } yyval.v[3] = 0. ; yyval.v[4] = 1. ; } } ; break;} case 316: #line 2683 "Gmsh.y" { ; break;} case 317: #line 2686 "Gmsh.y" { ; break;} case 318: #line 2692 "Gmsh.y" { ; break;} case 319: #line 2695 "Gmsh.y" { ; break;} case 320: #line 2701 "Gmsh.y" { ; break;} case 321: #line 2704 "Gmsh.y" { yyval.l=ListOfListOfDouble_L; ; break;} case 322: #line 2708 "Gmsh.y" { yyval.l=ListOfListOfDouble_L; ; break;} case 323: #line 2715 "Gmsh.y" { ListOfListOfDouble_L = List_Create(2,1,sizeof(List_T*)) ; List_Add(ListOfListOfDouble_L, &(yyvsp[0].l)) ; ; break;} case 324: #line 2720 "Gmsh.y" { List_Add(ListOfListOfDouble_L, &(yyvsp[0].l)) ; ; break;} case 325: #line 2727 "Gmsh.y" { ; break;} case 326: #line 2730 "Gmsh.y" { ListOfDouble_L = List_Create(2,1,sizeof(double)) ; List_Add(ListOfDouble_L, &(yyvsp[0].d)) ; yyval.l=ListOfDouble_L; ; break;} case 327: #line 2736 "Gmsh.y" { ListOfDouble_L = List_Create(2,1,sizeof(double)) ; TheSymbol.Name = yyvsp[-2].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-2].c) ; d = 0.0 ; List_Add(ListOfDouble_L, &d); } else{ for(i = 0 ; i < List_Nbr(pSymbol->val) ; i++) List_Add(ListOfDouble_L, (double*)List_Pointer_Fast(pSymbol->val, i)) ; } yyval.l=ListOfDouble_L; ; break;} case 328: #line 2751 "Gmsh.y" { yyval.l=ListOfDouble_L; ; break;} case 329: #line 2759 "Gmsh.y" { ListOfDouble_L = List_Create(2,1,sizeof(double)) ; List_Add(ListOfDouble_L, &(yyvsp[0].d)) ; ; break;} case 330: #line 2764 "Gmsh.y" { ListOfDouble_L = List_Create(2,1,sizeof(double)) ; for(i=0 ; i<List_Nbr(ListOfDouble2_L) ; i++){ List_Read(ListOfDouble2_L, i, &d) ; List_Add(ListOfDouble_L, &d) ; } List_Delete(ListOfDouble2_L); ; break;} case 331: #line 2773 "Gmsh.y" { ListOfDouble_L = List_Create(2,1,sizeof(double)) ; TheSymbol.Name = yyvsp[-2].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-2].c) ; } else{ for(i = 0 ; i < List_Nbr(pSymbol->val) ; i++) List_Add(ListOfDouble_L, (double*)List_Pointer_Fast(pSymbol->val, i)) ; } ; break;} case 332: #line 2785 "Gmsh.y" { List_Add(ListOfDouble_L, &(yyvsp[0].d)) ; ; break;} case 333: #line 2789 "Gmsh.y" { for(i=0 ; i<List_Nbr(ListOfDouble2_L) ; i++){ List_Read(ListOfDouble2_L, i, &d) ; List_Add(ListOfDouble_L, &d) ; } List_Delete(ListOfDouble2_L); ; break;} case 334: #line 2797 "Gmsh.y" { TheSymbol.Name = yyvsp[-2].c ; if (!(pSymbol = (Symbol*)List_PQuery(Symbol_L, &TheSymbol, CompareSymbols))) { vyyerror("Unknown Variable '%s'", yyvsp[-2].c) ; } else{ for(i = 0 ; i < List_Nbr(pSymbol->val) ; i++) List_Add(ListOfDouble_L, (double*)List_Pointer_Fast(pSymbol->val, i)) ; } ; break;} case 335: #line 2811 "Gmsh.y" { yyval.u = PACK_COLOR((int)yyvsp[-7].d, (int)yyvsp[-5].d, (int)yyvsp[-3].d, (int)yyvsp[-1].d); ; break;} case 336: #line 2815 "Gmsh.y" { yyval.u = PACK_COLOR((int)yyvsp[-5].d, (int)yyvsp[-3].d, (int)yyvsp[-1].d, 255); ; break;} case 337: #line 2819 "Gmsh.y" { yyval.u = Get_ColorForString(ColorString, (int)yyvsp[-1].d, yyvsp[-3].c, &flag); if(flag) vyyerror("Unknown Color '%s'", yyvsp[-3].c); ; break;} case 338: #line 2824 "Gmsh.y" { yyval.u = Get_ColorForString(ColorString, -1, yyvsp[0].c, &flag); if(flag) vyyerror("Unknown Color '%s'", yyvsp[0].c); ; break;} case 339: #line 2829 "Gmsh.y" { if(!(pColCat = Get_ColorOptionCategory(yyvsp[-4].c))){ vyyerror("Unknown Color Option Class '%s'", yyvsp[-4].c); yyval.u = 0 ; } else{ if(!(pColOpt = Get_ColorOption(yyvsp[0].c, pColCat))){ vyyerror("Unknown Color Option '%s.%s'", yyvsp[-4].c, yyvsp[0].c); yyval.u = 0 ; } else{ yyval.u = *pColOpt ; } } ; break;} case 340: #line 2849 "Gmsh.y" { yyval.l = ListOfColor_L; ; break;} case 341: #line 2853 "Gmsh.y" { if(!ListOfColor_L) ListOfColor_L = List_Create(256,10,sizeof(unsigned int)) ; else List_Reset(ListOfColor_L) ; if(strcmp(yyvsp[-7].c, "PostProcessing")) vyyerror("Unknown View Option Class '%s'", yyvsp[-7].c); else{ ColorTable *ct = Get_ColorTableViewOption((int)yyvsp[-3].d); if(!ct) vyyerror("PostProcessing View %d does not Exist", (int)yyvsp[-3].d); else{ for(i=0 ; i<ct->size ; i++) List_Add(ListOfColor_L, &ct->table[i]); } } yyval.l = ListOfColor_L; ; break;} case 342: #line 2875 "Gmsh.y" { if(!ListOfColor_L) ListOfColor_L = List_Create(256,10,sizeof(unsigned int)) ; else List_Reset(ListOfColor_L) ; List_Add(ListOfColor_L, &(yyvsp[0].u)) ; ; break;} case 343: #line 2883 "Gmsh.y" { List_Add(ListOfColor_L, &(yyvsp[0].u)) ; ; break;} case 344: #line 2890 "Gmsh.y" { yyval.c = yyvsp[0].c; ; break;} case 345: #line 2894 "Gmsh.y" { yyval.c = yyvsp[-1].c; ; break;} case 346: #line 2898 "Gmsh.y" { for(i = 0 ; i<List_Nbr(ListOfDouble_L) ; i++){ if(!i){ str = strtok(yyvsp[-3].c, "%"); strcpy(tmpstring, str); } str = strtok(NULL, "%"); if(str){ strcpy(tmpstring2, "%"); strcat(tmpstring2, str); sprintf(tmpstring3, tmpstring2, *(double*)List_Pointer(ListOfDouble_L,i)); strcat(tmpstring, tmpstring3); } else{ vyyerror("Missing %d Parameter(s) in Sprintf Format", List_Nbr(ListOfDouble_L)-i); break ; } } yyval.c = (char*)Malloc(strlen(tmpstring)); strcpy(yyval.c, tmpstring); ; break;} } /* the action file gets copied in in place of this dollarsign */ #line 543 "/usr/lib/bison.simple" yyvsp -= yylen; yyssp -= yylen; #ifdef YYLSP_NEEDED yylsp -= yylen; #endif #if YYDEBUG != 0 if (yydebug) { short *ssp1 = yyss - 1; fprintf (stderr, "state stack now"); while (ssp1 != yyssp) fprintf (stderr, " %d", *++ssp1); fprintf (stderr, "\n"); } #endif *++yyvsp = yyval; #ifdef YYLSP_NEEDED yylsp++; if (yylen == 0) { yylsp->first_line = yylloc.first_line; yylsp->first_column = yylloc.first_column; yylsp->last_line = (yylsp-1)->last_line; yylsp->last_column = (yylsp-1)->last_column; yylsp->text = 0; } else { yylsp->last_line = (yylsp+yylen-1)->last_line; yylsp->last_column = (yylsp+yylen-1)->last_column; } #endif /* Now "shift" the result of the reduction. Determine what state that goes to, based on the state we popped back to and the rule number reduced by. */ yyn = yyr1[yyn]; yystate = yypgoto[yyn - YYNTBASE] + *yyssp; if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp) yystate = yytable[yystate]; else yystate = yydefgoto[yyn - YYNTBASE]; goto yynewstate; yyerrlab: /* here on detecting error */ if (! yyerrstatus) /* If not already recovering from an error, report this error. */ { ++yynerrs; #ifdef YYERROR_VERBOSE yyn = yypact[yystate]; if (yyn > YYFLAG && yyn < YYLAST) { int size = 0; char *msg; int x, count; count = 0; /* Start X at -yyn if nec to avoid negative indexes in yycheck. */ for (x = (yyn < 0 ? -yyn : 0); x < (sizeof(yytname) / sizeof(char *)); x++) if (yycheck[x + yyn] == x) size += strlen(yytname[x]) + 15, count++; msg = (char *) malloc(size + 15); if (msg != 0) { strcpy(msg, "parse error"); if (count < 5) { count = 0; for (x = (yyn < 0 ? -yyn : 0); x < (sizeof(yytname) / sizeof(char *)); x++) if (yycheck[x + yyn] == x) { strcat(msg, count == 0 ? ", expecting `" : " or `"); strcat(msg, yytname[x]); strcat(msg, "'"); count++; } } yyerror(msg); free(msg); } else yyerror ("parse error; also virtual memory exceeded"); } else #endif /* YYERROR_VERBOSE */ yyerror("parse error"); } goto yyerrlab1; yyerrlab1: /* here on error raised explicitly by an action */ if (yyerrstatus == 3) { /* if just tried and failed to reuse lookahead token after an error, discard it. */ /* return failure if at end of input */ if (yychar == YYEOF) YYABORT; #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Discarding token %d (%s).\n", yychar, yytname[yychar1]); #endif yychar = YYEMPTY; } /* Else will try to reuse lookahead token after shifting the error token. */ yyerrstatus = 3; /* Each real token shifted decrements this */ goto yyerrhandle; yyerrdefault: /* current state does not do anything special for the error token. */ #if 0 /* This is wrong; only states that explicitly want error tokens should shift them. */ yyn = yydefact[yystate]; /* If its default is to accept any token, ok. Otherwise pop it.*/ if (yyn) goto yydefault; #endif yyerrpop: /* pop the current state because it cannot handle the error token */ if (yyssp == yyss) YYABORT; yyvsp--; yystate = *--yyssp; #ifdef YYLSP_NEEDED yylsp--; #endif #if YYDEBUG != 0 if (yydebug) { short *ssp1 = yyss - 1; fprintf (stderr, "Error: state stack now"); while (ssp1 != yyssp) fprintf (stderr, " %d", *++ssp1); fprintf (stderr, "\n"); } #endif yyerrhandle: yyn = yypact[yystate]; if (yyn == YYFLAG) goto yyerrdefault; yyn += YYTERROR; if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != YYTERROR) goto yyerrdefault; yyn = yytable[yyn]; if (yyn < 0) { if (yyn == YYFLAG) goto yyerrpop; yyn = -yyn; goto yyreduce; } else if (yyn == 0) goto yyerrpop; if (yyn == YYFINAL) YYACCEPT; #if YYDEBUG != 0 if (yydebug) fprintf(stderr, "Shifting error token, "); #endif *++yyvsp = yylval; #ifdef YYLSP_NEEDED *++yylsp = yylloc; #endif yystate = yyn; goto yynewstate; yyacceptlab: /* YYACCEPT comes here. */ if (yyfree_stacks) { free (yyss); free (yyvs); #ifdef YYLSP_NEEDED free (yyls); #endif } return 0; yyabortlab: /* YYABORT comes here. */ if (yyfree_stacks) { free (yyss); free (yyvs); #ifdef YYLSP_NEEDED free (yyls); #endif } return 1; } #line 2922 "Gmsh.y" void InitSymbols(void){ Symbol_L = List_Create(10,1,sizeof(Symbol)); } void DeleteSymbols(void){ int i; for(i = 0 ; i < List_Nbr(Symbol_L) ; i++) List_Delete(((Symbol*)List_Pointer_Fast(Symbol_L,i))->val); List_Delete(Symbol_L); } int CompareSymbols (const void *a, const void *b){ return(strcmp(((Symbol*)a)->Name,((Symbol*)b)->Name)); } void yyerror(char *s){ Msg(PARSER_ERROR, "'%s', line %d : %s (%s)",yyname,yylineno-1,s,yytext); yyerrorstate=1; } void vyyerror(char *fmt, ...){ va_list args; char tmp[TEXT_BUFFER_SIZE]; va_start (args, fmt); vsprintf (tmp, fmt, args); va_end (args); Msg(PARSER_ERROR, "'%s', line %d : %s", yyname, yylineno-1, tmp); yyerrorstate=1; }