#ifndef lint static char yysccsid[] = "@(#)yaccpar 1.9 (Berkeley) 02/21/93"; #endif #define YYBYACC 1 #define YYMAJOR 1 #define YYMINOR 9 #define yyclearin (DSQL_yychar=(-1)) #define yyerrok (DSQL_yyerrflag=0) #define YYRECOVERING (DSQL_yyerrflag!=0) #define YYPREFIX "yy" /* * PROGRAM: Dynamic SQL runtime support * MODULE: parse.y * DESCRIPTION: Dynamic SQL parser * * The contents of this file are subject to the Interbase Public * License Version 1.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy * of the License at http://www.Inprise.com/IPL.html * * Software distributed under the License is distributed on an * "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express * or implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code was created by Inprise Corporation * and its predecessors. Portions created by Inprise Corporation are * Copyright (C) Inprise Corporation. * * All Rights Reserved. * Contributor(s): ______________________________________. * * 2002-02-23 Sean Leyne - Code Cleanup, removed old Win3.1 port (Windows_Only) * */ #include "firebird.h" #include #include #include #include "../jrd/common.h" #include #include "gen/iberror.h" #include "../dsql/dsql.h" #include "../dsql/node.h" #include "../dsql/sym.h" #include "../jrd/gds.h" #include "../jrd/flags.h" #include "../dsql/alld_proto.h" #include "../dsql/errd_proto.h" #include "../dsql/hsh_proto.h" #include "../dsql/make_proto.h" #include "../dsql/parse_proto.h" #include "../jrd/gds_proto.h" #include "../jrd/thd_proto.h" /* #include "../jrd/err_proto.h" */ #include "../wal/wal.h" extern "C" TEXT *DLL_EXPORT ERR_string(CONST TEXT*, int); ASSERT_FILENAME static void yyerror (TEXT *); /* since UNIX isn't standard, we have to define stuff which is in (which isn't available on all UNIXes... */ #define SHRT_POS_MAX 32767 #define SHRT_UNSIGNED_MAX 65535 #define SHRT_NEG_MAX 32768 #define LONG_POS_MAX 2147483647 #define POSITIVE 0 #define NEGATIVE 1 #define UNSIGNED 2 #define MIN_CACHE_BUFFERS 250 #define DEF_CACHE_BUFFERS 1000 #define YYSTYPE NOD #ifdef DEBUG #define YYDEBUG 1 #endif static CONST UCHAR INTERNAL_FIELD_NAME [] = "DSQL internal"; /* NTX: placeholder */ static CONST UCHAR NULL_STRING [] = ""; extern "C" { #ifndef SHLIB_DEFS NOD DSQL_parse; #else extern NOD DSQL_parse; #endif } // extern "C" static FLD field; static FIL file; static NOD field_name; static TEXT *beginning; static SSHORT log_defined, cache_defined; #define ACTIVE 257 #define ADD 258 #define AFTER 259 #define ALL 260 #define ALTER 261 #define AND 262 #define ANY 263 #define AS 264 #define ASC 265 #define AT 266 #define AVG 267 #define AUTO 268 #define BASENAME 269 #define BEFORE 270 #define BEGIN 271 #define BETWEEN 272 #define BLOB 273 #define BY 274 #define CACHE 275 #define CAST 276 #define CHARACTER 277 #define CHECK 278 #define CHECK_POINT_LEN 279 #define COLLATE 280 #define COLLATION 281 #define COMMA 282 #define COMMIT 283 #define COMMITTED 284 #define COMPUTED 285 #define CONCATENATE 286 #define CONDITIONAL 287 #define CONSTRAINT 288 #define CONTAINING 289 #define COUNT 290 #define CREATE 291 #define CSTRING 292 #define CURRENT 293 #define CURSOR 294 #define DATABASE 295 #define DATE 296 #define DB_KEY 297 #ifdef DEBUG #undef DEBUG #endif #define DEBUG 298 #define DECIMAL 299 #define DECLARE 300 #define DEFAULT 301 #define DELETE 302 #define DESC 303 #define DISTINCT 304 #define DO 305 #define DOMAIN 306 #define DROP 307 #define ELSE 308 #define END 309 #define ENTRY_POINT 310 #define EQL 311 #define ESCAPE 312 #define EXCEPTION 313 #define EXECUTE 314 #define EXISTS 315 #define EXIT 316 #define EXTERNAL 317 #define FILTER 318 #define FOR 319 #define FOREIGN 320 #define FROM 321 #define FULL 322 #define FUNCTION 323 #define GDSCODE 324 #define GEQ 325 #define GENERATOR 326 #define GEN_ID 327 #define GRANT 328 #define GROUP 329 #define GROUP_COMMIT_WAIT 330 #define GTR 331 #define HAVING 332 #define IF 333 #define IN 334 #define INACTIVE 335 #define INNER 336 #define INPUT_TYPE 337 #define INDEX 338 #define INSERT 339 #define INTEGER 340 #define INTO 341 #define IS 342 #define ISOLATION 343 #define JOIN 344 #define KEY 345 #define KW_CHAR 346 #define KW_DEC 347 #define KW_DOUBLE 348 #define KW_FILE 349 #define KW_FLOAT 350 #define KW_INT 351 #define KW_LONG 352 #define KW_NULL 353 #define KW_NUMERIC 354 #define KW_UPPER 355 #define KW_VALUE 356 #define LENGTH 357 #define LOGFILE 358 #define LPAREN 359 #define LEFT 360 #define LEQ 361 #define LEVEL 362 #define LIKE 363 #define LOG_BUF_SIZE 364 #define LSS 365 #define MANUAL 366 #define MAXIMUM 367 #define MAX_SEGMENT 368 #define MERGE 369 #define MESSAGE 370 #define MINIMUM 371 #define MODULE_NAME 372 #define NAMES 373 #define NATIONAL 374 #define NATURAL 375 #define NCHAR 376 #define NEQ 377 #define NO 378 #define NOT 379 #define NOT_GTR 380 #define NOT_LSS 381 #define NUM_LOG_BUFS 382 #define OF 383 #define ON 384 #define ONLY 385 #define OPTION 386 #define OR 387 #define ORDER 388 #define OUTER 389 #define OUTPUT_TYPE 390 #define OVERFLOW 391 #define PAGE 392 #define PAGES 393 #define PAGE_SIZE 394 #define PARAMETER 395 #define PASSWORD 396 #define PLAN 397 #define POSITION 398 #define POST_EVENT 399 #define PRECISION 400 #define PRIMARY 401 #define PRIVILEGES 402 #define PROCEDURE 403 #define PROTECTED 404 #define RAW_PARTITIONS 405 #define READ 406 #define REAL 407 #define REFERENCES 408 #define RESERVING 409 #define RETAIN 410 #define RETURNING_VALUES 411 #define RETURNS 412 #define REVOKE 413 #define RIGHT 414 #define RPAREN 415 #define ROLLBACK 416 #define SEGMENT 417 #define SELECT 418 #define SET 419 #define SHADOW 420 #define SHARED 421 #define SINGULAR 422 #define SIZE 423 #define SMALLINT 424 #define SNAPSHOT 425 #define SOME 426 #define SORT 427 #define SQLCODE 428 #define STABILITY 429 #define STARTING 430 #define STATISTICS 431 #define SUB_TYPE 432 #define SUSPEND 433 #define SUM 434 #define TABLE 435 #define THEN 436 #define TO 437 #define TRANSACTION 438 #define TRIGGER 439 #define UNCOMMITTED 440 #define UNION 441 #define UNIQUE 442 #define UPDATE 443 #define USER 444 #define VALUES 445 #define VARCHAR 446 #define VARIABLE 447 #define VARYING 448 #define VERSION 449 #define VIEW 450 #define WAIT 451 #define WHEN 452 #define WHERE 453 #define WHILE 454 #define WITH 455 #define WORK 456 #define WRITE 457 #define FLOAT 458 #define NUMBER 459 #define NUMERIC 460 #define SYMBOL 461 #define STRING 462 #define INTRODUCER 463 #define ACTION 464 #define ADMIN 465 #define CASCADE 466 #define FREE_IT 467 #define RESTRICT 468 #define ROLE 469 #define COLUMN 470 #define TYPE 471 #define EXTRACT 472 #define YEAR 473 #define MONTH 474 #define DAY 475 #define HOUR 476 #define MINUTE 477 #define SECOND 478 #define WEEKDAY 479 #define YEARDAY 480 #define TIME 481 #define TIMESTAMP 482 #define CURRENT_DATE 483 #define CURRENT_TIME 484 #define CURRENT_TIMESTAMP 485 #define NUMBER64BIT 486 #define SCALEDINT 487 #define LIMIT 488 #define INT64 489 #define SUBSTRING 490 #define YYERRCODE 256 static short yylhs[] = { -1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 9, 9, 9, 9, 9, 19, 19, 18, 18, 18, 29, 29, 22, 30, 30, 30, 30, 30, 21, 21, 27, 27, 23, 12, 12, 12, 12, 12, 12, 12, 33, 24, 24, 24, 24, 34, 34, 34, 20, 20, 35, 35, 35, 25, 25, 39, 26, 26, 41, 41, 6, 42, 42, 44, 49, 49, 49, 46, 46, 46, 53, 53, 54, 47, 47, 56, 56, 56, 56, 43, 5, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 61, 61, 64, 64, 64, 72, 80, 80, 80, 81, 81, 82, 82, 83, 83, 87, 87, 71, 90, 90, 92, 92, 93, 93, 96, 96, 97, 98, 98, 99, 100, 69, 73, 70, 84, 84, 103, 104, 104, 106, 106, 107, 107, 107, 107, 107, 105, 105, 108, 108, 109, 109, 109, 109, 111, 111, 111, 111, 110, 110, 115, 115, 114, 88, 116, 116, 117, 120, 121, 121, 122, 118, 119, 119, 123, 123, 124, 124, 125, 125, 125, 86, 86, 86, 66, 126, 126, 126, 127, 127, 128, 128, 129, 129, 129, 135, 76, 76, 131, 131, 94, 94, 89, 140, 141, 55, 132, 132, 95, 95, 95, 95, 133, 133, 145, 145, 146, 148, 148, 148, 148, 148, 130, 147, 147, 151, 151, 151, 151, 153, 154, 155, 150, 149, 149, 149, 149, 149, 156, 157, 158, 158, 158, 158, 65, 163, 159, 159, 160, 160, 164, 164, 165, 161, 161, 166, 166, 167, 168, 168, 162, 162, 170, 170, 169, 169, 169, 169, 169, 169, 169, 169, 169, 169, 169, 169, 169, 173, 174, 175, 175, 176, 182, 178, 178, 178, 179, 179, 179, 184, 184, 184, 184, 184, 184, 184, 184, 180, 180, 180, 180, 177, 181, 181, 171, 171, 186, 187, 187, 188, 188, 188, 188, 11, 190, 190, 190, 191, 191, 191, 191, 191, 191, 68, 193, 196, 196, 196, 197, 200, 205, 205, 206, 206, 207, 207, 137, 195, 77, 79, 194, 194, 67, 210, 210, 210, 211, 211, 211, 211, 211, 211, 212, 212, 213, 2, 215, 215, 215, 215, 215, 215, 215, 221, 221, 223, 223, 223, 223, 223, 223, 223, 216, 216, 224, 224, 224, 224, 224, 224, 224, 220, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 229, 226, 226, 228, 228, 227, 225, 225, 225, 222, 222, 218, 219, 219, 230, 230, 230, 230, 231, 231, 217, 232, 232, 233, 233, 8, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 234, 91, 91, 134, 134, 237, 237, 240, 240, 242, 242, 50, 50, 239, 239, 239, 239, 239, 239, 239, 239, 247, 247, 238, 238, 238, 238, 248, 248, 58, 58, 58, 52, 52, 244, 244, 244, 241, 241, 241, 252, 252, 252, 251, 251, 250, 250, 250, 245, 245, 255, 253, 253, 253, 254, 254, 246, 246, 246, 246, 256, 256, 15, 15, 15, 258, 258, 258, 4, 13, 260, 260, 261, 261, 262, 262, 257, 263, 263, 264, 264, 265, 265, 265, 265, 266, 266, 267, 267, 268, 268, 270, 270, 270, 271, 271, 271, 272, 272, 272, 269, 274, 274, 274, 275, 275, 273, 273, 276, 278, 278, 277, 277, 259, 14, 279, 279, 279, 280, 280, 283, 283, 284, 284, 62, 62, 62, 281, 281, 285, 285, 282, 198, 198, 199, 199, 289, 289, 290, 290, 290, 286, 293, 293, 294, 294, 295, 295, 296, 296, 297, 297, 299, 299, 300, 300, 208, 208, 28, 209, 209, 209, 209, 209, 209, 209, 209, 202, 202, 301, 301, 302, 302, 302, 203, 203, 201, 201, 287, 287, 304, 304, 304, 204, 204, 305, 306, 306, 306, 306, 306, 307, 307, 308, 308, 309, 309, 310, 310, 310, 311, 311, 10, 10, 312, 312, 7, 7, 313, 314, 315, 16, 16, 316, 317, 318, 318, 172, 291, 291, 3, 3, 319, 319, 319, 321, 321, 58, 320, 320, 322, 322, 31, 31, 75, 74, 74, 139, 139, 139, 136, 101, 101, 101, 101, 324, 324, 324, 324, 324, 324, 324, 324, 324, 324, 324, 325, 325, 325, 325, 325, 325, 325, 325, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 330, 336, 336, 326, 326, 327, 327, 327, 327, 328, 328, 332, 332, 333, 333, 333, 333, 331, 334, 329, 329, 337, 337, 335, 339, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 78, 144, 144, 144, 340, 343, 343, 142, 142, 344, 344, 344, 344, 344, 342, 342, 342, 342, 342, 338, 338, 338, 338, 338, 338, 192, 345, 48, 48, 17, 17, 214, 346, 51, 113, 243, 243, 85, 341, 341, 341, 341, 341, 341, 341, 341, 341, 341, 341, 341, 341, 341, 341, 303, 303, 347, 347, 347, 347, 347, 347, 347, 347, 288, 288, 143, 45, 249, 112, 138, 323, 152, 185, 236, 60, 57, 189, 102, 63, 292, 32, 40, 298, 235, 36, 38, 183, 37, }; static short yylen[] = { 2, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 7, 8, 6, 7, 5, 1, 2, 1, 2, 1, 1, 3, 1, 1, 1, 1, 2, 2, 3, 0, 3, 0, 1, 7, 8, 6, 7, 6, 7, 4, 3, 1, 3, 3, 3, 2, 2, 2, 1, 3, 1, 2, 2, 1, 3, 1, 1, 3, 1, 2, 2, 2, 3, 8, 1, 1, 5, 0, 1, 3, 1, 3, 2, 1, 3, 2, 3, 4, 2, 9, 2, 3, 7, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 0, 1, 1, 6, 6, 1, 1, 0, 0, 1, 0, 4, 0, 1, 1, 2, 8, 1, 0, 3, 0, 0, 1, 1, 2, 1, 1, 1, 2, 6, 1, 1, 3, 0, 1, 1, 0, 1, 1, 2, 3, 4, 2, 2, 3, 0, 1, 1, 2, 1, 1, 1, 4, 3, 3, 3, 3, 1, 1, 6, 3, 1, 3, 1, 3, 2, 1, 0, 2, 3, 1, 0, 1, 1, 2, 3, 4, 0, 1, 2, 0, 1, 1, 5, 3, 2, 0, 1, 3, 1, 1, 6, 3, 2, 6, 2, 1, 2, 2, 2, 0, 1, 1, 2, 0, 2, 0, 1, 1, 1, 1, 0, 1, 1, 2, 2, 2, 4, 1, 1, 2, 2, 2, 0, 1, 1, 1, 1, 2, 3, 7, 6, 1, 1, 2, 2, 0, 3, 3, 1, 2, 2, 2, 8, 8, 3, 0, 2, 0, 1, 3, 2, 1, 0, 1, 2, 5, 1, 1, 3, 4, 1, 2, 2, 2, 3, 1, 1, 1, 2, 3, 1, 2, 1, 2, 2, 6, 7, 8, 6, 4, 2, 1, 3, 0, 2, 4, 0, 1, 1, 1, 1, 3, 3, 3, 3, 1, 1, 3, 3, 6, 3, 0, 1, 2, 4, 1, 3, 2, 2, 2, 1, 4, 1, 3, 0, 1, 1, 1, 3, 3, 3, 7, 1, 1, 3, 4, 8, 2, 1, 3, 1, 1, 6, 3, 0, 0, 0, 0, 3, 0, 9, 1, 1, 0, 2, 2, 2, 2, 2, 2, 2, 0, 4, 2, 3, 3, 2, 2, 3, 3, 2, 1, 2, 4, 3, 2, 2, 2, 2, 3, 1, 3, 3, 3, 2, 2, 4, 4, 5, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 1, 1, 1, 0, 2, 2, 0, 1, 2, 2, 2, 2, 2, 1, 3, 7, 1, 0, 1, 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 2, 2, 1, 1, 1, 1, 4, 5, 1, 3, 1, 3, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 4, 6, 5, 3, 0, 2, 2, 0, 3, 0, 4, 1, 5, 4, 1, 4, 1, 2, 2, 1, 1, 1, 2, 2, 2, 2, 1, 0, 3, 5, 1, 1, 2, 3, 1, 2, 3, 0, 1, 1, 1, 5, 5, 6, 3, 2, 1, 0, 2, 0, 1, 0, 3, 1, 0, 1, 2, 1, 1, 1, 1, 2, 2, 1, 2, 3, 1, 1, 3, 3, 1, 2, 3, 1, 2, 0, 2, 1, 1, 0, 1, 1, 1, 3, 2, 3, 0, 1, 3, 4, 3, 1, 3, 4, 3, 0, 1, 3, 3, 3, 1, 1, 0, 3, 0, 2, 0, 9, 1, 1, 1, 1, 1, 3, 1, 2, 3, 2, 1, 3, 1, 1, 6, 3, 3, 2, 3, 0, 1, 3, 1, 1, 1, 2, 1, 1, 1, 2, 1, 2, 1, 2, 0, 3, 0, 1, 3, 1, 1, 3, 2, 0, 2, 0, 2, 0, 3, 5, 0, 2, 0, 4, 1, 2, 1, 1, 0, 1, 3, 2, 1, 1, 2, 1, 4, 2, 1, 3, 8, 5, 1, 3, 1, 1, 4, 4, 4, 1, 1, 5, 5, 1, 3, 3, 1, 1, 7, 7, 5, 3, 0, 1, 1, 1, 2, 0, 1, 1, 1, 0, 3, 1, 3, 1, 3, 3, 1, 1, 3, 3, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 3, 3, 3, 3, 3, 3, 3, 3, 3, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 1, 1, 5, 6, 3, 4, 5, 6, 3, 4, 3, 4, 3, 4, 4, 5, 4, 4, 3, 4, 3, 3, 8, 8, 1, 1, 1, 1, 1, 1, 1, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 1, 1, 3, 1, 1, 1, 1, 1, 4, 1, 3, 1, 2, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 1, 1, 1, 3, 3, 3, 1, 1, 1, 2, 1, 2, 1, 1, 1, 1, 1, 2, 1, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 6, 4, 6, 6, 4, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, }; static short yydefred[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 497, 498, 499, 0, 550, 641, 642, 646, 647, 410, 0, 0, 0, 0, 0, 0, 356, 505, 0, 0, 0, 0, 0, 0, 0, 0, 0, 101, 0, 0, 89, 0, 791, 0, 18, 789, 0, 0, 69, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 424, 0, 0, 34, 31, 33, 0, 32, 0, 841, 0, 0, 0, 0, 29, 62, 64, 0, 0, 0, 0, 0, 0, 0, 0, 504, 823, 567, 0, 568, 0, 0, 0, 843, 591, 0, 0, 2, 0, 0, 0, 0, 399, 383, 384, 385, 386, 387, 388, 389, 390, 391, 392, 393, 394, 395, 396, 397, 398, 0, 382, 834, 0, 838, 0, 363, 840, 0, 360, 0, 593, 844, 0, 359, 0, 503, 787, 0, 137, 97, 0, 0, 98, 0, 672, 203, 0, 675, 0, 837, 96, 132, 0, 92, 0, 99, 793, 0, 93, 0, 94, 847, 0, 95, 133, 100, 559, 560, 0, 792, 790, 0, 835, 70, 0, 0, 833, 432, 425, 0, 431, 426, 427, 434, 428, 429, 430, 435, 0, 27, 0, 36, 667, 35, 0, 0, 0, 0, 0, 830, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 757, 0, 825, 0, 759, 0, 0, 0, 756, 771, 770, 769, 0, 0, 0, 0, 761, 762, 763, 772, 773, 0, 0, 570, 0, 0, 785, 0, 775, 0, 0, 654, 760, 744, 743, 0, 0, 571, 0, 0, 745, 740, 741, 742, 774, 0, 0, 0, 0, 0, 0, 0, 522, 511, 0, 514, 516, 517, 518, 519, 525, 526, 0, 842, 592, 0, 0, 551, 0, 549, 0, 0, 0, 0, 411, 0, 0, 337, 0, 206, 0, 364, 357, 408, 409, 0, 0, 0, 0, 0, 0, 373, 0, 344, 345, 0, 509, 507, 788, 0, 0, 0, 0, 0, 0, 0, 140, 119, 0, 0, 90, 0, 108, 107, 0, 0, 0, 0, 0, 0, 826, 71, 0, 0, 0, 643, 644, 433, 0, 0, 319, 320, 314, 0, 318, 767, 0, 670, 0, 0, 24, 0, 0, 845, 0, 67, 65, 63, 30, 0, 0, 0, 49, 0, 0, 0, 0, 0, 0, 0, 0, 776, 0, 0, 0, 0, 0, 0, 777, 778, 0, 0, 0, 0, 0, 846, 283, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 839, 574, 0, 0, 548, 0, 523, 0, 520, 0, 521, 546, 0, 541, 0, 0, 515, 0, 650, 0, 485, 0, 0, 0, 555, 552, 0, 172, 0, 0, 116, 416, 159, 160, 0, 414, 0, 0, 0, 0, 417, 0, 412, 339, 0, 368, 370, 369, 0, 371, 0, 365, 204, 0, 0, 251, 0, 0, 0, 0, 377, 378, 0, 401, 0, 0, 0, 0, 0, 0, 0, 0, 0, 420, 0, 136, 0, 0, 145, 0, 144, 0, 151, 134, 0, 149, 152, 153, 141, 0, 0, 453, 489, 456, 0, 490, 0, 0, 457, 0, 0, 0, 480, 493, 452, 475, 454, 455, 438, 339, 436, 437, 439, 0, 0, 448, 449, 450, 451, 0, 0, 0, 0, 674, 673, 0, 111, 0, 0, 187, 0, 0, 337, 0, 206, 0, 0, 79, 0, 0, 662, 0, 0, 0, 0, 0, 0, 0, 0, 676, 680, 681, 682, 683, 684, 685, 686, 687, 688, 689, 768, 0, 0, 0, 669, 25, 0, 0, 41, 68, 0, 0, 23, 0, 0, 638, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 815, 816, 817, 818, 819, 820, 821, 822, 0, 0, 754, 755, 814, 0, 0, 829, 750, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 579, 580, 0, 0, 572, 575, 758, 797, 501, 0, 795, 500, 0, 524, 0, 532, 528, 527, 0, 0, 0, 543, 531, 0, 0, 648, 649, 0, 0, 0, 0, 0, 562, 0, 0, 117, 0, 0, 0, 0, 0, 0, 367, 0, 0, 340, 372, 446, 0, 253, 0, 247, 249, 337, 831, 224, 0, 0, 339, 0, 0, 195, 337, 0, 0, 0, 0, 229, 223, 226, 227, 228, 376, 406, 405, 375, 374, 0, 0, 0, 352, 348, 350, 351, 347, 349, 0, 339, 0, 142, 146, 0, 150, 0, 0, 476, 477, 494, 0, 491, 0, 0, 483, 481, 482, 0, 0, 0, 0, 447, 0, 0, 0, 0, 484, 337, 0, 186, 0, 189, 191, 192, 0, 0, 0, 0, 0, 206, 74, 0, 81, 73, 827, 464, 465, 0, 0, 0, 679, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 316, 322, 323, 321, 671, 0, 0, 0, 0, 0, 0, 0, 50, 57, 59, 0, 0, 66, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 206, 0, 798, 0, 0, 810, 0, 0, 0, 0, 0, 0, 0, 0, 0, 813, 764, 0, 0, 0, 0, 0, 0, 594, 0, 0, 0, 0, 0, 502, 796, 533, 542, 537, 536, 0, 547, 652, 651, 201, 557, 558, 556, 0, 168, 162, 169, 0, 165, 0, 0, 164, 0, 175, 156, 155, 794, 158, 157, 418, 0, 210, 207, 209, 211, 212, 366, 252, 0, 197, 339, 199, 340, 194, 200, 0, 0, 230, 0, 379, 380, 339, 337, 340, 353, 0, 183, 184, 143, 0, 0, 0, 0, 0, 0, 492, 0, 0, 339, 340, 0, 442, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 185, 0, 0, 0, 0, 326, 0, 78, 0, 0, 0, 0, 82, 80, 0, 0, 832, 645, 0, 0, 690, 0, 0, 0, 716, 715, 0, 0, 0, 723, 733, 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, 678, 0, 61, 54, 55, 60, 56, 0, 0, 19, 0, 0, 0, 39, 0, 0, 0, 656, 639, 0, 655, 0, 0, 0, 0, 804, 803, 0, 0, 800, 799, 0, 808, 807, 806, 805, 802, 801, 0, 0, 0, 582, 0, 589, 0, 587, 583, 0, 600, 596, 598, 0, 0, 0, 0, 539, 540, 544, 0, 0, 0, 0, 0, 0, 176, 0, 0, 0, 0, 256, 0, 0, 0, 231, 0, 402, 403, 381, 339, 422, 340, 828, 154, 0, 0, 459, 0, 458, 495, 0, 487, 0, 0, 0, 440, 0, 467, 0, 0, 469, 472, 474, 0, 0, 106, 0, 190, 339, 0, 0, 338, 0, 91, 0, 104, 0, 87, 0, 0, 0, 0, 0, 731, 732, 0, 0, 0, 0, 786, 779, 780, 0, 0, 781, 734, 0, 0, 0, 0, 0, 0, 0, 724, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 53, 58, 51, 52, 20, 660, 661, 0, 658, 665, 666, 663, 0, 637, 0, 0, 205, 809, 811, 812, 0, 0, 585, 0, 0, 0, 604, 607, 0, 0, 0, 0, 170, 166, 0, 0, 181, 177, 340, 0, 0, 340, 257, 0, 0, 0, 215, 0, 0, 0, 0, 419, 461, 0, 462, 0, 121, 0, 0, 0, 125, 127, 128, 129, 443, 445, 441, 471, 340, 0, 0, 0, 0, 324, 0, 327, 339, 83, 0, 0, 85, 0, 0, 0, 0, 0, 0, 736, 0, 735, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 37, 0, 640, 0, 588, 0, 0, 0, 0, 613, 0, 566, 0, 161, 178, 131, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 260, 263, 259, 0, 0, 268, 269, 270, 273, 275, 246, 0, 193, 216, 0, 0, 0, 221, 217, 220, 0, 340, 0, 460, 488, 130, 118, 126, 245, 113, 340, 0, 0, 341, 328, 0, 0, 86, 75, 0, 702, 710, 0, 782, 783, 784, 703, 711, 706, 714, 0, 0, 704, 712, 705, 713, 699, 707, 700, 708, 701, 709, 657, 0, 0, 608, 605, 0, 621, 623, 0, 618, 0, 171, 0, 0, 0, 277, 0, 0, 0, 276, 0, 266, 271, 0, 274, 261, 0, 264, 0, 305, 265, 196, 218, 222, 0, 0, 233, 355, 343, 0, 0, 0, 333, 334, 0, 0, 72, 88, 0, 738, 615, 0, 622, 0, 258, 267, 0, 0, 0, 272, 0, 299, 0, 298, 313, 0, 0, 0, 0, 308, 262, 306, 0, 0, 232, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 629, 0, 0, 0, 0, 292, 291, 293, 0, 290, 0, 0, 0, 0, 282, 0, 312, 836, 311, 310, 0, 0, 219, 0, 0, 0, 237, 0, 236, 336, 0, 0, 0, 105, 0, 616, 631, 620, 0, 0, 632, 0, 628, 0, 0, 0, 0, 0, 0, 0, 0, 300, 301, 307, 309, 0, 0, 241, 240, 239, 0, 329, 0, 627, 0, 634, 285, 0, 0, 278, 296, 295, 297, 294, 0, 0, 0, 302, 244, 242, 243, 0, 737, 0, 0, 0, 303, 279, 0, 0, 0, 633, 288, 280, 636, }; static short yydgoto[] = { 17, 18, 19, 20, 21, 22, 23, 1303, 25, 26, 1304, 28, 29, 30, 1305, 32, 1306, 567, 95, 377, 818, 1020, 96, 594, 819, 97, 382, 599, 119, 98, 99, 216, 646, 109, 820, 821, 157, 187, 822, 100, 101, 384, 72, 198, 359, 265, 562, 960, 266, 779, 535, 447, 758, 563, 564, 565, 962, 199, 1174, 64, 147, 65, 193, 1538, 1123, 178, 183, 185, 188, 175, 164, 167, 180, 190, 374, 217, 706, 471, 574, 903, 352, 554, 948, 1115, 503, 659, 925, 456, 457, 486, 346, 536, 936, 1227, 677, 899, 1228, 1229, 1230, 1231, 1232, 575, 176, 165, 342, 510, 343, 344, 511, 512, 513, 514, 1093, 894, 459, 460, 884, 882, 461, 888, 883, 1069, 1201, 889, 890, 1074, 354, 767, 768, 769, 770, 708, 694, 1213, 537, 710, 169, 475, 638, 268, 480, 1039, 368, 269, 270, 1214, 1215, 489, 1325, 1443, 716, 717, 704, 718, 719, 720, 1444, 1445, 1513, 324, 484, 1078, 1307, 153, 481, 482, 1079, 1080, 1308, 1309, 1310, 1397, 1311, 1312, 1313, 1314, 1315, 1316, 1463, 1500, 1431, 1503, 271, 414, 1465, 967, 1398, 1437, 1438, 1473, 370, 371, 272, 953, 1121, 1242, 954, 955, 113, 273, 1339, 363, 865, 1065, 1288, 1409, 1410, 1411, 1412, 863, 333, 500, 736, 1090, 181, 50, 328, 158, 126, 311, 144, 318, 150, 319, 329, 724, 330, 497, 920, 145, 312, 468, 501, 1091, 85, 155, 202, 538, 539, 696, 937, 697, 938, 939, 542, 543, 544, 545, 930, 783, 546, 547, 548, 751, 549, 449, 748, 34, 35, 36, 52, 160, 335, 291, 292, 293, 294, 295, 296, 297, 298, 299, 665, 439, 872, 1068, 440, 441, 670, 37, 125, 307, 38, 450, 451, 681, 424, 1199, 114, 274, 275, 276, 428, 647, 648, 649, 650, 857, 277, 1055, 1056, 1194, 1195, 278, 1286, 1455, 1379, 1456, 1457, 1458, 1497, 1539, 1030, 39, 40, 364, 41, 42, 446, 827, 1028, 1176, 1180, 172, 576, 577, 578, 579, 580, 581, 582, 583, 584, 585, 586, 1142, 977, 979, 1143, 412, 279, 280, 281, 636, 282, 1144, 195, 630, }; static short yysindex[] = { 5716, 1361, -212, 2352, 28, 918, -91, 3437, 15, 554, 449, 157, 2081, -212, 524, -97, -19, 0, 403, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -153, 0, 0, 0, 0, 0, 0, 4173, 197, 227, 258, -19, 341, 0, 0, 409, 1050, 510, 197, 529, 258, 547, -19, 341, 0, 580, 596, 0, -39, 0, 634, 0, 0, 801, 668, 0, -19, 739, 197, 884, 668, 227, 258, 547, -19, 341, 580, 596, 0, 258, 812, 0, 0, 0, 1215, 0, 1215, 0, 858, 924, 42, 1258, 0, 0, 0, 860, -19, 860, 951, 962, 966, 52, 774, 0, 0, 0, 5299, 0, 529, 1041, 905, 0, 0, 968, 930, 0, 1123, -104, 1098, -66, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 508, 0, 0, 1050, 0, -38, 0, 0, 1386, 0, 1108, 0, 0, 453, 0, 1011, 0, 0, 980, 0, 0, 436, 0, 0, 1184, 0, 0, 1409, 0, 1050, 0, 0, 0, 1386, 0, -74, 0, 0, 1171, 0, 1154, 0, 0, 1215, 0, 0, 0, 0, 0, 1158, 0, 0, 1044, 0, 0, 1191, 1080, 0, 0, 0, 1044, 0, 0, 0, 0, 0, 0, 0, 0, 1797, 0, 510, 0, 0, 0, 266, 1135, -210, 596, 1049, 0, 1198, 1215, 1223, 1226, 266, 1139, -210, 1162, 1163, 1512, 1513, 1516, 1105, 0, 1528, 0, 1532, 0, 1542, 1543, 1546, 0, 0, 0, 0, 0, 1547, 1112, 1133, 0, 0, 0, 0, 0, 5866, 5866, 0, 5396, 1146, 0, 1560, 0, 1725, 1520, 0, 0, 0, 0, 1291, 1571, 0, -129, 1575, 0, 0, 0, 0, 0, 1185, 227, 1262, 1174, 492, -19, 1194, 0, 0, 905, 0, 0, 0, 0, 0, 0, 0, 510, 0, 0, 699, 1213, 0, 1189, 0, 776, 1275, 701, -66, 0, 1346, 394, 0, 860, 0, 508, 0, 0, 0, 0, 860, 1230, -106, 1179, -46, 1600, 0, 4543, 0, 0, 407, 0, 0, 0, 1590, 1590, 1050, 1280, 1050, 1692, 436, 0, 0, 4883, 56, 0, 1230, 0, 0, 1368, 455, 1621, -19, 1398, 227, 0, 0, 1623, 159, 4248, 0, 0, 0, 1160, 2500, 0, 0, 0, 1622, 0, 0, 845, 0, -19, 1231, 0, 258, 1208, 0, 58, 0, 0, 0, 0, -19, -195, -19, 0, 1350, 258, 1628, 266, 1270, 948, 5478, 601, 0, 529, 5866, 1036, 1064, 1104, 3046, 0, 0, 628, 628, 524, 960, 1639, 0, 0, 5576, 1227, 5866, 5866, 5866, 5866, 5866, 5866, 25, 1241, 5478, 1237, 0, 0, 43, 14, 0, -173, 0, -131, 0, -131, 0, 0, 1657, 0, 80, 1276, 0, 1650, 0, 116, 0, 1434, 1434, 1674, 0, 0, 1337, 0, 60, 1372, 0, 0, 0, 0, 1050, 0, 1590, 1590, 1590, 1590, 0, 1678, 0, 0, 1450, 0, 0, 0, 1428, 0, 4883, 0, 0, 4883, 855, 0, 1386, 1467, 1272, 5118, 0, 0, 393, 0, 1272, 816, 1108, 0, 1345, 1298, 1273, 405, 426, 0, 1347, 0, 1290, 547, 0, 1050, 0, 1474, 0, 0, 1692, 0, 0, 0, 0, 156, 1305, 0, 0, 0, 1307, 0, 1352, 1716, 0, 1412, 1719, -61, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1670, 35, 0, 0, 0, 0, 21, 1723, 1733, 1719, 0, 0, 1501, 0, 1050, 1050, 0, -106, 453, 0, 1391, 0, 1362, 1732, 0, 6082, 99, 0, 1388, 1397, 1741, 4399, 1745, 4345, 6235, 400, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1082, 2500, 510, 0, 0, 611, 1349, 0, 0, 1329, -210, 0, 1480, 1759, 0, 1480, 611, 1485, 1492, 258, 5866, 5866, 1537, 5866, 1761, 5866, 1771, 1534, 5866, 5866, 5866, 5866, 5866, 5866, 0, 0, 0, 0, 0, 0, 0, 0, 1495, 5866, 0, 0, 0, 1725, 1203, 0, 0, 1541, 628, 628, 578, 578, 704, 25, 1783, 1780, 853, 0, 0, 4399, 1496, 0, 0, 0, 0, 0, -221, 0, 0, -110, 0, 1379, 0, 0, 0, -19, 656, -19, 0, 0, 5478, 510, 0, 0, 1227, -39, -39, 699, 510, 0, 1050, 1050, 0, 307, 1290, 1290, 1374, 547, 701, 0, 1789, 2023, 0, 0, 0, 1554, 0, 860, 0, 0, 0, 0, 0, 1558, 1796, 0, 1428, 1555, 0, 0, 1498, 1503, 1215, 1568, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 547, 860, 6243, 0, 0, 0, 0, 0, 0, 547, 0, 1020, 0, 0, 1430, 0, 72, 1435, 0, 0, 0, 547, 0, 1716, 48, 0, 0, 0, 1552, 48, 1436, 48, 0, 1818, 547, 547, 547, 0, 0, 1502, 0, 1304, 0, 0, 0, 407, 1446, -19, 1354, 41, 0, 0, 1825, 0, 0, 0, 0, 0, 159, 1407, 1213, 0, 1213, 6123, 354, 5866, 5866, 4485, 1827, 647, 4628, 5866, 4713, 944, 4865, 4948, 5631, 5016, 5100, 5253, 4399, 4399, 0, 0, 0, 0, 0, 1208, 258, 341, 1208, 580, 93, 1826, 0, 0, 0, 611, 1486, 0, -134, 1505, 5478, 1505, 1837, 1826, 611, -151, 1550, 1644, 2141, 0, 2186, 0, 2322, 5866, 0, 2330, 2413, 2577, 2597, 2898, 3343, 5866, 829, 5866, 0, 0, 853, 1842, 5478, 930, 25, 1497, 0, 1499, 1500, 1548, 1624, 1567, 0, 0, 0, 0, 0, 0, 440, 0, 0, 0, 0, 0, 0, 0, 1857, 0, 0, 0, 1399, 0, 1590, 1636, 0, 307, 0, 0, 0, 0, 0, 0, 0, 4399, 0, 0, 0, 0, 0, 0, 0, 1603, 0, 0, 0, 0, 0, 0, 1215, 1215, 0, 1865, 0, 0, 0, 0, 0, 0, 1642, 0, 0, 0, 1449, 28, 1420, 1493, 1554, 1874, 0, 1290, 1422, 0, 0, 767, 0, 1859, 1449, 798, 547, 1877, 1878, 1879, 1603, 1590, 1372, -106, 0, 1347, 524, 1466, 1482, 0, 17, 0, 547, 1531, 1625, 6082, 0, 0, 547, 1626, 0, 0, 1891, 1893, 0, 1461, 1725, 1898, 0, 0, 1725, 1900, 1862, 0, 0, 1588, 1902, 1725, 1904, 899, 1906, 1725, 1907, 5866, 5866, 1827, 5866, 5831, 1908, 1725, 1910, 1916, 1725, 1917, 5866, 1725, 1918, 1725, 1919, 1921, 1725, 1922, 1924, 1725, 1925, 0, 1705, 0, 0, 0, 0, 0, 1640, 611, 0, 611, 93, 1826, 0, 161, 161, 112, 0, 0, 1431, 0, 1837, 1826, 1926, -151, 0, 0, 4883, 1928, 0, 0, 3462, 0, 0, 0, 0, 0, 0, 3492, 1241, 1725, 0, 1725, 0, 1438, 0, 0, 853, 0, 0, 0, 25, 1511, 4399, 1504, 0, 0, 0, 1551, 1050, 1592, 1290, 1587, 1290, 0, 362, 1544, 1717, 1603, 0, 5866, 1701, 1594, 0, 4399, 0, 0, 0, 0, 0, 0, 0, 0, 1954, 28, 0, 1374, 0, 0, 48, 0, 2023, 1617, 48, 0, 48, 0, 1554, 1959, 0, 0, 0, 1717, 1290, 0, 1372, 0, 0, 5299, 1726, 0, -57, 0, 1857, 0, 1963, 0, 1967, 1050, -119, 1974, 1050, 0, 0, 5866, 1601, 1601, 524, 0, 0, 0, 1980, 1470, 0, 0, 1601, 1601, 5866, 1601, 1601, 1517, 1725, 0, 1106, 5866, 1725, 1601, 1601, 1601, 1601, 1725, 1601, 1601, 1601, 1601, 1601, 1601, 1637, 0, 0, 0, 0, 0, 0, 0, 1593, 0, 0, 0, 0, 5478, 0, -151, 1926, 0, 0, 0, 0, 1496, 5478, 0, 1005, 1744, 1983, 0, 0, 400, 1989, 1634, 1590, 0, 0, 1050, 1020, 0, 0, 0, 510, 4062, 0, 0, 1725, 1434, 1701, 0, 954, -19, 551, 1603, 0, 0, 1995, 0, 1997, 0, 1686, 1434, 1617, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1020, 1642, 1722, 1654, 0, 1446, 0, 0, 0, 1676, 1691, 0, 1554, 1679, 1725, 2014, 2017, 5866, 0, 2978, 0, 2018, 2020, 1725, 2022, 2024, 5866, 5866, 1725, 2030, 2031, 2034, 2037, 2040, 2044, 2045, 2047, 2050, 2061, 0, 161, 0, 1567, 0, 4399, 1227, 1511, 1290, 0, 452, 0, 1290, 0, 0, 0, 4883, 197, 1661, 2051, 1213, 2073, 1773, 5866, 2056, 2076, 2060, 2062, 1782, 2071, 0, 0, 0, 6359, 2072, 0, 0, 0, 0, 0, 0, 2092, 0, 0, 1781, 1792, -19, 0, 0, 0, 1215, 0, 1717, 0, 0, 0, 0, 0, 0, 0, 0, 29, 1241, 0, 0, 5866, 1050, 0, 0, 1050, 0, 0, 829, 0, 0, 0, 0, 0, 0, 0, 1725, 1725, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1634, 400, 0, 0, 391, 0, 0, 1769, 0, 2099, 0, 2082, 2084, 258, 0, 1799, 4399, 1695, 0, 4399, 0, 0, 96, 0, 0, -111, 0, -32, 0, 0, 0, 0, 0, 1215, 1760, 0, 0, 0, 29, 2104, 853, 0, 0, 1496, 1725, 0, 0, 1241, 0, 0, 1290, 0, 506, 0, 0, 941, 96, 582, 0, 604, 0, 766, 0, 0, 197, 1688, 28, 75, 0, 0, 0, 1760, -117, 0, 1767, 1768, 853, 2114, 29, 1815, 1567, 2124, 1496, 2127, -19, 0, 2129, 2128, 790, 2168, 0, 0, 0, 1762, 0, 2130, 85, 1739, 1875, 0, 96, 0, 0, 0, 0, 4062, -111, 0, -183, -183, 1883, 0, 1747, 0, 0, 853, 29, 1634, 0, 1567, 0, 0, 0, 506, 2147, 0, 227, 0, 1478, 37, 2132, 2168, 1899, 1887, 4062, 4062, 0, 0, 0, 0, 1730, 731, 0, 0, 0, 1318, 0, 1634, 0, 227, 0, 0, 96, 2153, 0, 0, 0, 0, 0, 1407, 4062, 1892, 0, 0, 0, 0, 4399, 0, 2155, 2163, 1483, 0, 0, 4062, 400, 227, 0, 0, 0, 0, }; static short yyrindex[] = { 0, 0, 109, 413, 0, 0, 0, 0, 0, 0, 0, 0, 0, 640, 5335, 0, 0, 0, 2206, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 367, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 831, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1870, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1833, 0, 0, 0, 59, 0, 59, 0, 0, 0, 0, 1834, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 915, 0, 0, 0, 1102, 0, 0, 0, 82, 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, -43, 0, 0, 0, 0, 320, 0, 936, 0, 0, 0, 0, 0, 985, 3723, 0, 6305, 0, 0, 0, 0, 0, 0, 0, 0, -43, 0, 460, 0, 0, 2170, 0, 0, 0, 0, 1947, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 937, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 939, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -175, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1229, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 63, 1316, 0, 0, 0, 0, 0, 1903, 0, 62, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 208, 0, 0, 953, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1021, 0, 1943, 0, 0, 0, 0, 1042, 0, 0, 0, 0, 0, 1961, 16, 4789, 0, 1058, 0, 0, 0, 0, 180, 0, 0, 0, 1775, 1775, 0, 0, 0, 1103, 1526, 0, 0, 0, 0, 0, 1961, 0, 0, 1074, 0, 0, 0, 0, 0, 0, 0, 5827, 1840, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1145, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1156, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1172, 0, 0, 6009, 0, 6009, 0, 0, 0, 6009, 6009, 6009, 0, 0, 0, 1973, 2207, 6009, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 750, 0, 0, 0, 0, 0, 0, 0, 0, 0, 768, 0, 768, 0, 0, 287, 0, 639, 661, 0, 0, 0, 937, 0, 994, 994, 778, 0, 0, 309, 0, 3093, 163, 0, 0, 0, 0, 0, 0, 1775, 1775, 1775, 1775, 0, 295, 0, 0, 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, 0, 1975, 0, 0, 0, 0, 0, 1943, 0, 0, 934, 0, 345, 1770, 0, 0, 0, 0, 0, 158, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1173, 0, 0, 0, 0, 4085, 1675, 0, 0, 0, 3771, 0, 0, 3875, 0, 0, 3940, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1222, 2991, 0, 0, 0, 0, 4046, 3858, 0, 3940, 0, 0, 0, 0, 0, 0, 0, 16, 863, 0, 0, 0, 0, 1828, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 365, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 207, 0, 0, 207, 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, 996, 0, 0, 0, 1665, 2345, 2432, 1748, 1835, 0, 0, 865, 522, 215, 0, 0, 0, 186, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 571, 0, 0, 0, 0, 0, 0, 0, 0, 646, 646, 0, 0, 0, 0, 0, 0, 4002, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 118, 0, 0, 0, 0, 0, 0, 0, 2198, 0, 0, 284, 2122, 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, 1998, 0, 0, 0, 0, 0, 4152, 0, 0, 0, 0, 0, 3875, 0, 0, 0, 0, 173, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 125, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6259, 0, 0, 0, 0, 0, 0, 0, 0, 1932, 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, 1202, 1221, 0, 0, 0, 0, 0, 0, 0, 1228, 0, 1228, 1251, 1285, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1909, 691, 0, 3506, 0, 1914, 0, 1920, 1927, 0, 0, 92, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 311, 0, 0, 0, 0, 0, 1775, 1784, 0, 4092, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1976, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1293, 0, 0, 0, 0, 0, 0, 0, 2161, 0, 0, 0, 0, 0, 0, 0, 0, 940, 0, 0, 0, 0, 0, 0, 1976, 1775, 1325, 16, 0, 1982, 5335, 1370, 83, 0, 0, 0, 0, 6259, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 53, 0, 0, 0, 632, 0, 0, 0, 0, 0, 0, 1525, 0, 2515, 0, 2592, 0, 0, 0, 0, 0, 0, 0, 2656, 0, 0, 2676, 0, 0, 2740, 0, 2763, 0, 0, 2827, 0, 0, 2850, 0, 0, 3472, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1202, 1373, 0, 1807, 237, 0, 0, 0, 0, 0, 1382, 1385, 1390, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 275, 1066, 0, 1491, 0, 0, 0, 0, 730, 0, 0, 0, 0, 0, 0, 398, 0, 0, 0, 3759, 0, 0, 0, 1795, 0, 0, 0, 0, 0, 1990, 0, 0, 2905, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 130, 0, 0, 0, 0, 2381, 0, 0, 0, 0, 0, 0, 0, 1394, 0, 0, 0, 0, 0, 0, 0, 1406, 0, 0, 0, 0, 0, 97, 0, 0, 0, 0, 0, 0, 0, 6009, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2913, 0, 2990, 0, 3074, 0, 0, 0, 0, 3158, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1410, 0, 0, 0, 0, 69, 0, 0, 1909, 711, 1295, 0, 0, 404, 857, 862, 1775, 0, 0, 0, 1481, 0, 0, 0, 0, 0, 0, 0, 2222, 1022, 3323, 0, 1943, 0, 0, 1976, 0, 0, 0, 0, 0, 0, 0, 1411, 134, 0, 0, 0, 0, 0, 0, 0, 0, 0, 272, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 47, 0, 3222, 0, 0, 0, 0, 0, 0, 0, 0, 3298, 0, 0, 0, 0, 3321, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 237, 0, 49, 0, 0, 0, 0, 0, 0, 2230, 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, 337, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 132, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3332, 3408, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2231, 3548, 0, 0, 0, 0, 0, 2233, 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, 826, 1260, 0, 0, 0, 0, 214, 87, 0, 0, 68, 2222, 0, 0, 275, 0, 0, 0, 0, 2230, 0, 0, 189, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2459, 0, 0, 3075, 3299, 1909, 756, 0, 0, 84, 0, 69, 0, 1142, 0, 0, 2234, 0, 0, 0, 0, 0, 2215, 0, 202, 1977, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 153, 0, 55, 0, 49, 0, 0, 0, 2230, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1909, 0, 2231, 0, 0, 0, 0, 0, 2227, 0, 0, 0, 0, 0, 0, 0, 6400, 0, 0, 0, 0, 0, 0, 2240, 0, 0, 0, 0, 0, 1490, 0, 0, 0, 0, 0, }; static short yygindex[] = { 0, 0, 0, 0, 0, 0, 0, 2287, 0, 0, 2289, 0, 0, 0, 8, 0, 2291, 1, 167, -93, -533, 1271, 257, -284, 6, 2285, 2070, 0, -31, 0, 2080, -86, -41, 0, 476, -850, -35, -50, -169, 2086, 984, 1706, 0, 0, 0, 1016, 0, 0, -34, 1351, -485, -29, -802, 1749, 1535, -276, 1357, 2236, -291, 0, -51, 0, 806, -44, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -565, -25, 1371, -447, 339, -860, 0, 0, 0, 0, -316, -477, -976, 1378, -311, -40, 0, -442, 0, 0, -428, 1216, 0, 1101, 0, 0, -108, -553, -10, 0, 0, 0, 0, 1987, 0, 1820, 2027, -235, 1392, -663, 0, 0, 0, -635, 0, 0, 0, 0, 0, 0, 1448, 0, 0, 0, 1389, 2015, 2021, 0, 1631, 0, -450, 1633, -48, 70, -630, -45, 0, 0, -576, -202, -526, 0, 1137, -906, 0, 917, 1143, 0, 1888, 0, 0, 0, 921, 938, 889, -78, 2025, -826, -456, 0, 0, 1685, 0, 1299, -623, 0, 0, 0, -226, 0, 0, 0, 0, 0, 0, 0,-1236, 0, 392, 0, 926, 864, 999, 0, 922, 0, 0, 2032, -203, 0, 0, 0, 0, -904, -375, 1278, 0, -409,-1078, -671, -670, 0, -608, 983, 950, -289, 1843, 1641, 1457, 1176, -1, 0, 0, 0, 0, 0, 2083, 0, 0, 2093, 1923, 0, 0, 0, 0, 0, 2107, 0, 0, 0, 0, -15, 0, 0, 0, -314, 1667, -303, 1326, -391, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1880, 0, 0, 1682, 0, 0, 0, 2420, 0, 0, 0, 0, 2143, 0, 0, 0, 0, 2004, 0, 2001, 0, 0, 0, 1776, 0, 0, 0, 0, 0, -84, 0, 1765, 0, -800, 0, 1195, 0, 2026, -374, 2019, 0, -567, 1802, 0, 0, -54, 0, 1263, 0, 1164, -942, 0, 1165, 0, 957, 0, 1003, 0, 920, 0, 0, 0, 2028, 0, 0, 0, 1860, 1649, -869, 0, -148, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3433, 1300, 1479, 0, 0, 0, 0, -201, 2058, 2118, 1233, 0, 0, }; #define YYTABLESIZE 6861 static short yytable[] = { 171, 121, 149, 69, 173, 68, 152, 218, 31, 170, 372, 369, 373, 809, 168, 652, 177, 154, 787, 163, 790, 678, 504, 610, 203, 184, 737, 695, 182, 179, 698, 509, 540, 211, 206, 631, 709, 674, 207, 660, 305, 477, 715, 541, 707, 213, 876, 210, 885, 1082, 1050, 208, 383, 725, 225, 619, 227, 215, 121, 658, 1088, 760, 383, 653, 208, 645, 209, 302, 603, 1408, 568, 830, 226, 67, 445, 467, 1103, 1522, 854, 928, 780, 959, 563, 325, 610, 550, 222, 331, 468, 754, 610, 468, 610, 933, 725, 263, 222, 725, 550, 349, 683, 356, 598, 668, 653, 283, 573, 653, 605, 506, 603, 1280, 725, 320, 619, 880, 927, 900, 468, 1476, 1113, 1196, 653, 208, 669, 112, 757, 603, 1098, 1470, 123, 331, 612, 610, 124, 426, 391, 1019, 84, 348, 388, 563, 325, 610, 67, 684, 331, 686, 687, 688, 689, 610, 1433, 332, 263, 1248, 304, 1177, 354, 468, 673, 171, 468, 413, 372, 369, 373, 902, 506, 1170, 375, 1172, 540, 122, 434, 264, 1216, 468, 813, 106, 421, 867, 485, 541, 112, 1478, 603, 1025, 378, 123, 1466, 612, 308, 124, 350, 1510, 742, 332, 378, 551, 509, 67, 1434, 1243, 67, 472, 67, 659, 529, 891, 892, 596, 332, 1435, 330, 577, 752, 354, 1244, 321, 452, 248, 413, 14, 264, 743, 191, 603, 1291, 115, 73, 1220, 122, 661, 380, 123, 1511, 466, 656, 421, 431, 309, 491, 668, 51, 603, 171, 663, 286, 171, 601, 381, 289, 1011, 1012, 444, 577, 438, 448, 577, 908, 284, 1336, 1523, 192, 866, 659, 529, 476, 107, 668, 171, 182, 330, 577, 479, 232, 1439, 918, 492, 170, 551, 495, 1512, 208, 753, 1540, 535, 124, 922, 1022, 1058, 351, 816, 225, 415, 466, 322, 874, 1032, 1034, 606, 705, 1026, 602, 505, 1235, 507, 1216, 565, 381, 564, 756, 560, 14, 725, 612, 1436, 664, 556, 346, 468, 208, 834, 558, 208, 1479, 653, 208, 682, 436, 182, 427, 1170, 116, 1450, 225, 668, 595, 1341, 655, 117, 1196, 208, 1076, 592, 535, 1292, 1249, 1502, 1317, 595, 1318, 310, 415, 166, 600, 468, 603, 934, 69, 952, 691, 378, 1178, 611, 233, 554, 565, 248, 564, 208, 725, 231, 1489, 725, 468, 1335, 668, 346, 1475, 668, 725, 573, 653, 725, 811, 810, 373, 725, 614, 1124, 468, 1329, 725, 970, 668, 725, 614, 668, 603, 603, 1140, 1207, 609, 701, 611, 84, 339, 1369, 123, 610, 339, 725, 124, 224, 331, 225, 86, 331, 1395, 413, 354, 563, 611, 468, 554, 685, 468, 383, 104, 601, 1419, 610, 1223, 1202, 958, 725, 711, 614, 725, 725, 118, 668, 421, 609, 610, 875, 1345, 1420, 725, 122, 267, 122, 1029, 896, 867, 614, 225, 468, 1081, 612, 122, 609, 612, 603, 603, 725, 1405, 759, 413, 1086, 739, 656, 112, 738, 780, 1407, 166, 221, 610, 610, 332, 208, 331, 332, 151, 66, 1102, 610, 118, 901, 373, 965, 725, 1192, 619, 601, 166, 961, 657, 208, 1184, 171, 224, 603, 725, 656, 725, 603, 619, 1197, 170, 597, 468, 69, 653, 224, 603, 506, 765, 766, 576, 603, 653, 610, 900, 603, 331, 612, 468, 893, 1218, 610, 577, 208, 171, 468, 325, 610, 331, 725, 331, 330, 577, 812, 330, 577, 1018, 1417, 332, 529, 122, 415, 1451, 468, 577, 166, 66, 601, 781, 1038, 208, 576, 208, 69, 595, 782, 1290, 362, 1072, 893, 208, 612, 603, 659, 902, 1119, 421, 346, 610, 576, 413, 603, 346, 468, 529, 612, 566, 468, 346, 566, 1328, 566, 332, 1204, 1185, 1206, 408, 409, 286, 411, 415, 577, 612, 466, 332, 612, 332, 1370, 831, 330, 577, 284, 529, 66, 806, 529, 66, 171, 66, 182, 1210, 1467, 806, 171, 171, 603, 444, 772, 535, 1114, 694, 529, 448, 375, 438, 1238, 873, 545, 506, 1189, 1219, 612, 1013, 1468, 561, 1016, 881, 881, 565, 479, 564, 1372, 1054, 330, 577, 1237, 146, 529, 895, 530, 806, 208, 886, 535, 498, 330, 577, 330, 420, 1239, 612, 694, 603, 421, 694, 499, 102, 917, 919, 1350, 473, 961, 611, 208, 554, 1396, 148, 914, 561, 694, 208, 535, 611, 474, 535, 611, 545, 506, 1418, 376, 968, 577, 969, 561, 611, 729, 554, 1224, 331, 606, 535, 712, 415, 1234, 102, 614, 346, 151, 530, 668, 102, 609, 540, 916, 208, 118, 732, 1371, 578, 943, 944, 945, 921, 541, 267, 887, 535, 614, 615, 807, 956, 830, 730, 609, 931, 109, 851, 807, 612, 102, 606, 611, 635, 606, 639, 640, 641, 642, 643, 635, 611, 1255, 267, 733, 313, 1017, 534, 715, 606, 578, 905, 1014, 578, 1141, 434, 373, 553, 1487, 1015, 911, 399, 69, 111, 1319, 614, 807, 332, 578, 103, 612, 609, 337, 713, 614, 1375, 853, 1342, 1333, 1446, 609, 156, 1057, 555, 684, 611, 1279, 1374, 612, 1470, 1104, 1380, 806, 87, 314, 830, 1516, 1517, 159, 611, 1376, 1175, 1175, 1179, 1469, 668, 534, 112, 1023, 338, 508, 339, 1427, 946, 714, 1429, 553, 1033, 614, 1485, 576, 1104, 1381, 806, 609, 1066, 1537, 731, 1461, 1375, 576, 1508, 611, 576, 340, 88, 617, 416, 609, 1105, 111, 619, 576, 417, 586, 806, 668, 89, 734, 668, 420, 418, 1406, 419, 1376, 421, 435, 1515, 1377, 341, 1531, 1532, 1461, 1289, 668, 591, 1083, 1084, 590, 508, 1108, 609, 90, 694, 171, 700, 1067, 617, 699, 901, 373, 171, 619, 170, 611, 586, 1542, 416, 586, 576, 375, 789, 1109, 417, 513, 617, 161, 162, 576, 1548, 619, 109, 109, 586, 1526, 69, 315, 1094, 1127, 1413, 1125, 436, 1377, 407, 1131, 510, 612, 807, 317, 813, 420, 418, 1453, 419, 316, 421, 835, 836, 437, 838, 694, 840, 512, 694, 843, 844, 845, 846, 847, 848, 694, 91, 576, 694, 561, 120, 118, 694, 807, 850, 166, 92, 694, 513, 576, 694, 538, 407, 317, 463, 1459, 545, 1544, 444, 138, 366, 561, 1054, 1087, 174, 807, 694, 407, 202, 510, 612, 93, 317, 263, 980, 632, 420, 418, 530, 419, 66, 421, 1452, 171, 576, 267, 512, 579, 814, 94, 694, 545, 1193, 694, 694, 361, 202, 200, 69, 69, 981, 579, 538, 694, 606, 464, 1534, 444, 87, 579, 881, 765, 202, 530, 765, 186, 362, 606, 138, 545, 694, 189, 545, 578, 815, 579, 606, 202, 1351, 816, 373, 94, 358, 578, 870, 817, 578, 202, 545, 465, 202, 530, 212, 612, 530, 578, 381, 694, 601, 1175, 88, 871, 333, 612, 361, 202, 612, 466, 1535, 694, 530, 694, 89, 765, 545, 612, 333, 194, 69, 1247, 1222, 553, 1251, 606, 333, 362, 593, 147, 668, 579, 668, 766, 606, 416, 766, 534, 530, 90, 668, 417, 333, 358, 578, 553, 694, 1449, 346, 808, 196, 454, 589, 578, 1494, 197, 971, 972, 976, 346, 455, 983, 985, 987, 612, 995, 998, 1001, 1003, 1006, 1009, 315, 593, 612, 420, 418, 423, 419, 606, 421, 171, 171, 40, 1449, 66, 766, 166, 593, 147, 170, 444, 1495, 606, 267, 1293, 881, 333, 578, 48, 148, 534, 859, 617, 534, 1496, 416, 1042, 619, 91, 578, 586, 417, 1327, 586, 1049, 860, 1051, 612, 92, 534, 586, 1053, 1449, 586, 617, 606, 201, 586, 38, 619, 315, 668, 586, 204, 111, 586, 668, 1148, 360, 861, 214, 40, 989, 93, 578, 534, 365, 21, 446, 1462, 373, 586, 1449, 668, 664, 830, 171, 48, 148, 990, 668, 70, 71, 237, 612, 1193, 416, 1404, 219, 1382, 852, 617, 417, 851, 285, 586, 619, 44, 608, 586, 617, 215, 171, 1462, 373, 202, 238, 38, 586, 446, 138, 444, 446, 862, 668, 826, 830, 830, 830, 830, 830, 842, 830, 69, 991, 586, 21, 446, 722, 286, 723, 46, 138, 664, 830, 830, 830, 830, 1403, 423, 240, 602, 111, 202, 617, 1527, 373, 238, 223, 619, 238, 1385, 586, 992, 220, 1415, 44, 287, 1416, 202, 288, 138, 739, 1441, 586, 238, 830, 224, 830, 121, 111, 114, 586, 859, 1151, 1152, 289, 1154, 1156, 1321, 138, 202, 602, 228, 171, 1161, 616, 860, 1425, 138, 46, 950, 229, 1430, 949, 138, 230, 88, 423, 586, 602, 1322, 290, 739, 739, 739, 739, 739, 1323, 739, 111, 861, 325, 138, 618, 326, 342, 171, 171, 22, 993, 739, 739, 739, 739, 284, 1460, 1430, 45, 1471, 114, 47, 416, 300, 90, 1282, 42, 301, 417, 121, 115, 957, 1324, 303, 776, 247, 248, 249, 166, 161, 162, 171, 103, 1454, 620, 739, 43, 202, 923, 924, 1460, 327, 171, 306, 1265, 862, 1212, 171, 252, 253, 593, 1506, 323, 257, 258, 342, 444, 593, 22, 121, 593, 69, 334, 1474, 593, 1454, 1071, 45, 336, 1070, 47, 171, 593, 171, 345, 42, 171, 171, 1520, 115, 1430, 347, 1525, 91, 267, 444, 444, 1096, 593, 1101, 1095, 103, 1100, 92, 171, 43, 202, 121, 1182, 355, 1252, 1181, 171, 1430, 1454, 1191, 630, 182, 1190, 877, 878, 444, 593, 1261, 353, 171, 335, 830, 93, 830, 1266, 1169, 357, 1171, 444, 593, 446, 830, 446, 420, 418, 358, 419, 446, 421, 830, 446, 1258, 161, 162, 1257, 830, 593, 630, 830, 1521, 267, 593, 1501, 446, 1547, 695, 139, 1470, 361, 1053, 630, 335, 590, 362, 335, 590, 110, 110, 379, 387, 182, 830, 392, 593, 389, 390, 394, 395, 830, 335, 830, 830, 396, 397, 830, 593, 398, 593, 830, 420, 418, 830, 419, 830, 421, 830, 695, 399, 400, 695, 830, 830, 401, 830, 406, 842, 420, 418, 739, 419, 739, 421, 402, 403, 695, 139, 404, 405, 739, 830, 830, 609, 830, 613, 1349, 407, 739, 617, 619, 621, 415, 446, 739, 1357, 1358, 739, 830, 413, 830, 830, 830, 422, 423, 830, 602, 425, 830, 830, 247, 248, 249, 429, 430, 446, 432, 433, 830, 602, 739, 442, 446, 14, 453, 462, 470, 739, 602, 739, 739, 1387, 859, 739, 483, 830, 493, 739, 257, 258, 739, 490, 739, 502, 739, 506, 860, 553, 43, 739, 739, 830, 739, 557, 559, 561, 446, 749, 589, 44, 593, 381, 830, 604, 598, 607, 45, 478, 739, 739, 861, 739, 633, 1414, 830, 602, 830, 1036, 420, 418, 637, 419, 830, 421, 602, 739, 651, 739, 739, 739, 427, 46, 739, 667, 1536, 739, 739, 671, 749, 749, 749, 749, 749, 672, 749, 739, 676, 478, 478, 830, 679, 478, 680, 454, 690, 1135, 749, 749, 749, 749, 692, 693, 739, 702, 862, 703, 478, 727, 602, 420, 418, 182, 419, 416, 421, 726, 728, 735, 739, 417, 752, 656, 602, 740, 746, 744, 1428, 745, 747, 739, 749, 750, 182, 755, 749, 761, 47, 764, 478, 420, 418, 739, 419, 739, 421, 762, 775, 773, 776, 739, 784, 1264, 785, 786, 182, 602, 1432, 788, 823, 695, 182, 752, 752, 752, 752, 752, 824, 752, 48, 416, 826, 828, 49, 837, 839, 417, 739, 139, 832, 752, 752, 752, 752, 182, 335, 833, 416, 841, 849, 1464, 1432, 335, 417, 416, 335, 856, 858, 864, 335, 139, 868, 897, 182, 756, 906, 893, 335, 753, 907, 367, 182, 182, 705, 752, 366, 912, 695, 182, 915, 695, 913, 926, 335, 1464, 929, 935, 695, 940, 139, 695, 942, 947, 264, 695, 1507, 182, 952, 964, 695, 978, 966, 695, 1021, 1035, 1024, 1027, 335, 139, 753, 753, 753, 753, 753, 1019, 753, 1052, 139, 695, 1059, 335, 1060, 1061, 139, 1432, 1062, 1528, 753, 753, 753, 753, 1063, 1064, 182, 590, 1073, 1077, 335, 1085, 1089, 366, 139, 695, 1092, 182, 695, 695, 1432, 1099, 1097, 1106, 1110, 1111, 1112, 1120, 695, 1122, 416, 264, 958, 749, 753, 749, 417, 335, 1133, 478, 1134, 1129, 1132, 749, 1136, 695, 1137, 1145, 1146, 335, 1147, 335, 1149, 1150, 1157, 478, 1158, 749, 478, 478, 749, 478, 1159, 1160, 1162, 1163, 478, 1164, 1165, 478, 1166, 1167, 695, 806, 1168, 1186, 1183, 463, 250, 747, 1200, 416, 478, 749, 695, 1205, 695, 417, 478, 1203, 749, 478, 749, 749, 1209, 485, 749, 1208, 1198, 508, 749, 1221, 1226, 749, 182, 749, 1236, 749, 1217, 1245, 1241, 416, 749, 749, 1246, 749, 752, 417, 752, 695, 747, 1250, 747, 747, 747, 1138, 752, 1256, 464, 1277, 1283, 749, 749, 1284, 749, 1285, 1278, 1287, 747, 747, 747, 747, 1330, 752, 1331, 1332, 1340, 454, 749, 1338, 749, 749, 749, 1344, 1343, 749, 455, 1346, 749, 749, 478, 1347, 465, 182, 1348, 1353, 752, 1354, 749, 1355, 1383, 1356, 747, 752, 366, 752, 752, 1359, 1360, 752, 466, 1361, 478, 752, 1362, 749, 752, 1363, 752, 478, 752, 1364, 1365, 478, 1366, 752, 752, 1367, 752, 237, 478, 749, 984, 753, 988, 753, 996, 999, 1368, 1004, 1007, 1010, 749, 753, 752, 752, 1384, 752, 478, 1386, 103, 1388, 1389, 478, 749, 1390, 749, 1391, 436, 1392, 753, 752, 749, 752, 752, 752, 1393, 1399, 752, 1400, 1401, 752, 752, 1402, 1421, 1422, 1426, 1423, 478, 1424, 1442, 752, 478, 753, 1448, 1472, 240, 1480, 1482, 749, 753, 1484, 753, 753, 237, 1486, 753, 468, 752, 436, 753, 1488, 436, 753, 1490, 753, 1492, 753, 1493, 1499, 1501, 1504, 753, 753, 752, 753, 1505, 436, 1037, 420, 418, 1478, 419, 1519, 421, 752, 1479, 1524, 1530, 1529, 1533, 753, 753, 1470, 753, 1545, 1543, 752, 468, 752, 1546, 468, 1, 746, 561, 752, 188, 668, 753, 366, 753, 753, 753, 26, 28, 753, 468, 339, 753, 753, 569, 250, 263, 1040, 420, 418, 466, 419, 753, 421, 135, 747, 752, 747, 198, 248, 77, 404, 466, 179, 466, 747, 354, 255, 746, 753, 746, 746, 746, 601, 180, 247, 248, 249, 599, 161, 162, 254, 747, 340, 595, 753, 746, 746, 746, 746, 625, 597, 619, 624, 289, 626, 753, 182, 252, 253, 1138, 635, 304, 257, 258, 747, 287, 24, 753, 27, 753, 33, 747, 1173, 747, 747, 753, 108, 747, 182, 746, 393, 747, 386, 825, 747, 1139, 747, 385, 747, 774, 963, 1130, 205, 747, 747, 1128, 747, 1225, 237, 247, 248, 249, 753, 161, 162, 1116, 1126, 182, 1334, 515, 741, 1107, 747, 747, 458, 747, 1075, 1117, 909, 487, 87, 910, 252, 253, 748, 488, 182, 257, 258, 747, 1320, 747, 747, 747, 182, 182, 747, 1477, 1326, 747, 747, 182, 1041, 420, 418, 1483, 419, 1514, 421, 747, 1043, 420, 418, 552, 419, 240, 421, 1211, 721, 182, 468, 1481, 88, 904, 1498, 748, 747, 748, 748, 748, 1447, 182, 1541, 182, 89, 1440, 1240, 1509, 588, 436, 771, 436, 747, 748, 748, 748, 748, 1118, 105, 436, 478, 951, 496, 747, 1337, 725, 182, 469, 468, 90, 416, 468, 436, 941, 468, 747, 417, 747, 763, 1233, 932, 751, 110, 747, 443, 662, 666, 748, 468, 468, 468, 182, 869, 879, 654, 468, 855, 1373, 468, 1518, 653, 1378, 1281, 1044, 420, 418, 1491, 419, 238, 421, 747, 468, 829, 237, 1549, 416, 898, 468, 746, 1153, 746, 417, 751, 675, 751, 751, 751, 1031, 746, 644, 247, 248, 249, 587, 161, 162, 0, 0, 91, 1352, 751, 751, 751, 751, 0, 746, 0, 0, 92, 238, 436, 0, 238, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 719, 0, 0, 238, 746, 0, 240, 0, 436, 93, 751, 746, 0, 746, 746, 436, 0, 746, 0, 0, 0, 746, 0, 0, 746, 468, 746, 94, 746, 0, 366, 0, 0, 746, 746, 0, 746, 0, 0, 0, 0, 719, 0, 0, 719, 0, 0, 468, 264, 436, 0, 0, 746, 746, 468, 746, 0, 0, 0, 719, 0, 0, 0, 0, 0, 468, 0, 0, 0, 746, 0, 746, 746, 746, 0, 0, 746, 698, 0, 746, 746, 0, 0, 468, 0, 0, 0, 416, 468, 746, 0, 0, 748, 417, 748, 416, 0, 0, 0, 0, 0, 417, 748, 1045, 420, 418, 746, 419, 0, 421, 0, 247, 248, 249, 166, 161, 162, 468, 698, 748, 0, 698, 746, 1046, 420, 418, 0, 419, 0, 421, 0, 0, 53, 746, 252, 253, 698, 0, 0, 257, 258, 696, 748, 54, 468, 746, 468, 746, 0, 748, 55, 748, 748, 746, 468, 748, 0, 0, 0, 748, 0, 697, 748, 56, 748, 0, 748, 468, 0, 0, 0, 748, 748, 0, 748, 0, 0, 0, 416, 751, 746, 751, 696, 0, 417, 696, 0, 0, 0, 751, 748, 748, 0, 748, 0, 0, 0, 0, 0, 0, 696, 0, 697, 0, 0, 697, 751, 748, 0, 748, 748, 748, 0, 0, 748, 0, 0, 748, 748, 0, 697, 0, 238, 0, 238, 727, 0, 748, 0, 751, 0, 0, 238, 0, 0, 0, 751, 0, 751, 751, 57, 0, 751, 0, 748, 468, 751, 0, 691, 751, 0, 751, 0, 751, 0, 0, 0, 58, 751, 751, 748, 751, 719, 0, 0, 0, 727, 468, 0, 727, 0, 748, 59, 0, 468, 0, 60, 751, 751, 61, 751, 237, 0, 748, 727, 748, 0, 62, 0, 691, 0, 748, 691, 0, 751, 0, 751, 751, 751, 0, 0, 751, 0, 0, 751, 751, 63, 691, 468, 0, 0, 0, 692, 0, 751, 0, 0, 0, 748, 719, 0, 0, 719, 238, 0, 0, 0, 0, 0, 719, 0, 751, 719, 0, 0, 693, 719, 0, 240, 698, 0, 719, 416, 0, 719, 238, 0, 751, 417, 0, 0, 0, 238, 692, 0, 0, 692, 0, 751, 0, 719, 0, 416, 0, 0, 0, 0, 0, 417, 0, 751, 692, 751, 0, 0, 0, 693, 0, 751, 693, 0, 0, 0, 0, 719, 0, 238, 719, 719, 0, 213, 0, 0, 0, 693, 0, 698, 719, 726, 698, 0, 0, 0, 696, 0, 751, 698, 0, 0, 698, 0, 0, 0, 698, 719, 0, 0, 0, 698, 0, 0, 698, 0, 697, 1047, 420, 418, 0, 419, 0, 421, 213, 0, 0, 213, 0, 0, 698, 0, 726, 0, 719, 726, 247, 248, 249, 0, 161, 162, 213, 0, 0, 0, 719, 0, 719, 0, 726, 0, 0, 696, 698, 0, 696, 698, 698, 252, 253, 0, 0, 696, 257, 258, 696, 698, 720, 468, 696, 0, 0, 697, 0, 696, 697, 0, 696, 0, 727, 719, 0, 697, 698, 0, 697, 0, 0, 0, 697, 0, 0, 0, 696, 697, 0, 0, 697, 0, 0, 366, 0, 691, 0, 0, 0, 0, 0, 720, 468, 698, 720, 468, 697, 0, 0, 0, 696, 264, 0, 696, 696, 698, 0, 698, 0, 720, 468, 0, 0, 696, 0, 0, 0, 0, 0, 727, 697, 0, 727, 697, 697, 0, 0, 0, 0, 727, 696, 0, 727, 697, 728, 234, 727, 0, 0, 0, 698, 727, 691, 0, 727, 691, 0, 0, 0, 692, 697, 0, 691, 163, 0, 691, 0, 696, 0, 691, 727, 0, 0, 0, 691, 0, 0, 691, 0, 696, 0, 696, 693, 0, 0, 728, 234, 697, 728, 234, 0, 0, 0, 691, 727, 0, 0, 727, 727, 697, 0, 697, 0, 728, 234, 0, 0, 727, 0, 0, 0, 0, 0, 0, 696, 0, 692, 691, 0, 692, 691, 691, 163, 0, 727, 0, 692, 0, 729, 692, 691, 0, 0, 692, 697, 0, 0, 0, 692, 693, 0, 692, 693, 0, 0, 726, 0, 691, 416, 693, 0, 727, 693, 225, 417, 213, 693, 692, 0, 0, 0, 693, 0, 727, 693, 727, 0, 0, 0, 729, 0, 0, 729, 0, 691, 0, 0, 0, 0, 0, 693, 692, 0, 0, 692, 692, 691, 729, 691, 0, 0, 0, 717, 0, 692, 0, 0, 0, 727, 0, 0, 0, 726, 0, 693, 726, 0, 693, 693, 0, 0, 692, 726, 0, 0, 726, 0, 693, 0, 726, 0, 691, 720, 0, 726, 0, 0, 726, 0, 0, 0, 0, 0, 717, 693, 0, 717, 0, 692, 468, 0, 468, 0, 726, 237, 0, 468, 0, 0, 468, 692, 717, 692, 0, 225, 0, 0, 0, 0, 0, 0, 693, 468, 0, 0, 0, 0, 726, 721, 235, 726, 726, 0, 693, 0, 693, 225, 0, 0, 720, 726, 0, 720, 225, 0, 692, 0, 0, 0, 720, 0, 730, 720, 214, 0, 0, 720, 726, 0, 0, 0, 720, 718, 0, 720, 0, 728, 0, 693, 721, 235, 0, 721, 235, 0, 0, 0, 225, 0, 0, 720, 163, 0, 234, 726, 234, 0, 721, 235, 0, 0, 0, 730, 234, 214, 730, 726, 214, 726, 0, 468, 0, 163, 718, 720, 0, 718, 720, 720, 0, 730, 0, 214, 0, 1048, 420, 418, 720, 419, 0, 421, 718, 468, 728, 163, 0, 728, 0, 0, 468, 163, 726, 0, 728, 720, 0, 728, 0, 722, 0, 728, 0, 0, 0, 0, 728, 0, 0, 728, 0, 729, 0, 1139, 163, 0, 0, 0, 0, 0, 0, 0, 720, 0, 468, 728, 0, 247, 248, 249, 0, 161, 162, 163, 720, 0, 720, 0, 0, 0, 722, 0, 163, 722, 0, 234, 0, 0, 163, 728, 252, 253, 728, 728, 0, 257, 258, 0, 722, 0, 0, 0, 728, 677, 0, 0, 163, 234, 729, 720, 0, 729, 0, 0, 234, 717, 0, 0, 729, 728, 0, 729, 0, 0, 0, 729, 0, 0, 0, 0, 729, 0, 0, 729, 1187, 420, 418, 584, 419, 0, 421, 0, 0, 163, 677, 0, 728, 677, 234, 729, 622, 623, 624, 625, 626, 627, 628, 629, 728, 0, 728, 0, 677, 0, 1188, 420, 418, 0, 419, 0, 421, 0, 717, 729, 0, 717, 729, 729, 584, 581, 0, 584, 717, 0, 0, 717, 729, 0, 0, 717, 0, 721, 0, 728, 717, 0, 584, 717, 0, 0, 0, 0, 0, 729, 0, 0, 0, 0, 235, 0, 235, 0, 0, 717, 730, 0, 0, 0, 235, 0, 581, 0, 0, 581, 0, 718, 0, 0, 0, 0, 729, 0, 225, 0, 214, 0, 0, 717, 581, 0, 717, 717, 729, 0, 729, 0, 0, 0, 721, 0, 717, 721, 0, 0, 416, 0, 0, 0, 721, 0, 417, 721, 0, 0, 0, 721, 0, 717, 0, 0, 721, 730, 0, 721, 730, 0, 0, 729, 0, 0, 0, 730, 718, 0, 730, 718, 0, 0, 730, 721, 0, 0, 718, 730, 717, 718, 730, 0, 0, 718, 0, 722, 0, 0, 718, 0, 717, 718, 717, 235, 0, 0, 730, 721, 0, 0, 721, 721, 0, 0, 0, 0, 0, 718, 0, 0, 721, 0, 0, 0, 0, 235, 0, 225, 0, 0, 730, 0, 235, 730, 730, 717, 0, 721, 0, 0, 0, 718, 0, 730, 718, 718, 0, 0, 830, 225, 0, 0, 722, 0, 718, 722, 225, 0, 0, 0, 730, 0, 722, 0, 721, 722, 235, 416, 74, 722, 0, 718, 0, 417, 722, 75, 721, 722, 721, 76, 77, 0, 0, 0, 167, 0, 0, 730, 0, 830, 225, 0, 830, 722, 842, 0, 479, 416, 718, 730, 78, 730, 0, 417, 0, 0, 0, 830, 0, 830, 718, 721, 718, 0, 0, 0, 677, 722, 0, 677, 722, 722, 0, 0, 0, 167, 677, 0, 167, 677, 722, 0, 0, 677, 730, 0, 479, 479, 677, 0, 479, 677, 0, 167, 0, 718, 0, 722, 0, 0, 584, 0, 0, 584, 0, 479, 0, 677, 0, 0, 584, 0, 0, 584, 0, 79, 0, 584, 0, 0, 0, 0, 584, 0, 722, 584, 0, 0, 0, 0, 0, 677, 80, 473, 677, 677, 722, 479, 722, 0, 0, 584, 581, 0, 677, 581, 0, 81, 0, 0, 496, 82, 581, 0, 0, 581, 0, 0, 0, 581, 0, 677, 83, 0, 581, 584, 0, 581, 0, 584, 0, 722, 0, 0, 473, 0, 0, 473, 584, 0, 0, 84, 0, 581, 0, 0, 0, 0, 677, 0, 0, 496, 473, 0, 496, 584, 0, 0, 0, 0, 677, 0, 677, 0, 0, 0, 0, 581, 0, 496, 0, 581, 0, 0, 0, 486, 0, 0, 0, 0, 581, 0, 584, 0, 473, 0, 0, 0, 0, 0, 0, 0, 0, 0, 584, 677, 0, 581, 0, 0, 0, 496, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 486, 0, 0, 486, 0, 0, 830, 830, 581, 0, 0, 0, 0, 584, 0, 830, 0, 0, 486, 830, 581, 173, 830, 0, 0, 0, 0, 830, 0, 0, 0, 0, 0, 0, 0, 0, 167, 0, 830, 0, 0, 830, 0, 0, 0, 830, 0, 830, 479, 0, 486, 0, 0, 0, 0, 581, 0, 167, 0, 0, 0, 830, 0, 0, 479, 470, 0, 479, 479, 0, 479, 0, 0, 0, 0, 479, 0, 0, 479, 167, 173, 0, 830, 830, 0, 167, 0, 0, 830, 830, 830, 479, 830, 830, 830, 0, 830, 479, 0, 0, 479, 0, 0, 0, 466, 0, 470, 0, 167, 470, 0, 174, 0, 0, 0, 0, 830, 0, 830, 0, 0, 0, 0, 0, 470, 0, 0, 167, 0, 0, 0, 0, 0, 0, 0, 473, 167, 0, 0, 0, 0, 0, 167, 0, 0, 466, 0, 0, 466, 830, 0, 473, 496, 830, 473, 473, 470, 473, 0, 0, 167, 0, 473, 466, 0, 473, 830, 0, 496, 479, 174, 463, 496, 0, 496, 0, 0, 0, 473, 496, 0, 0, 496, 0, 473, 0, 0, 473, 830, 0, 0, 479, 0, 0, 0, 496, 0, 167, 479, 0, 0, 496, 479, 830, 496, 0, 0, 0, 0, 479, 0, 0, 463, 0, 0, 463, 0, 486, 0, 0, 0, 0, 0, 830, 830, 0, 0, 479, 0, 0, 463, 0, 479, 486, 0, 0, 0, 486, 0, 486, 0, 0, 0, 0, 486, 0, 0, 486, 0, 0, 0, 0, 0, 0, 0, 0, 473, 479, 0, 0, 486, 479, 0, 0, 0, 0, 486, 0, 0, 486, 0, 0, 0, 496, 0, 0, 0, 0, 473, 173, 0, 0, 0, 0, 0, 473, 0, 0, 0, 473, 0, 0, 0, 0, 0, 496, 473, 0, 0, 0, 173, 0, 496, 0, 0, 0, 496, 573, 0, 0, 259, 0, 260, 496, 473, 0, 0, 0, 0, 473, 0, 0, 173, 470, 0, 263, 0, 0, 173, 0, 264, 496, 0, 0, 0, 0, 496, 0, 486, 470, 0, 0, 0, 470, 473, 470, 0, 0, 473, 0, 470, 173, 1209, 470, 0, 0, 0, 0, 0, 0, 486, 496, 466, 0, 0, 496, 470, 486, 0, 174, 173, 486, 470, 0, 0, 470, 0, 0, 486, 173, 0, 466, 466, 6, 466, 173, 0, 0, 0, 466, 174, 0, 466, 0, 1294, 1295, 486, 1296, 0, 0, 1297, 486, 0, 173, 573, 466, 0, 259, 0, 260, 0, 466, 174, 0, 1298, 0, 0, 0, 174, 0, 1299, 0, 263, 0, 0, 0, 486, 264, 0, 463, 486, 0, 0, 0, 0, 0, 0, 0, 0, 0, 173, 174, 0, 0, 470, 0, 0, 0, 463, 463, 0, 463, 0, 0, 0, 0, 463, 0, 573, 463, 174, 259, 0, 260, 0, 0, 470, 0, 0, 174, 0, 0, 463, 470, 0, 174, 263, 470, 463, 0, 1300, 264, 0, 466, 470, 0, 0, 0, 0, 0, 0, 0, 0, 174, 0, 0, 0, 0, 0, 14, 0, 0, 470, 0, 0, 466, 0, 470, 0, 0, 0, 0, 466, 0, 1301, 0, 0, 0, 0, 0, 0, 466, 0, 466, 16, 0, 0, 0, 0, 0, 174, 0, 470, 0, 234, 1302, 470, 0, 0, 0, 0, 466, 166, 235, 262, 0, 466, 259, 0, 260, 463, 0, 0, 0, 0, 0, 0, 236, 0, 0, 569, 0, 263, 237, 238, 0, 0, 264, 0, 0, 0, 0, 463, 0, 0, 466, 0, 0, 0, 463, 0, 0, 570, 0, 0, 0, 0, 0, 1253, 1254, 463, 0, 0, 0, 239, 0, 0, 0, 1259, 1260, 0, 1262, 1263, 0, 0, 0, 0, 0, 463, 1267, 1268, 1269, 1270, 463, 1271, 1272, 1273, 1274, 1275, 1276, 0, 0, 241, 242, 0, 0, 0, 0, 0, 0, 0, 234, 0, 0, 243, 0, 0, 0, 244, 0, 235, 0, 463, 0, 0, 0, 571, 0, 0, 0, 0, 0, 0, 127, 236, 0, 0, 0, 0, 0, 237, 238, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 0, 570, 0, 0, 0, 0, 0, 234, 0, 262, 0, 572, 259, 239, 260, 0, 235, 0, 0, 0, 0, 0, 0, 245, 0, 0, 0, 263, 0, 0, 236, 0, 264, 246, 0, 0, 237, 238, 0, 0, 0, 241, 242, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 243, 0, 570, 0, 244, 0, 0, 0, 251, 0, 0, 0, 571, 0, 239, 0, 0, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 0, 0, 0, 973, 0, 0, 974, 0, 0, 0, 234, 262, 241, 242, 259, 0, 260, 0, 0, 235, 0, 410, 0, 0, 243, 572, 0, 0, 244, 263, 0, 0, 0, 236, 264, 0, 571, 245, 0, 237, 238, 0, 0, 0, 0, 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 239, 0, 0, 0, 0, 251, 0, 0, 0, 572, 0, 0, 0, 0, 252, 253, 254, 255, 256, 257, 258, 245, 0, 0, 0, 0, 0, 0, 241, 242, 0, 246, 0, 0, 0, 0, 0, 0, 0, 0, 243, 0, 0, 0, 244, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 0, 0, 251, 0, 0, 0, 0, 0, 0, 0, 0, 252, 253, 254, 255, 256, 257, 258, 0, 982, 0, 0, 974, 0, 0, 0, 234, 0, 0, 0, 0, 0, 0, 0, 0, 235, 262, 0, 0, 259, 0, 260, 975, 0, 0, 0, 0, 0, 0, 236, 245, 0, 0, 0, 263, 237, 238, 0, 0, 264, 246, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 239, 0, 251, 0, 0, 0, 0, 0, 0, 0, 0, 252, 253, 254, 255, 256, 257, 258, 986, 0, 0, 974, 0, 0, 0, 234, 0, 0, 241, 242, 0, 0, 0, 262, 235, 0, 259, 0, 260, 0, 243, 0, 0, 0, 244, 0, 0, 0, 236, 494, 0, 263, 0, 0, 237, 238, 264, 0, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140, 141, 142, 143, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 239, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 975, 0, 262, 0, 0, 259, 0, 260, 245, 0, 0, 0, 0, 0, 241, 242, 0, 0, 246, 0, 263, 0, 0, 0, 0, 264, 243, 0, 0, 0, 244, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 0, 0, 251, 0, 0, 0, 0, 0, 0, 0, 0, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 0, 0, 0, 994, 0, 0, 974, 0, 0, 0, 234, 0, 0, 0, 0, 0, 0, 975, 262, 235, 0, 259, 0, 260, 0, 245, 0, 0, 0, 0, 0, 0, 0, 236, 516, 246, 263, 0, 517, 237, 238, 264, 0, 0, 0, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 518, 0, 0, 519, 0, 0, 251, 0, 0, 0, 0, 0, 0, 239, 0, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 0, 997, 0, 0, 974, 0, 0, 0, 234, 0, 0, 0, 0, 241, 242, 0, 520, 235, 0, 0, 0, 0, 521, 522, 523, 243, 524, 525, 526, 244, 527, 236, 0, 0, 0, 0, 0, 237, 238, 0, 0, 0, 0, 400, 0, 0, 0, 0, 0, 0, 528, 0, 529, 400, 400, 400, 400, 400, 400, 400, 400, 400, 400, 400, 400, 400, 400, 400, 239, 1002, 0, 0, 974, 0, 0, 0, 234, 0, 0, 0, 0, 0, 0, 530, 975, 235, 262, 0, 0, 259, 0, 260, 245, 0, 0, 0, 241, 242, 0, 236, 531, 0, 246, 0, 263, 237, 238, 0, 243, 264, 0, 0, 244, 0, 0, 0, 247, 248, 249, 250, 161, 162, 532, 0, 0, 0, 0, 0, 0, 0, 251, 0, 262, 0, 261, 259, 239, 260, 0, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 263, 0, 0, 1005, 0, 264, 974, 533, 534, 0, 234, 0, 0, 0, 241, 242, 0, 975, 824, 235, 824, 824, 0, 824, 0, 245, 243, 0, 0, 0, 244, 0, 0, 236, 516, 246, 824, 0, 517, 237, 238, 824, 0, 0, 0, 0, 705, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 518, 0, 0, 519, 0, 0, 251, 0, 0, 0, 0, 0, 0, 239, 0, 252, 253, 254, 255, 256, 257, 258, 262, 0, 0, 259, 0, 260, 975, 0, 0, 0, 0, 0, 0, 0, 245, 0, 0, 0, 263, 241, 242, 0, 520, 264, 246, 0, 0, 0, 521, 522, 523, 243, 524, 525, 526, 244, 527, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 0, 0, 251, 0, 0, 0, 528, 0, 529, 0, 0, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1008, 0, 0, 974, 0, 262, 0, 234, 259, 0, 260, 0, 530, 975, 0, 0, 235, 0, 0, 0, 0, 245, 0, 263, 0, 0, 0, 0, 264, 531, 236, 246, 0, 0, 0, 0, 237, 238, 0, 0, 0, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 532, 0, 234, 0, 0, 0, 0, 0, 251, 0, 0, 235, 0, 0, 0, 224, 239, 252, 253, 254, 255, 256, 257, 258, 0, 236, 0, 0, 0, 0, 0, 237, 238, 0, 0, 533, 534, 0, 824, 0, 0, 0, 0, 0, 241, 242, 0, 824, 0, 0, 0, 0, 262, 634, 0, 259, 243, 260, 0, 0, 244, 824, 239, 0, 0, 0, 0, 824, 824, 0, 263, 0, 0, 0, 0, 264, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 240, 0, 241, 242, 0, 0, 0, 0, 0, 0, 824, 234, 0, 0, 243, 0, 0, 0, 244, 262, 235, 0, 259, 0, 260, 0, 0, 975, 0, 0, 0, 0, 0, 0, 236, 245, 824, 263, 824, 824, 237, 238, 264, 0, 0, 246, 0, 0, 0, 0, 824, 0, 0, 0, 824, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 239, 0, 251, 0, 0, 0, 0, 0, 0, 0, 245, 252, 253, 254, 255, 256, 257, 258, 0, 0, 246, 0, 234, 0, 0, 0, 0, 0, 241, 242, 0, 235, 0, 0, 247, 248, 249, 250, 161, 162, 243, 0, 0, 0, 244, 236, 824, 0, 251, 0, 0, 237, 238, 0, 0, 0, 824, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 824, 824, 824, 824, 824, 824, 0, 0, 0, 0, 0, 0, 239, 0, 824, 0, 0, 0, 0, 0, 0, 410, 0, 824, 824, 824, 824, 824, 824, 824, 0, 0, 0, 0, 0, 0, 0, 245, 240, 0, 241, 242, 0, 0, 0, 0, 0, 246, 0, 0, 234, 0, 243, 0, 0, 0, 244, 0, 0, 235, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 236, 0, 251, 0, 0, 262, 237, 238, 259, 0, 260, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 263, 0, 0, 0, 0, 264, 0, 0, 0, 234, 0, 0, 0, 0, 239, 0, 0, 262, 235, 0, 259, 0, 260, 245, 0, 0, 0, 0, 0, 0, 0, 0, 236, 246, 0, 263, 0, 0, 237, 238, 264, 0, 241, 242, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 243, 0, 0, 0, 244, 0, 0, 251, 0, 0, 0, 0, 0, 0, 0, 239, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 241, 242, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 243, 2, 0, 0, 244, 0, 0, 0, 0, 3, 0, 0, 245, 0, 0, 0, 4, 0, 5, 0, 6, 0, 246, 0, 0, 7, 0, 0, 0, 0, 0, 0, 8, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 9, 0, 0, 0, 251, 824, 0, 0, 824, 0, 824, 10, 0, 252, 253, 254, 255, 256, 257, 258, 0, 245, 0, 824, 0, 0, 0, 0, 824, 0, 0, 246, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1000, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 234, 0, 206, 0, 0, 251, 206, 0, 0, 235, 0, 0, 0, 0, 252, 253, 254, 255, 256, 257, 258, 206, 0, 236, 11, 206, 0, 0, 206, 237, 238, 12, 0, 0, 13, 234, 14, 15, 0, 0, 0, 0, 0, 0, 235, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 236, 0, 239, 16, 0, 0, 237, 238, 632, 420, 418, 206, 419, 0, 421, 0, 0, 206, 206, 206, 0, 206, 206, 206, 0, 206, 0, 804, 803, 805, 241, 242, 0, 0, 0, 0, 0, 239, 0, 0, 0, 0, 243, 0, 0, 206, 244, 206, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 241, 242, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 243, 206, 0, 0, 244, 0, 76, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 206, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 245, 0, 0, 0, 0, 0, 0, 0, 206, 0, 246, 824, 420, 418, 0, 419, 0, 421, 0, 0, 824, 1155, 0, 0, 247, 248, 249, 250, 161, 162, 804, 803, 805, 0, 824, 245, 0, 0, 251, 0, 824, 824, 0, 206, 206, 246, 0, 252, 253, 254, 255, 256, 257, 258, 0, 0, 0, 0, 0, 247, 248, 249, 250, 161, 162, 0, 0, 0, 0, 0, 0, 824, 0, 251, 0, 0, 0, 0, 0, 0, 0, 0, 252, 253, 254, 255, 256, 257, 258, 0, 777, 0, 0, 0, 517, 0, 0, 0, 0, 824, 824, 0, 0, 0, 0, 0, 0, 0, 0, 778, 0, 824, 0, 518, 0, 824, 519, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 791, 0, 0, 0, 0, 0, 0, 0, 416, 0, 0, 0, 0, 0, 417, 0, 0, 792, 0, 0, 0, 0, 0, 0, 0, 0, 0, 520, 0, 0, 0, 0, 0, 521, 522, 523, 0, 524, 525, 526, 0, 527, 0, 0, 0, 0, 0, 0, 824, 0, 0, 0, 0, 793, 0, 0, 0, 0, 824, 0, 0, 528, 794, 529, 0, 0, 0, 0, 0, 0, 795, 0, 824, 824, 824, 824, 824, 824, 0, 0, 0, 0, 0, 0, 0, 0, 824, 0, 0, 796, 0, 797, 0, 0, 530, 824, 824, 824, 824, 824, 824, 824, 0, 0, 0, 798, 0, 799, 800, 801, 0, 531, 791, 0, 0, 0, 0, 0, 0, 0, 416, 516, 0, 0, 0, 517, 417, 0, 0, 792, 0, 0, 0, 532, 0, 0, 0, 206, 0, 0, 0, 206, 0, 0, 518, 0, 0, 519, 0, 0, 0, 0, 0, 0, 0, 0, 206, 0, 802, 0, 206, 0, 0, 206, 0, 793, 0, 0, 533, 534, 0, 0, 0, 0, 794, 0, 0, 0, 0, 0, 0, 0, 795, 120, 0, 0, 0, 120, 520, 0, 0, 0, 0, 0, 521, 522, 523, 0, 524, 525, 526, 796, 527, 797, 206, 0, 120, 0, 0, 120, 206, 206, 206, 0, 206, 206, 206, 798, 206, 799, 800, 801, 528, 0, 529, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1209, 0, 0, 206, 0, 206, 0, 0, 0, 0, 0, 0, 0, 0, 0, 120, 0, 0, 0, 0, 530, 120, 120, 120, 0, 120, 120, 120, 0, 120, 0, 6, 0, 0, 0, 802, 206, 531, 1394, 0, 0, 281, 1294, 1295, 0, 1296, 0, 0, 1297, 120, 0, 120, 0, 206, 0, 0, 0, 0, 0, 532, 0, 0, 1298, 0, 0, 0, 0, 0, 1299, 0, 0, 0, 281, 0, 224, 206, 0, 0, 0, 281, 0, 0, 120, 281, 281, 0, 281, 0, 0, 281, 0, 0, 0, 0, 533, 534, 0, 0, 0, 120, 0, 0, 0, 281, 0, 0, 0, 0, 0, 281, 206, 206, 0, 0, 0, 0, 0, 0, 0, 0, 0, 120, 0, 0, 0, 0, 0, 0, 1300, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 14, 0, 0, 0, 0, 0, 0, 0, 0, 120, 120, 0, 0, 0, 0, 1301, 0, 0, 0, 0, 0, 0, 281, 0, 0, 16, 0, 0, 0, 0, 0, 0, 0, 0, 1395, 0, 1302, 0, 0, 0, 0, 281, 0, 166, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 281, 0, 0, 0, 0, 0, 0, 0, 0, 0, 281, 0, 0, 0, 0, 0, 0, 0, 0, 281, 0, 281, 0, 0, 0, 0, 0, 0, 281, }; static short yycheck[] = { 54, 16, 46, 4, 55, 4, 47, 93, 0, 54, 213, 213, 213, 589, 54, 424, 57, 48, 571, 53, 573, 449, 338, 397, 75, 60, 503, 477, 59, 58, 480, 342, 346, 83, 78, 410, 486, 446, 79, 430, 124, 317, 489, 346, 486, 86, 676, 82, 683, 909, 850, 80, 221, 0, 102, 0, 104, 40, 73, 45, 920, 40, 231, 0, 0, 40, 81, 121, 0, 40, 361, 604, 103, 45, 300, 310, 936, 40, 645, 742, 565, 40, 0, 0, 0, 42, 44, 0, 41, 536, 41, 44, 0, 45, 41, 58, 44, 44, 42, 177, 40, 187, 44, 44, 41, 115, 44, 44, 392, 0, 41, 1189, 59, 147, 59, 680, 44, 693, 0, 44, 946, 1063, 59, 59, 44, 0, 91, 59, 930, 44, 0, 44, 0, 41, 0, 264, 229, 44, 41, 173, 226, 59, 59, 59, 45, 456, 59, 463, 464, 465, 466, 59, 263, 0, 58, 274, 260, 1026, 0, 41, 44, 215, 44, 0, 367, 367, 367, 693, 59, 1019, 215, 1021, 486, 0, 284, 63, 1082, 59, 329, 12, 0, 658, 288, 486, 59, 302, 0, 321, 219, 59, 1426, 59, 258, 59, 268, 378, 40, 44, 229, 347, 511, 45, 313, 260, 45, 313, 45, 0, 0, 686, 687, 380, 59, 324, 0, 0, 277, 59, 1122, 257, 304, 264, 59, 418, 63, 516, 265, 41, 1204, 326, 321, 1091, 59, 406, 444, 388, 419, 0, 459, 59, 284, 307, 288, 418, 456, 59, 300, 378, 59, 303, 445, 461, 425, 806, 807, 300, 41, 288, 303, 44, 707, 59, 1238, 1499, 303, 486, 59, 59, 316, 12, 445, 325, 0, 59, 59, 323, 109, 309, 728, 327, 325, 429, 330, 466, 0, 346, 1522, 0, 441, 736, 823, 858, 366, 444, 278, 0, 59, 335, 672, 832, 833, 394, 285, 437, 388, 339, 1108, 341, 1214, 0, 461, 0, 277, 357, 418, 262, 41, 428, 449, 353, 0, 274, 258, 607, 355, 41, 443, 264, 44, 269, 440, 59, 461, 1183, 431, 1413, 320, 0, 379, 1243, 297, 438, 1284, 59, 897, 376, 59, 1207, 467, 264, 1210, 392, 1212, 419, 59, 461, 387, 310, 389, 750, 361, 418, 470, 394, 1027, 0, 109, 0, 59, 412, 59, 307, 319, 321, 1452, 322, 258, 1237, 41, 59, 305, 44, 329, 321, 321, 332, 589, 589, 589, 336, 400, 956, 274, 1219, 341, 41, 59, 344, 0, 319, 332, 332, 978, 41, 0, 483, 41, 310, 278, 1278, 280, 319, 278, 360, 280, 461, 329, 401, 403, 332, 452, 258, 264, 341, 59, 307, 59, 461, 310, 598, 273, 344, 41, 341, 1097, 1070, 395, 384, 486, 41, 387, 388, 461, 384, 264, 41, 397, 673, 1250, 58, 397, 278, 113, 280, 828, 690, 933, 59, 442, 412, 907, 329, 59, 59, 332, 397, 397, 414, 1328, 448, 307, 918, 506, 459, 349, 504, 961, 1337, 461, 437, 388, 397, 329, 419, 397, 332, 461, 459, 935, 397, 461, 693, 693, 784, 441, 1062, 441, 344, 461, 775, 486, 437, 1035, 557, 461, 319, 453, 459, 455, 441, 455, 1064, 557, 455, 467, 516, 453, 461, 332, 410, 554, 555, 0, 455, 461, 441, 1102, 341, 441, 397, 412, 459, 1085, 441, 319, 471, 590, 419, 455, 455, 453, 488, 455, 329, 329, 590, 332, 332, 455, 1349, 397, 343, 379, 258, 1414, 437, 341, 461, 459, 344, 461, 837, 278, 41, 280, 566, 607, 566, 1203, 453, 886, 459, 288, 441, 388, 368, 1102, 952, 398, 259, 488, 59, 419, 397, 264, 467, 378, 455, 432, 471, 270, 432, 41, 432, 441, 1072, 1038, 1074, 259, 260, 411, 262, 307, 388, 329, 368, 453, 332, 455, 1280, 604, 397, 397, 411, 406, 459, 262, 409, 459, 673, 459, 349, 1078, 41, 262, 679, 680, 441, 673, 559, 343, 947, 0, 425, 679, 680, 667, 1114, 669, 0, 0, 1050, 1089, 42, 813, 41, 0, 816, 682, 683, 341, 699, 341, 1283, 856, 441, 441, 1113, 461, 451, 689, 0, 262, 379, 357, 378, 259, 453, 453, 455, 42, 1118, 397, 41, 488, 47, 44, 270, 265, 727, 728, 1257, 288, 959, 319, 401, 319, 1310, 461, 714, 44, 59, 408, 406, 329, 301, 409, 332, 59, 59, 1370, 435, 786, 488, 788, 59, 341, 302, 341, 1100, 257, 0, 425, 320, 419, 1106, 303, 319, 398, 461, 59, 384, 273, 319, 1038, 726, 442, 461, 302, 1282, 0, 760, 761, 762, 735, 1038, 397, 430, 451, 341, 401, 387, 773, 398, 339, 341, 747, 287, 44, 387, 0, 338, 41, 388, 415, 44, 417, 418, 419, 420, 421, 422, 397, 1138, 425, 339, 258, 817, 0, 1216, 59, 41, 702, 814, 44, 978, 284, 978, 0, 1450, 815, 711, 437, 784, 260, 1213, 388, 387, 335, 59, 341, 41, 388, 357, 401, 397, 344, 93, 1245, 1227, 1408, 397, 461, 857, 349, 1116, 441, 1181, 1285, 59, 44, 44, 1289, 262, 260, 307, 471, 1487, 1489, 410, 455, 369, 1025, 1026, 1027, 59, 0, 59, 304, 823, 394, 0, 396, 1386, 764, 442, 1389, 59, 832, 441, 1448, 319, 44, 1293, 262, 441, 406, 1517, 443, 1425, 344, 329, 1475, 488, 332, 419, 302, 0, 280, 455, 93, 260, 0, 341, 286, 0, 262, 41, 314, 443, 44, 42, 43, 1329, 45, 369, 47, 385, 1486, 427, 444, 1504, 1505, 1459, 1200, 59, 41, 912, 913, 44, 59, 93, 488, 339, 262, 949, 41, 457, 41, 44, 1102, 1102, 956, 41, 949, 304, 41, 1530, 280, 44, 388, 956, 573, 942, 286, 0, 59, 462, 463, 397, 1543, 59, 462, 463, 59, 1501, 927, 419, 927, 958, 1339, 956, 440, 427, 0, 964, 0, 0, 387, 0, 329, 42, 43, 1420, 45, 437, 47, 608, 609, 457, 611, 319, 613, 0, 322, 616, 617, 618, 619, 620, 621, 329, 408, 441, 332, 319, 16, 461, 336, 387, 631, 461, 418, 341, 59, 453, 344, 406, 44, 471, 279, 40, 343, 1536, 44, 0, 45, 341, 1190, 919, 461, 387, 360, 59, 0, 59, 59, 443, 59, 58, 353, 41, 42, 43, 343, 45, 459, 47, 1417, 1063, 488, 672, 59, 322, 403, 461, 384, 378, 1063, 387, 388, 0, 0, 73, 1025, 1026, 379, 336, 457, 397, 319, 330, 301, 93, 260, 344, 1070, 41, 44, 378, 44, 461, 0, 332, 59, 406, 414, 63, 409, 319, 439, 360, 341, 59, 1257, 444, 1257, 461, 0, 329, 404, 450, 332, 41, 425, 364, 44, 406, 84, 319, 409, 341, 461, 441, 344, 1278, 302, 421, 322, 329, 59, 59, 332, 382, 353, 453, 425, 455, 314, 93, 451, 341, 336, 459, 1095, 1129, 1095, 319, 1132, 388, 344, 59, 0, 0, 278, 414, 280, 41, 397, 280, 44, 343, 451, 339, 288, 286, 360, 59, 388, 341, 488, 1410, 259, 41, 323, 349, 44, 397, 338, 461, 791, 792, 793, 270, 358, 796, 797, 798, 388, 800, 801, 802, 803, 804, 805, 0, 44, 397, 42, 43, 321, 45, 441, 47, 1208, 1209, 0, 1446, 459, 93, 461, 59, 59, 1208, 1209, 375, 455, 828, 1208, 1203, 414, 441, 0, 0, 406, 322, 319, 409, 388, 280, 841, 319, 408, 453, 319, 286, 1217, 322, 849, 336, 851, 441, 418, 425, 329, 856, 1485, 332, 341, 488, 461, 336, 0, 341, 59, 379, 341, 323, 260, 344, 384, 312, 196, 360, 402, 59, 272, 443, 488, 451, 204, 0, 0, 1425, 1425, 360, 1515, 401, 0, 0, 1284, 59, 59, 289, 408, 317, 318, 296, 488, 1284, 280, 1327, 384, 1294, 41, 388, 286, 44, 343, 384, 388, 0, 304, 388, 397, 40, 1310, 1459, 1459, 265, 0, 59, 397, 41, 279, 1310, 44, 414, 442, 40, 41, 42, 43, 44, 45, 46, 47, 1278, 334, 414, 59, 59, 466, 378, 468, 0, 301, 59, 59, 60, 61, 62, 1323, 0, 353, 0, 260, 303, 441, 1501, 1501, 41, 44, 441, 44, 1297, 441, 363, 384, 1343, 59, 406, 1346, 319, 409, 330, 0, 1403, 453, 59, 91, 461, 93, 1338, 260, 0, 461, 322, 989, 990, 425, 992, 993, 379, 349, 341, 41, 386, 1392, 1000, 304, 336, 1383, 358, 59, 41, 384, 1392, 44, 364, 384, 302, 59, 488, 59, 401, 451, 41, 42, 43, 44, 45, 408, 47, 260, 360, 258, 382, 304, 261, 0, 1425, 1426, 0, 430, 59, 60, 61, 62, 338, 1425, 1426, 0, 1434, 59, 0, 280, 419, 339, 384, 0, 461, 286, 1408, 0, 41, 442, 274, 44, 458, 459, 460, 461, 462, 463, 1459, 0, 1422, 304, 93, 0, 0, 392, 393, 1459, 307, 1470, 319, 312, 414, 1081, 1475, 481, 482, 322, 1470, 40, 486, 487, 59, 1475, 329, 59, 1448, 332, 1436, 425, 1436, 336, 1454, 41, 59, 462, 44, 59, 1499, 344, 1501, 264, 59, 1504, 1505, 1496, 59, 1499, 46, 1501, 408, 1119, 1504, 1505, 41, 360, 41, 44, 59, 44, 418, 1522, 59, 59, 1486, 41, 319, 1135, 44, 1530, 1522, 1493, 41, 338, 0, 44, 677, 678, 1530, 384, 1148, 317, 1543, 0, 262, 443, 264, 1155, 1019, 338, 1021, 1543, 397, 278, 272, 280, 42, 43, 461, 45, 285, 47, 280, 288, 41, 462, 463, 44, 286, 414, 375, 289, 41, 1181, 419, 44, 301, 41, 0, 0, 44, 337, 1190, 388, 41, 41, 453, 44, 44, 462, 463, 403, 341, 59, 312, 403, 441, 321, 319, 384, 384, 319, 59, 321, 322, 40, 40, 325, 453, 40, 455, 329, 42, 43, 332, 45, 334, 47, 336, 41, 462, 40, 44, 341, 342, 40, 344, 462, 41, 42, 43, 262, 45, 264, 47, 40, 40, 59, 59, 40, 40, 272, 360, 361, 396, 363, 398, 1255, 462, 280, 402, 403, 404, 40, 379, 286, 1264, 1265, 289, 377, 461, 379, 380, 381, 91, 321, 384, 319, 44, 387, 388, 458, 459, 460, 46, 437, 401, 362, 451, 397, 332, 312, 435, 408, 418, 443, 358, 288, 319, 341, 321, 322, 1300, 322, 325, 412, 414, 44, 329, 486, 487, 332, 470, 334, 61, 336, 373, 336, 287, 295, 341, 342, 430, 344, 40, 264, 40, 442, 0, 44, 306, 437, 461, 441, 321, 44, 403, 313, 0, 360, 361, 360, 363, 41, 1342, 453, 388, 455, 41, 42, 43, 461, 45, 461, 47, 397, 377, 453, 379, 380, 381, 461, 338, 384, 44, 384, 387, 388, 429, 41, 42, 43, 44, 45, 61, 47, 397, 280, 40, 41, 488, 44, 44, 383, 349, 44, 262, 59, 60, 61, 62, 278, 301, 414, 264, 414, 461, 59, 437, 441, 42, 43, 258, 45, 280, 47, 398, 471, 398, 430, 286, 0, 459, 455, 277, 400, 448, 59, 448, 40, 441, 93, 40, 279, 91, 350, 40, 403, 264, 91, 42, 43, 453, 45, 455, 47, 40, 412, 384, 44, 461, 390, 262, 383, 40, 301, 488, 1392, 40, 437, 262, 307, 41, 42, 43, 44, 45, 465, 47, 435, 280, 318, 40, 439, 264, 41, 286, 488, 279, 321, 59, 60, 61, 62, 330, 322, 321, 280, 44, 321, 1425, 1426, 329, 286, 280, 332, 40, 44, 329, 336, 301, 449, 40, 349, 277, 274, 459, 344, 0, 40, 40, 357, 358, 285, 93, 45, 345, 319, 364, 278, 322, 345, 419, 360, 1459, 417, 301, 329, 419, 330, 332, 40, 357, 63, 336, 1470, 382, 418, 40, 341, 40, 461, 344, 44, 321, 386, 368, 384, 349, 41, 42, 43, 44, 45, 44, 47, 41, 358, 360, 389, 397, 389, 389, 364, 1499, 344, 1501, 59, 60, 61, 62, 274, 332, 419, 44, 266, 300, 414, 40, 264, 45, 382, 384, 461, 430, 387, 388, 1522, 41, 423, 58, 41, 41, 41, 455, 397, 441, 280, 63, 395, 262, 93, 264, 286, 441, 41, 258, 41, 310, 310, 272, 40, 414, 40, 353, 40, 453, 40, 455, 40, 40, 40, 274, 40, 286, 277, 278, 289, 280, 40, 40, 40, 40, 285, 40, 40, 288, 40, 40, 441, 262, 328, 41, 44, 279, 461, 0, 423, 280, 301, 312, 453, 392, 455, 286, 307, 391, 319, 310, 321, 322, 271, 288, 325, 447, 488, 301, 329, 41, 379, 332, 0, 334, 41, 336, 408, 40, 278, 280, 341, 342, 41, 344, 262, 286, 264, 488, 41, 41, 43, 44, 45, 418, 272, 41, 330, 386, 280, 360, 361, 44, 363, 40, 437, 397, 59, 60, 61, 62, 41, 289, 41, 353, 386, 349, 377, 321, 379, 380, 381, 356, 372, 384, 358, 372, 387, 388, 379, 41, 364, 59, 41, 41, 312, 41, 397, 41, 403, 41, 93, 319, 45, 321, 322, 41, 41, 325, 382, 41, 401, 329, 41, 414, 332, 41, 334, 408, 336, 41, 41, 412, 41, 341, 342, 41, 344, 296, 419, 430, 796, 262, 798, 264, 800, 801, 41, 803, 804, 805, 441, 272, 360, 361, 59, 363, 437, 40, 341, 59, 40, 442, 453, 59, 455, 59, 0, 341, 289, 377, 461, 379, 380, 381, 59, 59, 384, 41, 353, 387, 388, 345, 369, 40, 341, 59, 467, 59, 384, 397, 471, 312, 44, 461, 353, 384, 384, 488, 319, 41, 321, 322, 296, 344, 325, 0, 414, 41, 329, 41, 44, 332, 41, 334, 41, 336, 44, 411, 44, 436, 341, 342, 430, 344, 305, 59, 41, 42, 43, 302, 45, 40, 47, 441, 443, 59, 305, 294, 464, 360, 361, 44, 363, 44, 308, 453, 41, 455, 41, 44, 0, 0, 338, 461, 40, 264, 377, 45, 379, 380, 381, 384, 384, 384, 59, 278, 387, 388, 321, 264, 58, 41, 42, 43, 390, 45, 397, 47, 459, 262, 488, 264, 40, 264, 412, 471, 310, 459, 437, 272, 264, 271, 41, 414, 43, 44, 45, 344, 459, 458, 459, 460, 344, 462, 463, 271, 289, 41, 344, 430, 59, 60, 61, 62, 40, 344, 41, 40, 59, 41, 441, 279, 481, 482, 418, 41, 305, 486, 487, 312, 59, 0, 453, 0, 455, 0, 319, 1022, 321, 322, 461, 12, 325, 301, 93, 231, 329, 223, 598, 332, 444, 334, 222, 336, 561, 776, 961, 77, 341, 342, 959, 344, 1102, 296, 458, 459, 460, 488, 462, 463, 948, 956, 330, 1228, 343, 511, 940, 360, 361, 308, 363, 889, 949, 708, 325, 260, 709, 481, 482, 0, 325, 349, 486, 487, 377, 1214, 379, 380, 381, 357, 358, 384, 1441, 1216, 387, 388, 364, 41, 42, 43, 1445, 45, 1479, 47, 397, 41, 42, 43, 349, 45, 353, 47, 1079, 491, 382, 0, 1444, 302, 699, 1459, 41, 414, 43, 44, 45, 1408, 394, 1529, 396, 314, 1397, 1119, 1476, 367, 278, 558, 280, 430, 59, 60, 61, 62, 951, 328, 288, 318, 771, 330, 441, 1239, 493, 419, 311, 258, 339, 280, 41, 301, 757, 44, 453, 286, 455, 549, 1104, 749, 0, 13, 461, 292, 432, 436, 93, 278, 59, 280, 444, 667, 679, 426, 285, 645, 1284, 288, 1493, 425, 1287, 1190, 41, 42, 43, 1454, 45, 0, 47, 488, 301, 603, 296, 1545, 280, 444, 307, 262, 991, 264, 286, 41, 446, 43, 44, 45, 829, 272, 422, 458, 459, 460, 366, 462, 463, -1, -1, 408, 1257, 59, 60, 61, 62, -1, 289, -1, -1, 418, 41, 379, -1, 44, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, 0, -1, -1, 59, 312, -1, 353, -1, 401, 443, 93, 319, -1, 321, 322, 408, -1, 325, -1, -1, -1, 329, -1, -1, 332, 379, 334, 461, 336, -1, 45, -1, -1, 341, 342, -1, 344, -1, -1, -1, -1, 41, -1, -1, 44, -1, -1, 401, 63, 442, -1, -1, 360, 361, 408, 363, -1, -1, -1, 59, -1, -1, -1, -1, -1, 419, -1, -1, -1, 377, -1, 379, 380, 381, -1, -1, 384, 0, -1, 387, 388, -1, -1, 437, -1, -1, -1, 280, 442, 397, -1, -1, 262, 286, 264, 280, -1, -1, -1, -1, -1, 286, 272, 41, 42, 43, 414, 45, -1, 47, -1, 458, 459, 460, 461, 462, 463, 471, 41, 289, -1, 44, 430, 41, 42, 43, -1, 45, -1, 47, -1, -1, 295, 441, 481, 482, 59, -1, -1, 486, 487, 0, 312, 306, 278, 453, 280, 455, -1, 319, 313, 321, 322, 461, 288, 325, -1, -1, -1, 329, -1, 0, 332, 326, 334, -1, 336, 301, -1, -1, -1, 341, 342, -1, 344, -1, -1, -1, 280, 262, 488, 264, 41, -1, 286, 44, -1, -1, -1, 272, 360, 361, -1, 363, -1, -1, -1, -1, -1, -1, 59, -1, 41, -1, -1, 44, 289, 377, -1, 379, 380, 381, -1, -1, 384, -1, -1, 387, 388, -1, 59, -1, 278, -1, 280, 0, -1, 397, -1, 312, -1, -1, 288, -1, -1, -1, 319, -1, 321, 322, 403, -1, 325, -1, 414, 379, 329, -1, 0, 332, -1, 334, -1, 336, -1, -1, -1, 420, 341, 342, 430, 344, 262, -1, -1, -1, 41, 401, -1, 44, -1, 441, 435, -1, 408, -1, 439, 360, 361, 442, 363, 296, -1, 453, 59, 455, -1, 450, -1, 41, -1, 461, 44, -1, 377, -1, 379, 380, 381, -1, -1, 384, -1, -1, 387, 388, 469, 59, 442, -1, -1, -1, 0, -1, 397, -1, -1, -1, 488, 319, -1, -1, 322, 379, -1, -1, -1, -1, -1, 329, -1, 414, 332, -1, -1, 0, 336, -1, 353, 262, -1, 341, 280, -1, 344, 401, -1, 430, 286, -1, -1, -1, 408, 41, -1, -1, 44, -1, 441, -1, 360, -1, 280, -1, -1, -1, -1, -1, 286, -1, 453, 59, 455, -1, -1, -1, 41, -1, 461, 44, -1, -1, -1, -1, 384, -1, 442, 387, 388, -1, 0, -1, -1, -1, 59, -1, 319, 397, 0, 322, -1, -1, -1, 262, -1, 488, 329, -1, -1, 332, -1, -1, -1, 336, 414, -1, -1, -1, 341, -1, -1, 344, -1, 262, 41, 42, 43, -1, 45, -1, 47, 41, -1, -1, 44, -1, -1, 360, -1, 41, -1, 441, 44, 458, 459, 460, -1, 462, 463, 59, -1, -1, -1, 453, -1, 455, -1, 59, -1, -1, 319, 384, -1, 322, 387, 388, 481, 482, -1, -1, 329, 486, 487, 332, 397, 0, 0, 336, -1, -1, 319, -1, 341, 322, -1, 344, -1, 262, 488, -1, 329, 414, -1, 332, -1, -1, -1, 336, -1, -1, -1, 360, 341, -1, -1, 344, -1, -1, 45, -1, 262, -1, -1, -1, -1, -1, 41, 41, 441, 44, 44, 360, -1, -1, -1, 384, 63, -1, 387, 388, 453, -1, 455, -1, 59, 59, -1, -1, 397, -1, -1, -1, -1, -1, 319, 384, -1, 322, 387, 388, -1, -1, -1, -1, 329, 414, -1, 332, 397, 0, 0, 336, -1, -1, -1, 488, 341, 319, -1, 344, 322, -1, -1, -1, 262, 414, -1, 329, 0, -1, 332, -1, 441, -1, 336, 360, -1, -1, -1, 341, -1, -1, 344, -1, 453, -1, 455, 262, -1, -1, 41, 41, 441, 44, 44, -1, -1, -1, 360, 384, -1, -1, 387, 388, 453, -1, 455, -1, 59, 59, -1, -1, 397, -1, -1, -1, -1, -1, -1, 488, -1, 319, 384, -1, 322, 387, 388, 59, -1, 414, -1, 329, -1, 0, 332, 397, -1, -1, 336, 488, -1, -1, -1, 341, 319, -1, 344, 322, -1, -1, 262, -1, 414, 280, 329, -1, 441, 332, 278, 286, 280, 336, 360, -1, -1, -1, 341, -1, 453, 344, 455, -1, -1, -1, 41, -1, -1, 44, -1, 441, -1, -1, -1, -1, -1, 360, 384, -1, -1, 387, 388, 453, 59, 455, -1, -1, -1, 0, -1, 397, -1, -1, -1, 488, -1, -1, -1, 319, -1, 384, 322, -1, 387, 388, -1, -1, 414, 329, -1, -1, 332, -1, 397, -1, 336, -1, 488, 262, -1, 341, -1, -1, 344, -1, -1, -1, -1, -1, 41, 414, -1, 44, -1, 441, 278, -1, 280, -1, 360, 296, -1, 285, -1, -1, 288, 453, 59, 455, -1, 379, -1, -1, -1, -1, -1, -1, 441, 301, -1, -1, -1, -1, 384, 0, 0, 387, 388, -1, 453, -1, 455, 401, -1, -1, 319, 397, -1, 322, 408, -1, 488, -1, -1, -1, 329, -1, 0, 332, 0, -1, -1, 336, 414, -1, -1, -1, 341, 0, -1, 344, -1, 262, -1, 488, 41, 41, -1, 44, 44, -1, -1, -1, 442, -1, -1, 360, 258, -1, 278, 441, 280, -1, 59, 59, -1, -1, -1, 41, 288, 41, 44, 453, 44, 455, -1, 379, -1, 279, 41, 384, -1, 44, 387, 388, -1, 59, -1, 59, -1, 41, 42, 43, 397, 45, -1, 47, 59, 401, 319, 301, -1, 322, -1, -1, 408, 307, 488, -1, 329, 414, -1, 332, -1, 0, -1, 336, -1, -1, -1, -1, 341, -1, -1, 344, -1, 262, -1, 444, 330, -1, -1, -1, -1, -1, -1, -1, 441, -1, 442, 360, -1, 458, 459, 460, -1, 462, 463, 349, 453, -1, 455, -1, -1, -1, 41, -1, 358, 44, -1, 379, -1, -1, 364, 384, 481, 482, 387, 388, -1, 486, 487, -1, 59, -1, -1, -1, 397, 0, -1, -1, 382, 401, 319, 488, -1, 322, -1, -1, 408, 262, -1, -1, 329, 414, -1, 332, -1, -1, -1, 336, -1, -1, -1, -1, 341, -1, -1, 344, 41, 42, 43, 0, 45, -1, 47, -1, -1, 419, 41, -1, 441, 44, 442, 360, 473, 474, 475, 476, 477, 478, 479, 480, 453, -1, 455, -1, 59, -1, 41, 42, 43, -1, 45, -1, 47, -1, 319, 384, -1, 322, 387, 388, 41, 0, -1, 44, 329, -1, -1, 332, 397, -1, -1, 336, -1, 262, -1, 488, 341, -1, 59, 344, -1, -1, -1, -1, -1, 414, -1, -1, -1, -1, 278, -1, 280, -1, -1, 360, 262, -1, -1, -1, 288, -1, 41, -1, -1, 44, -1, 262, -1, -1, -1, -1, 441, -1, 278, -1, 280, -1, -1, 384, 59, -1, 387, 388, 453, -1, 455, -1, -1, -1, 319, -1, 397, 322, -1, -1, 280, -1, -1, -1, 329, -1, 286, 332, -1, -1, -1, 336, -1, 414, -1, -1, 341, 319, -1, 344, 322, -1, -1, 488, -1, -1, -1, 329, 319, -1, 332, 322, -1, -1, 336, 360, -1, -1, 329, 341, 441, 332, 344, -1, -1, 336, -1, 262, -1, -1, 341, -1, 453, 344, 455, 379, -1, -1, 360, 384, -1, -1, 387, 388, -1, -1, -1, -1, -1, 360, -1, -1, 397, -1, -1, -1, -1, 401, -1, 379, -1, -1, 384, -1, 408, 387, 388, 488, -1, 414, -1, -1, -1, 384, -1, 397, 387, 388, -1, -1, 0, 401, -1, -1, 319, -1, 397, 322, 408, -1, -1, -1, 414, -1, 329, -1, 441, 332, 442, 280, 306, 336, -1, 414, -1, 286, 341, 313, 453, 344, 455, 317, 318, -1, -1, -1, 0, -1, -1, 441, -1, 41, 442, -1, 44, 360, 46, -1, 0, 280, 441, 453, 338, 455, -1, 286, -1, -1, -1, 59, -1, 61, 453, 488, 455, -1, -1, -1, 319, 384, -1, 322, 387, 388, -1, -1, -1, 41, 329, -1, 44, 332, 397, -1, -1, 336, 488, -1, 40, 41, 341, -1, 44, 344, -1, 59, -1, 488, -1, 414, -1, -1, 319, -1, -1, 322, -1, 59, -1, 360, -1, -1, 329, -1, -1, 332, -1, 403, -1, 336, -1, -1, -1, -1, 341, -1, 441, 344, -1, -1, -1, -1, -1, 384, 420, 0, 387, 388, 453, 91, 455, -1, -1, 360, 319, -1, 397, 322, -1, 435, -1, -1, 0, 439, 329, -1, -1, 332, -1, -1, -1, 336, -1, 414, 450, -1, 341, 384, -1, 344, -1, 388, -1, 488, -1, -1, 41, -1, -1, 44, 397, -1, -1, 469, -1, 360, -1, -1, -1, -1, 441, -1, -1, 41, 59, -1, 44, 414, -1, -1, -1, -1, 453, -1, 455, -1, -1, -1, -1, 384, -1, 59, -1, 388, -1, -1, -1, 0, -1, -1, -1, -1, 397, -1, 441, -1, 91, -1, -1, -1, -1, -1, -1, -1, -1, -1, 453, 488, -1, 414, -1, -1, -1, 91, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 41, -1, -1, 44, -1, -1, 264, 265, 441, -1, -1, -1, -1, 488, -1, 273, -1, -1, 59, 277, 453, 0, 280, -1, -1, -1, -1, 285, -1, -1, -1, -1, -1, -1, -1, -1, 258, -1, 296, -1, -1, 299, -1, -1, -1, 303, -1, 305, 258, -1, 91, -1, -1, -1, -1, 488, -1, 279, -1, -1, -1, 319, -1, -1, 274, 0, -1, 277, 278, -1, 280, -1, -1, -1, -1, 285, -1, -1, 288, 301, 59, -1, 340, 341, -1, 307, -1, -1, 346, 347, 348, 301, 350, 351, 352, -1, 354, 307, -1, -1, 310, -1, -1, -1, 0, -1, 41, -1, 330, 44, -1, 0, -1, -1, -1, -1, 374, -1, 376, -1, -1, -1, -1, -1, 59, -1, -1, 349, -1, -1, -1, -1, -1, -1, -1, 258, 358, -1, -1, -1, -1, -1, 364, -1, -1, 41, -1, -1, 44, 407, -1, 274, 258, 411, 277, 278, 91, 280, -1, -1, 382, -1, 285, 59, -1, 288, 424, -1, 274, 379, 59, 0, 278, -1, 280, -1, -1, -1, 301, 285, -1, -1, 288, -1, 307, -1, -1, 310, 446, -1, -1, 401, -1, -1, -1, 301, -1, 419, 408, -1, -1, 307, 412, 461, 310, -1, -1, -1, -1, 419, -1, -1, 41, -1, -1, 44, -1, 258, -1, -1, -1, -1, -1, 481, 482, -1, -1, 437, -1, -1, 59, -1, 442, 274, -1, -1, -1, 278, -1, 280, -1, -1, -1, -1, 285, -1, -1, 288, -1, -1, -1, -1, -1, -1, -1, -1, 379, 467, -1, -1, 301, 471, -1, -1, -1, -1, 307, -1, -1, 310, -1, -1, -1, 379, -1, -1, -1, -1, 401, 258, -1, -1, -1, -1, -1, 408, -1, -1, -1, 412, -1, -1, -1, -1, -1, 401, 419, -1, -1, -1, 279, -1, 408, -1, -1, -1, 412, 40, -1, -1, 43, -1, 45, 419, 437, -1, -1, -1, -1, 442, -1, -1, 301, 258, -1, 58, -1, -1, 307, -1, 63, 437, -1, -1, -1, -1, 442, -1, 379, 274, -1, -1, -1, 278, 467, 280, -1, -1, 471, -1, 285, 330, 271, 288, -1, -1, -1, -1, -1, -1, 401, 467, 258, -1, -1, 471, 301, 408, -1, 258, 349, 412, 307, -1, -1, 310, -1, -1, 419, 358, -1, 277, 278, 302, 280, 364, -1, -1, -1, 285, 279, -1, 288, -1, 313, 314, 437, 316, -1, -1, 319, 442, -1, 382, 40, 301, -1, 43, -1, 45, -1, 307, 301, -1, 333, -1, -1, -1, 307, -1, 339, -1, 58, -1, -1, -1, 467, 63, -1, 258, 471, -1, -1, -1, -1, -1, -1, -1, -1, -1, 419, 330, -1, -1, 379, -1, -1, -1, 277, 278, -1, 280, -1, -1, -1, -1, 285, -1, 40, 288, 349, 43, -1, 45, -1, -1, 401, -1, -1, 358, -1, -1, 301, 408, -1, 364, 58, 412, 307, -1, 399, 63, -1, 379, 419, -1, -1, -1, -1, -1, -1, -1, -1, 382, -1, -1, -1, -1, -1, 418, -1, -1, 437, -1, -1, 401, -1, 442, -1, -1, -1, -1, 408, -1, 433, -1, -1, -1, -1, -1, -1, 417, -1, 419, 443, -1, -1, -1, -1, -1, 419, -1, 467, -1, 267, 454, 471, -1, -1, -1, -1, 437, 461, 276, 40, -1, 442, 43, -1, 45, 379, -1, -1, -1, -1, -1, -1, 290, -1, -1, 293, -1, 58, 296, 297, -1, -1, 63, -1, -1, -1, -1, 401, -1, -1, 471, -1, -1, -1, 408, -1, -1, 315, -1, -1, -1, -1, -1, 1136, 1137, 419, -1, -1, -1, 327, -1, -1, -1, 1146, 1147, -1, 1149, 1150, -1, -1, -1, -1, -1, 437, 1157, 1158, 1159, 1160, 442, 1162, 1163, 1164, 1165, 1166, 1167, -1, -1, 355, 356, -1, -1, -1, -1, -1, -1, -1, 267, -1, -1, 367, -1, -1, -1, 371, -1, 276, -1, 471, -1, -1, -1, 379, -1, -1, -1, -1, -1, -1, 461, 290, -1, -1, -1, -1, -1, 296, 297, 470, 471, 472, 473, 474, 475, 476, 477, 478, 479, 480, 481, 482, 483, 484, 485, -1, 315, -1, -1, -1, -1, -1, 267, -1, 40, -1, 422, 43, 327, 45, -1, 276, -1, -1, -1, -1, -1, -1, 434, -1, -1, -1, 58, -1, -1, 290, -1, 63, 444, -1, -1, 296, 297, -1, -1, -1, 355, 356, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, 367, -1, 315, -1, 371, -1, -1, -1, 472, -1, -1, -1, 379, -1, 327, -1, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, -1, -1, -1, 260, -1, -1, 263, -1, -1, -1, 267, 40, 355, 356, 43, -1, 45, -1, -1, 276, -1, 418, -1, -1, 367, 422, -1, -1, 371, 58, -1, -1, -1, 290, 63, -1, 379, 434, -1, 296, 297, -1, -1, -1, -1, -1, -1, 444, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, 327, -1, -1, -1, -1, 472, -1, -1, -1, 422, -1, -1, -1, -1, 481, 482, 483, 484, 485, 486, 487, 434, -1, -1, -1, -1, -1, -1, 355, 356, -1, 444, -1, -1, -1, -1, -1, -1, -1, -1, 367, -1, -1, -1, 371, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, -1, -1, 472, -1, -1, -1, -1, -1, -1, -1, -1, 481, 482, 483, 484, 485, 486, 487, -1, 260, -1, -1, 263, -1, -1, -1, 267, -1, -1, -1, -1, -1, -1, -1, -1, 276, 40, -1, -1, 43, -1, 45, 426, -1, -1, -1, -1, -1, -1, 290, 434, -1, -1, -1, 58, 296, 297, -1, -1, 63, 444, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, 327, -1, 472, -1, -1, -1, -1, -1, -1, -1, -1, 481, 482, 483, 484, 485, 486, 487, 260, -1, -1, 263, -1, -1, -1, 267, -1, -1, 355, 356, -1, -1, -1, 40, 276, -1, 43, -1, 45, -1, 367, -1, -1, -1, 371, -1, -1, -1, 290, 461, -1, 58, -1, -1, 296, 297, 63, -1, 470, 471, 472, 473, 474, 475, 476, 477, 478, 479, 480, 481, 482, 483, 484, 485, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 327, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 426, -1, 40, -1, -1, 43, -1, 45, 434, -1, -1, -1, -1, -1, 355, 356, -1, -1, 444, -1, 58, -1, -1, -1, -1, 63, 367, -1, -1, -1, 371, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, -1, -1, 472, -1, -1, -1, -1, -1, -1, -1, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, -1, -1, -1, 260, -1, -1, 263, -1, -1, -1, 267, -1, -1, -1, -1, -1, -1, 426, 40, 276, -1, 43, -1, 45, -1, 434, -1, -1, -1, -1, -1, -1, -1, 290, 273, 444, 58, -1, 277, 296, 297, 63, -1, -1, -1, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, 296, -1, -1, 299, -1, -1, 472, -1, -1, -1, -1, -1, -1, 327, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, -1, 260, -1, -1, 263, -1, -1, -1, 267, -1, -1, -1, -1, 355, 356, -1, 340, 276, -1, -1, -1, -1, 346, 347, 348, 367, 350, 351, 352, 371, 354, 290, -1, -1, -1, -1, -1, 296, 297, -1, -1, -1, -1, 461, -1, -1, -1, -1, -1, -1, 374, -1, 376, 471, 472, 473, 474, 475, 476, 477, 478, 479, 480, 481, 482, 483, 484, 485, 327, 260, -1, -1, 263, -1, -1, -1, 267, -1, -1, -1, -1, -1, -1, 407, 426, 276, 40, -1, -1, 43, -1, 45, 434, -1, -1, -1, 355, 356, -1, 290, 424, -1, 444, -1, 58, 296, 297, -1, 367, 63, -1, -1, 371, -1, -1, -1, 458, 459, 460, 461, 462, 463, 446, -1, -1, -1, -1, -1, -1, -1, 472, -1, 40, -1, 42, 43, 327, 45, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, 58, -1, -1, 260, -1, 63, 263, 481, 482, -1, 267, -1, -1, -1, 355, 356, -1, 426, 40, 276, 42, 43, -1, 45, -1, 434, 367, -1, -1, -1, 371, -1, -1, 290, 273, 444, 58, -1, 277, 296, 297, 63, -1, -1, -1, -1, 285, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, 296, -1, -1, 299, -1, -1, 472, -1, -1, -1, -1, -1, -1, 327, -1, 481, 482, 483, 484, 485, 486, 487, 40, -1, -1, 43, -1, 45, 426, -1, -1, -1, -1, -1, -1, -1, 434, -1, -1, -1, 58, 355, 356, -1, 340, 63, 444, -1, -1, -1, 346, 347, 348, 367, 350, 351, 352, 371, 354, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, -1, -1, 472, -1, -1, -1, 374, -1, 376, -1, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, -1, -1, -1, 260, -1, -1, 263, -1, 40, -1, 267, 43, -1, 45, -1, 407, 426, -1, -1, 276, -1, -1, -1, -1, 434, -1, 58, -1, -1, -1, -1, 63, 424, 290, 444, -1, -1, -1, -1, 296, 297, -1, -1, -1, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, 446, -1, 267, -1, -1, -1, -1, -1, 472, -1, -1, 276, -1, -1, -1, 461, 327, 481, 482, 483, 484, 485, 486, 487, -1, 290, -1, -1, -1, -1, -1, 296, 297, -1, -1, 481, 482, -1, 267, -1, -1, -1, -1, -1, 355, 356, -1, 276, -1, -1, -1, -1, 40, 41, -1, 43, 367, 45, -1, -1, 371, 290, 327, -1, -1, -1, -1, 296, 297, -1, 58, -1, -1, -1, -1, 63, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 353, -1, 355, 356, -1, -1, -1, -1, -1, -1, 327, 267, -1, -1, 367, -1, -1, -1, 371, 40, 276, -1, 43, -1, 45, -1, -1, 426, -1, -1, -1, -1, -1, -1, 290, 434, 353, 58, 355, 356, 296, 297, 63, -1, -1, 444, -1, -1, -1, -1, 367, -1, -1, -1, 371, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, 327, -1, 472, -1, -1, -1, -1, -1, -1, -1, 434, 481, 482, 483, 484, 485, 486, 487, -1, -1, 444, -1, 267, -1, -1, -1, -1, -1, 355, 356, -1, 276, -1, -1, 458, 459, 460, 461, 462, 463, 367, -1, -1, -1, 371, 290, 434, -1, 472, -1, -1, 296, 297, -1, -1, -1, 444, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, 327, -1, 472, -1, -1, -1, -1, -1, -1, 418, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, -1, 434, 353, -1, 355, 356, -1, -1, -1, -1, -1, 444, -1, -1, 267, -1, 367, -1, -1, -1, 371, -1, -1, 276, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, 290, -1, 472, -1, -1, 40, 296, 297, 43, -1, 45, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, 58, -1, -1, -1, -1, 63, -1, -1, -1, 267, -1, -1, -1, -1, 327, -1, -1, 40, 276, -1, 43, -1, 45, 434, -1, -1, -1, -1, -1, -1, -1, -1, 290, 444, -1, 58, -1, -1, 296, 297, 63, -1, 355, 356, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, 367, -1, -1, -1, 371, -1, -1, 472, -1, -1, -1, -1, -1, -1, -1, 327, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 261, -1, -1, -1, -1, -1, -1, -1, -1, 355, 356, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 367, 283, -1, -1, 371, -1, -1, -1, -1, 291, -1, -1, 434, -1, -1, -1, 298, -1, 300, -1, 302, -1, 444, -1, -1, 307, -1, -1, -1, -1, -1, -1, 314, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, 328, -1, -1, -1, 472, 40, -1, -1, 43, -1, 45, 339, -1, 481, 482, 483, 484, 485, 486, 487, -1, 434, -1, 58, -1, -1, -1, -1, 63, -1, -1, 444, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 455, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, 267, -1, 273, -1, -1, 472, 277, -1, -1, 276, -1, -1, -1, -1, 481, 482, 483, 484, 485, 486, 487, 292, -1, 290, 406, 296, -1, -1, 299, 296, 297, 413, -1, -1, 416, 267, 418, 419, -1, -1, -1, -1, -1, -1, 276, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 290, -1, 327, 443, -1, -1, 296, 297, 41, 42, 43, 340, 45, -1, 47, -1, -1, 346, 347, 348, -1, 350, 351, 352, -1, 354, -1, 60, 61, 62, 355, 356, -1, -1, -1, -1, -1, 327, -1, -1, -1, -1, 367, -1, -1, 374, 371, 376, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 355, 356, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 367, 407, -1, -1, 371, -1, 412, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 424, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 434, -1, -1, -1, -1, -1, -1, -1, 446, -1, 444, 267, 42, 43, -1, 45, -1, 47, -1, -1, 276, 455, -1, -1, 458, 459, 460, 461, 462, 463, 60, 61, 62, -1, 290, 434, -1, -1, 472, -1, 296, 297, -1, 481, 482, 444, -1, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, -1, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, 327, -1, 472, -1, -1, -1, -1, -1, -1, -1, -1, 481, 482, 483, 484, 485, 486, 487, -1, 273, -1, -1, -1, 277, -1, -1, -1, -1, 355, 356, -1, -1, -1, -1, -1, -1, -1, -1, 292, -1, 367, -1, 296, -1, 371, 299, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 272, -1, -1, -1, -1, -1, -1, -1, 280, -1, -1, -1, -1, -1, 286, -1, -1, 289, -1, -1, -1, -1, -1, -1, -1, -1, -1, 340, -1, -1, -1, -1, -1, 346, 347, 348, -1, 350, 351, 352, -1, 354, -1, -1, -1, -1, -1, -1, 434, -1, -1, -1, -1, 325, -1, -1, -1, -1, 444, -1, -1, 374, 334, 376, -1, -1, -1, -1, -1, -1, 342, -1, 458, 459, 460, 461, 462, 463, -1, -1, -1, -1, -1, -1, -1, -1, 472, -1, -1, 361, -1, 363, -1, -1, 407, 481, 482, 483, 484, 485, 486, 487, -1, -1, -1, 377, -1, 379, 380, 381, -1, 424, 272, -1, -1, -1, -1, -1, -1, -1, 280, 273, -1, -1, -1, 277, 286, -1, -1, 289, -1, -1, -1, 446, -1, -1, -1, 273, -1, -1, -1, 277, -1, -1, 296, -1, -1, 299, -1, -1, -1, -1, -1, -1, -1, -1, 292, -1, 430, -1, 296, -1, -1, 299, -1, 325, -1, -1, 481, 482, -1, -1, -1, -1, 334, -1, -1, -1, -1, -1, -1, -1, 342, 273, -1, -1, -1, 277, 340, -1, -1, -1, -1, -1, 346, 347, 348, -1, 350, 351, 352, 361, 354, 363, 340, -1, 296, -1, -1, 299, 346, 347, 348, -1, 350, 351, 352, 377, 354, 379, 380, 381, 374, -1, 376, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 271, -1, -1, 374, -1, 376, -1, -1, -1, -1, -1, -1, -1, -1, -1, 340, -1, -1, -1, -1, 407, 346, 347, 348, -1, 350, 351, 352, -1, 354, -1, 302, -1, -1, -1, 430, 407, 424, 309, -1, -1, 271, 313, 314, -1, 316, -1, -1, 319, 374, -1, 376, -1, 424, -1, -1, -1, -1, -1, 446, -1, -1, 333, -1, -1, -1, -1, -1, 339, -1, -1, -1, 302, -1, 461, 446, -1, -1, -1, 309, -1, -1, 407, 313, 314, -1, 316, -1, -1, 319, -1, -1, -1, -1, 481, 482, -1, -1, -1, 424, -1, -1, -1, 333, -1, -1, -1, -1, -1, 339, 481, 482, -1, -1, -1, -1, -1, -1, -1, -1, -1, 446, -1, -1, -1, -1, -1, -1, 399, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 418, -1, -1, -1, -1, -1, -1, -1, -1, 481, 482, -1, -1, -1, -1, 433, -1, -1, -1, -1, -1, -1, 399, -1, -1, 443, -1, -1, -1, -1, -1, -1, -1, -1, 452, -1, 454, -1, -1, -1, -1, 418, -1, 461, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 433, -1, -1, -1, -1, -1, -1, -1, -1, -1, 443, -1, -1, -1, -1, -1, -1, -1, -1, 452, -1, 454, -1, -1, -1, -1, -1, -1, 461, }; #define YYFINAL 17 #ifndef YYDEBUG #define YYDEBUG 0 #endif #define YYMAXTOKEN 490 #if YYDEBUG char *yyname[] = { "end-of-file",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,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,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,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,0,0,0,0,0,0,0,0,0,0,0,0,"ACTIVE","ADD","AFTER","ALL","ALTER","AND","ANY", "AS","ASC","AT","AVG","AUTO","BASENAME","BEFORE","BEGIN","BETWEEN","BLOB","BY", "CACHE","CAST","CHARACTER","CHECK","CHECK_POINT_LEN","COLLATE","COLLATION", "COMMA","COMMIT","COMMITTED","COMPUTED","CONCATENATE","CONDITIONAL", "CONSTRAINT","CONTAINING","COUNT","CREATE","CSTRING","CURRENT","CURSOR", "DATABASE","DATE","DB_KEY","DEBUG","DECIMAL","DECLARE","DEFAULT","DELETE", "DESC","DISTINCT","DO","DOMAIN","DROP","ELSE","END","ENTRY_POINT","EQL", "ESCAPE","EXCEPTION","EXECUTE","EXISTS","EXIT","EXTERNAL","FILTER","FOR", "FOREIGN","FROM","FULL","FUNCTION","GDSCODE","GEQ","GENERATOR","GEN_ID","GRANT", "GROUP","GROUP_COMMIT_WAIT","GTR","HAVING","IF","IN","INACTIVE","INNER", "INPUT_TYPE","INDEX","INSERT","INTEGER","INTO","IS","ISOLATION","JOIN","KEY", "KW_CHAR","KW_DEC","KW_DOUBLE","KW_FILE","KW_FLOAT","KW_INT","KW_LONG", "KW_NULL","KW_NUMERIC","KW_UPPER","KW_VALUE","LENGTH","LOGFILE","LPAREN","LEFT", "LEQ","LEVEL","LIKE","LOG_BUF_SIZE","LSS","MANUAL","MAXIMUM","MAX_SEGMENT", "MERGE","MESSAGE","MINIMUM","MODULE_NAME","NAMES","NATIONAL","NATURAL","NCHAR", "NEQ","NO","NOT","NOT_GTR","NOT_LSS","NUM_LOG_BUFS","OF","ON","ONLY","OPTION", "OR","ORDER","OUTER","OUTPUT_TYPE","OVERFLOW","PAGE","PAGES","PAGE_SIZE", "PARAMETER","PASSWORD","PLAN","POSITION","POST_EVENT","PRECISION","PRIMARY", "PRIVILEGES","PROCEDURE","PROTECTED","RAW_PARTITIONS","READ","REAL", "REFERENCES","RESERVING","RETAIN","RETURNING_VALUES","RETURNS","REVOKE","RIGHT", "RPAREN","ROLLBACK","SEGMENT","SELECT","SET","SHADOW","SHARED","SINGULAR", "SIZE","SMALLINT","SNAPSHOT","SOME","SORT","SQLCODE","STABILITY","STARTING", "STATISTICS","SUB_TYPE","SUSPEND","SUM","TABLE","THEN","TO","TRANSACTION", "TRIGGER","UNCOMMITTED","UNION","UNIQUE","UPDATE","USER","VALUES","VARCHAR", "VARIABLE","VARYING","VERSION","VIEW","WAIT","WHEN","WHERE","WHILE","WITH", "WORK","WRITE","FLOAT","NUMBER","NUMERIC","SYMBOL","STRING","INTRODUCER", "ACTION","ADMIN","CASCADE","FREE_IT","RESTRICT","ROLE","COLUMN","TYPE", "EXTRACT","YEAR","MONTH","DAY","HOUR","MINUTE","SECOND","WEEKDAY","YEARDAY", "TIME","TIMESTAMP","CURRENT_DATE","CURRENT_TIME","CURRENT_TIMESTAMP", "NUMBER64BIT","SCALEDINT","LIMIT","INT64","SUBSTRING", }; char *yyrule[] = { "$accept : top", "top : statement", "top : statement ';'", "statement : alter", "statement : blob", "statement : commit", "statement : create", "statement : declare", "statement : delete", "statement : drop", "statement : grant", "statement : insert", "statement : invoke_procedure", "statement : revoke", "statement : rollback", "statement : select", "statement : set", "statement : update", "statement : DEBUG signed_short_integer", "grant : GRANT privileges ON prot_table_name TO user_grantee_list grant_option", "grant : GRANT proc_privileges ON PROCEDURE simple_proc_name TO user_grantee_list grant_option", "grant : GRANT privileges ON prot_table_name TO grantee_list", "grant : GRANT proc_privileges ON PROCEDURE simple_proc_name TO grantee_list", "grant : GRANT role_name_list TO role_grantee_list role_admin_option", "prot_table_name : simple_table_name", "prot_table_name : TABLE simple_table_name", "privileges : ALL", "privileges : ALL PRIVILEGES", "privileges : privilege_list", "privilege_list : privilege", "privilege_list : privilege_list ',' privilege", "proc_privileges : EXECUTE", "privilege : SELECT", "privilege : INSERT", "privilege : DELETE", "privilege : UPDATE column_parens_opt", "privilege : REFERENCES column_parens_opt", "grant_option : WITH GRANT OPTION", "grant_option :", "role_admin_option : WITH ADMIN OPTION", "role_admin_option :", "simple_proc_name : symbol_procedure_name", "revoke : REVOKE rev_grant_option privileges ON prot_table_name FROM user_grantee_list", "revoke : REVOKE rev_grant_option proc_privileges ON PROCEDURE simple_proc_name FROM user_grantee_list", "revoke : REVOKE privileges ON prot_table_name FROM user_grantee_list", "revoke : REVOKE proc_privileges ON PROCEDURE simple_proc_name FROM user_grantee_list", "revoke : REVOKE privileges ON prot_table_name FROM grantee_list", "revoke : REVOKE proc_privileges ON PROCEDURE simple_proc_name FROM grantee_list", "revoke : REVOKE role_name_list FROM role_grantee_list", "rev_grant_option : GRANT OPTION FOR", "grantee_list : grantee", "grantee_list : grantee_list ',' grantee", "grantee_list : grantee_list ',' user_grantee", "grantee_list : user_grantee_list ',' grantee", "grantee : PROCEDURE symbol_procedure_name", "grantee : TRIGGER symbol_trigger_name", "grantee : VIEW symbol_view_name", "user_grantee_list : user_grantee", "user_grantee_list : user_grantee_list ',' user_grantee", "user_grantee : symbol_user_name", "user_grantee : USER symbol_user_name", "user_grantee : GROUP symbol_user_name", "role_name_list : role_name", "role_name_list : role_name_list ',' role_name", "role_name : symbol_role_name", "role_grantee_list : role_grantee", "role_grantee_list : role_grantee_list ',' role_grantee", "role_grantee : symbol_user_name", "role_grantee : USER symbol_user_name", "declare : DECLARE declare_clause", "declare_clause : FILTER filter_decl_clause", "declare_clause : EXTERNAL FUNCTION udf_decl_clause", "udf_decl_clause : symbol_UDF_name arg_desc_list1 RETURNS return_value1 ENTRY_POINT sql_string MODULE_NAME sql_string", "udf_data_type : simple_type", "udf_data_type : BLOB", "udf_data_type : CSTRING '(' pos_short_integer ')' charset_clause", "arg_desc_list1 :", "arg_desc_list1 : arg_desc_list", "arg_desc_list1 : '(' arg_desc_list ')'", "arg_desc_list : arg_desc", "arg_desc_list : arg_desc_list ',' arg_desc", "arg_desc : init_data_type udf_data_type", "return_value1 : return_value", "return_value1 : '(' return_value ')'", "return_value : init_data_type udf_data_type", "return_value : init_data_type udf_data_type FREE_IT", "return_value : init_data_type udf_data_type BY KW_VALUE", "return_value : PARAMETER pos_short_integer", "filter_decl_clause : symbol_filter_name INPUT_TYPE blob_subtype OUTPUT_TYPE blob_subtype ENTRY_POINT sql_string MODULE_NAME sql_string", "create : CREATE create_clause", "create_clause : EXCEPTION symbol_exception_name sql_string", "create_clause : unique_opt order_direction INDEX symbol_index_name ON simple_table_name index_definition", "create_clause : PROCEDURE procedure_clause", "create_clause : TABLE table_clause", "create_clause : TRIGGER def_trigger_clause", "create_clause : VIEW view_clause", "create_clause : GENERATOR generator_clause", "create_clause : DATABASE db_clause", "create_clause : DOMAIN domain_clause", "create_clause : SHADOW shadow_clause", "create_clause : ROLE role_clause", "unique_opt : UNIQUE", "unique_opt :", "index_definition : column_list", "index_definition : column_parens", "index_definition : computed_by '(' begin_trigger value end_trigger ')'", "shadow_clause : pos_short_integer manual_auto conditional sql_string first_file_length sec_shadow_files", "manual_auto : MANUAL", "manual_auto : AUTO", "manual_auto :", "conditional :", "conditional : CONDITIONAL", "first_file_length :", "first_file_length : LENGTH equals long_integer page_noise", "sec_shadow_files :", "sec_shadow_files : db_file_list", "db_file_list : db_file", "db_file_list : db_file_list db_file", "domain_clause : column_def_name as_opt data_type begin_trigger domain_default_opt end_trigger domain_constraint_clause collate_clause", "as_opt : AS", "as_opt :", "domain_default_opt : DEFAULT begin_trigger default_value", "domain_default_opt :", "domain_constraint_clause :", "domain_constraint_clause : domain_constraint_list", "domain_constraint_list : domain_constraint_def", "domain_constraint_list : domain_constraint_list domain_constraint_def", "domain_constraint_def : domain_constraint", "domain_constraint : null_constraint", "domain_constraint : domain_check_constraint", "null_constraint : NOT KW_NULL", "domain_check_constraint : begin_trigger CHECK '(' search_condition ')' end_trigger", "generator_clause : symbol_generator_name", "role_clause : symbol_role_name", "db_clause : db_name db_initial_desc1 db_rem_desc1", "equals :", "equals : '='", "db_name : sql_string", "db_initial_desc1 :", "db_initial_desc1 : db_initial_desc", "db_initial_desc : db_initial_option", "db_initial_desc : db_initial_desc db_initial_option", "db_initial_option : PAGE_SIZE equals pos_short_integer", "db_initial_option : LENGTH equals long_integer page_noise", "db_initial_option : USER sql_string", "db_initial_option : PASSWORD sql_string", "db_initial_option : SET NAMES sql_string", "db_rem_desc1 :", "db_rem_desc1 : db_rem_desc", "db_rem_desc : db_rem_option", "db_rem_desc : db_rem_desc db_rem_option", "db_rem_option : db_file", "db_rem_option : db_log", "db_rem_option : db_log_option", "db_rem_option : DEFAULT CHARACTER SET symbol_character_set_name", "db_log_option : GROUP_COMMIT_WAIT equals long_integer", "db_log_option : CHECK_POINT_LEN equals long_integer", "db_log_option : NUM_LOG_BUFS equals pos_short_integer", "db_log_option : LOG_BUF_SIZE equals unsigned_short_integer", "db_log : db_default_log_spec", "db_log : db_rem_log_spec", "db_rem_log_spec : LOGFILE '(' logfiles ')' OVERFLOW logfile_desc", "db_rem_log_spec : LOGFILE BASENAME logfile_desc", "db_default_log_spec : LOGFILE", "db_file : file1 sql_string file_desc1", "logfiles : logfile_desc", "logfiles : logfiles ',' logfile_desc", "logfile_desc : logfile_name logfile_attrs", "logfile_name : sql_string", "logfile_attrs :", "logfile_attrs : logfile_attrs logfile_attr", "logfile_attr : SIZE equals long_integer", "file1 : KW_FILE", "file_desc1 :", "file_desc1 : file_desc", "file_desc : file_clause", "file_desc : file_desc file_clause", "file_clause : STARTING file_clause_noise long_integer", "file_clause : LENGTH equals long_integer page_noise", "file_clause_noise :", "file_clause_noise : AT", "file_clause_noise : AT PAGE", "page_noise :", "page_noise : PAGE", "page_noise : PAGES", "table_clause : simple_table_name external_file '(' table_elements ')'", "external_file : EXTERNAL KW_FILE sql_string", "external_file : EXTERNAL sql_string", "external_file :", "table_elements : table_element", "table_elements : table_elements ',' table_element", "table_element : column_def", "table_element : table_constraint_definition", "column_def : column_def_name data_type_or_domain default_opt end_trigger column_constraint_clause collate_clause", "column_def : column_def_name non_array_type def_computed", "column_def : column_def_name def_computed", "def_computed : computed_by '(' begin_trigger value end_trigger ')'", "computed_by : COMPUTED BY", "computed_by : COMPUTED", "data_type_or_domain : data_type begin_trigger", "data_type_or_domain : simple_column_name begin_string", "collate_clause : COLLATE symbol_collation_name", "collate_clause :", "column_def_name : column_name", "simple_column_def_name : simple_column_name", "data_type_descriptor : init_data_type data_type", "init_data_type :", "default_opt : DEFAULT default_value", "default_opt :", "default_value : constant", "default_value : USER", "default_value : null_value", "default_value : datetime_value_expression", "column_constraint_clause :", "column_constraint_clause : column_constraint_list", "column_constraint_list : column_constraint_def", "column_constraint_list : column_constraint_list column_constraint_def", "column_constraint_def : constraint_name_opt column_constraint", "column_constraint : NOT KW_NULL", "column_constraint : REFERENCES simple_table_name column_parens_opt referential_trigger_action", "column_constraint : check_constraint", "column_constraint : UNIQUE", "column_constraint : PRIMARY KEY", "table_constraint_definition : constraint_name_opt table_constraint", "constraint_name_opt : CONSTRAINT symbol_constraint_name", "constraint_name_opt :", "table_constraint : unique_constraint", "table_constraint : primary_constraint", "table_constraint : referential_constraint", "table_constraint : check_constraint", "unique_constraint : UNIQUE column_parens", "primary_constraint : PRIMARY KEY column_parens", "referential_constraint : FOREIGN KEY column_parens REFERENCES simple_table_name column_parens_opt referential_trigger_action", "check_constraint : begin_trigger CHECK '(' search_condition ')' end_trigger", "referential_trigger_action : update_rule", "referential_trigger_action : delete_rule", "referential_trigger_action : delete_rule update_rule", "referential_trigger_action : update_rule delete_rule", "referential_trigger_action :", "update_rule : ON UPDATE referential_action", "delete_rule : ON DELETE referential_action", "referential_action : CASCADE", "referential_action : SET DEFAULT", "referential_action : SET KW_NULL", "referential_action : NO ACTION", "procedure_clause : symbol_procedure_name input_parameters output_parameters AS begin_string var_declaration_list full_proc_block end_trigger", "alter_procedure_clause : symbol_procedure_name input_parameters output_parameters AS begin_string var_declaration_list full_proc_block end_trigger", "input_parameters : '(' proc_parameters ')'", "input_parameters :", "output_parameters : RETURNS input_parameters", "output_parameters :", "proc_parameters : proc_parameter", "proc_parameters : proc_parameters ',' proc_parameter", "proc_parameter : simple_column_def_name non_array_type", "var_declaration_list : var_declarations", "var_declaration_list :", "var_declarations : var_declaration", "var_declarations : var_declarations var_declaration", "var_declaration : DECLARE VARIABLE column_def_name non_array_type ';'", "proc_block : proc_statement", "proc_block : full_proc_block", "full_proc_block : BEGIN proc_statements END", "full_proc_block : BEGIN proc_statements excp_statements END", "proc_statements : proc_block", "proc_statements : proc_statements proc_block", "proc_statement : assignment ';'", "proc_statement : delete ';'", "proc_statement : EXCEPTION symbol_exception_name ';'", "proc_statement : exec_procedure", "proc_statement : for_select", "proc_statement : if_then_else", "proc_statement : insert ';'", "proc_statement : POST_EVENT value ';'", "proc_statement : singleton_select", "proc_statement : update ';'", "proc_statement : while", "proc_statement : SUSPEND ';'", "proc_statement : EXIT ';'", "exec_procedure : EXECUTE PROCEDURE symbol_procedure_name proc_inputs proc_outputs ';'", "for_select : FOR select INTO variable_list cursor_def DO proc_block", "if_then_else : IF '(' search_condition ')' THEN proc_block ELSE proc_block", "if_then_else : IF '(' search_condition ')' THEN proc_block", "singleton_select : select INTO variable_list ';'", "variable : ':' symbol_variable_name", "proc_inputs : var_const_list", "proc_inputs : '(' var_const_list ')'", "proc_inputs :", "proc_outputs : RETURNING_VALUES variable_list", "proc_outputs : RETURNING_VALUES '(' variable_list ')'", "proc_outputs :", "var_const_list : variable", "var_const_list : constant", "var_const_list : column_name", "var_const_list : null_value", "var_const_list : var_const_list ',' variable", "var_const_list : var_const_list ',' constant", "var_const_list : var_const_list ',' column_name", "var_const_list : var_const_list ',' null_value", "variable_list : variable", "variable_list : column_name", "variable_list : variable_list ',' column_name", "variable_list : variable_list ',' variable", "while : WHILE '(' search_condition ')' DO proc_block", "cursor_def : AS CURSOR symbol_cursor_name", "cursor_def :", "excp_statements : excp_statement", "excp_statements : excp_statements excp_statement", "excp_statement : WHEN errors DO proc_block", "errors : err", "errors : errors ',' err", "err : SQLCODE signed_short_integer", "err : GDSCODE symbol_gdscode_name", "err : EXCEPTION symbol_exception_name", "err : ANY", "invoke_procedure : EXECUTE PROCEDURE symbol_procedure_name prc_inputs", "prc_inputs : prm_const_list", "prc_inputs : '(' prm_const_list ')'", "prc_inputs :", "prm_const_list : parameter", "prm_const_list : constant", "prm_const_list : null_value", "prm_const_list : prm_const_list ',' parameter", "prm_const_list : prm_const_list ',' constant", "prm_const_list : prm_const_list ',' null_value", "view_clause : symbol_view_name column_parens_opt AS begin_string union_view check_opt end_string", "union_view : union_view_expr", "union_view_expr : select_view_expr", "union_view_expr : union_view_expr UNION select_view_expr", "union_view_expr : union_view_expr UNION ALL select_view_expr", "select_view_expr : SELECT distinct_clause select_list from_view_clause where_clause group_clause having_clause plan_clause", "from_view_clause : FROM from_view_list", "from_view_list : view_table", "from_view_list : from_view_list ',' view_table", "view_table : joined_view_table", "view_table : table_name", "joined_view_table : view_table join_type JOIN view_table ON search_condition", "joined_view_table : '(' joined_view_table ')'", "begin_string :", "end_string :", "begin_trigger :", "end_trigger :", "check_opt : WITH CHECK OPTION", "check_opt :", "def_trigger_clause : symbol_trigger_name FOR simple_table_name trigger_active trigger_type trigger_position begin_trigger trigger_action end_trigger", "trigger_active : ACTIVE", "trigger_active : INACTIVE", "trigger_active :", "trigger_type : BEFORE INSERT", "trigger_type : AFTER INSERT", "trigger_type : BEFORE UPDATE", "trigger_type : AFTER UPDATE", "trigger_type : BEFORE DELETE", "trigger_type : AFTER DELETE", "trigger_position : POSITION nonneg_short_integer", "trigger_position :", "trigger_action : AS begin_trigger var_declaration_list full_proc_block", "alter : ALTER alter_clause", "alter_clause : EXCEPTION symbol_exception_name sql_string", "alter_clause : TABLE simple_table_name alter_ops", "alter_clause : TRIGGER alter_trigger_clause", "alter_clause : PROCEDURE alter_procedure_clause", "alter_clause : DATABASE init_alter_db alter_db", "alter_clause : DOMAIN alter_column_name alter_domain_ops", "alter_clause : INDEX alter_index_clause", "alter_domain_ops : alter_domain_op", "alter_domain_ops : alter_domain_ops alter_domain_op", "alter_domain_op : SET begin_string default_opt end_trigger", "alter_domain_op : ADD CONSTRAINT domain_check_constraint", "alter_domain_op : ADD domain_check_constraint", "alter_domain_op : DROP DEFAULT", "alter_domain_op : DROP CONSTRAINT", "alter_domain_op : TO simple_column_name", "alter_domain_op : TYPE init_data_type non_array_type", "alter_ops : alter_op", "alter_ops : alter_ops ',' alter_op", "alter_op : DROP simple_column_name drop_behaviour", "alter_op : DROP CONSTRAINT symbol_constraint_name", "alter_op : ADD column_def", "alter_op : ADD table_constraint_definition", "alter_op : col_opt simple_column_name POSITION nonneg_short_integer", "alter_op : col_opt alter_column_name TO simple_column_name", "alter_op : col_opt alter_col_name TYPE alter_data_type_or_domain end_trigger", "alter_column_name : keyword_or_column", "keyword_or_column : COLUMN", "keyword_or_column : TYPE", "keyword_or_column : EXTRACT", "keyword_or_column : YEAR", "keyword_or_column : MONTH", "keyword_or_column : DAY", "keyword_or_column : HOUR", "keyword_or_column : MINUTE", "keyword_or_column : SECOND", "keyword_or_column : WEEKDAY", "keyword_or_column : YEARDAY", "keyword_or_column : TIME", "keyword_or_column : TIMESTAMP", "keyword_or_column : CURRENT_DATE", "keyword_or_column : CURRENT_TIME", "keyword_or_column : CURRENT_TIMESTAMP", "keyword_or_column : SYMBOL", "col_opt : ALTER", "col_opt : ALTER COLUMN", "alter_data_type_or_domain : non_array_type begin_trigger", "alter_data_type_or_domain : simple_column_name begin_string", "alter_col_name : simple_column_name", "drop_behaviour : RESTRICT", "drop_behaviour : CASCADE", "drop_behaviour :", "alter_index_clause : symbol_index_name ACTIVE", "alter_index_clause : symbol_index_name INACTIVE", "init_alter_db :", "alter_db : db_alter_clause", "alter_db : alter_db db_alter_clause", "db_alter_clause : ADD db_file_list", "db_alter_clause : DROP LOGFILE", "db_alter_clause : SET db_log_option_list", "db_alter_clause : ADD db_log", "db_log_option_list : db_log_option", "db_log_option_list : db_log_option_list ',' db_log_option", "alter_trigger_clause : symbol_trigger_name trigger_active new_trigger_type trigger_position begin_trigger new_trigger_action end_trigger", "new_trigger_type : trigger_type", "new_trigger_type :", "new_trigger_action : trigger_action", "new_trigger_action :", "drop : DROP drop_clause", "drop_clause : EXCEPTION symbol_exception_name", "drop_clause : INDEX symbol_index_name", "drop_clause : PROCEDURE symbol_procedure_name", "drop_clause : TABLE symbol_table_name", "drop_clause : TRIGGER symbol_trigger_name", "drop_clause : VIEW symbol_view_name", "drop_clause : FILTER symbol_filter_name", "drop_clause : DOMAIN symbol_domain_name", "drop_clause : EXTERNAL FUNCTION symbol_UDF_name", "drop_clause : SHADOW pos_short_integer", "drop_clause : ROLE symbol_role_name", "data_type : non_array_type", "data_type : array_type", "non_array_type : simple_type", "non_array_type : blob_type", "array_type : non_charset_simple_type '[' array_spec ']'", "array_type : character_type '[' array_spec ']' charset_clause", "array_spec : array_range", "array_spec : array_spec ',' array_range", "array_range : signed_long_integer", "array_range : signed_long_integer ':' signed_long_integer", "simple_type : non_charset_simple_type", "simple_type : character_type charset_clause", "non_charset_simple_type : national_character_type", "non_charset_simple_type : numeric_type", "non_charset_simple_type : float_type", "non_charset_simple_type : integer_keyword", "non_charset_simple_type : SMALLINT", "non_charset_simple_type : DATE", "non_charset_simple_type : TIME", "non_charset_simple_type : TIMESTAMP", "integer_keyword : INTEGER", "integer_keyword : KW_INT", "blob_type : BLOB blob_subtype blob_segsize charset_clause", "blob_type : BLOB '(' unsigned_short_integer ')'", "blob_type : BLOB '(' unsigned_short_integer ',' signed_short_integer ')'", "blob_type : BLOB '(' ',' signed_short_integer ')'", "blob_segsize : SEGMENT SIZE unsigned_short_integer", "blob_segsize :", "blob_subtype : SUB_TYPE signed_short_integer", "blob_subtype : SUB_TYPE symbol_blob_subtype_name", "blob_subtype :", "charset_clause : CHARACTER SET symbol_character_set_name", "charset_clause :", "national_character_type : national_character_keyword '(' pos_short_integer ')'", "national_character_type : national_character_keyword", "national_character_type : national_character_keyword VARYING '(' pos_short_integer ')'", "character_type : character_keyword '(' pos_short_integer ')'", "character_type : character_keyword", "character_type : varying_keyword '(' pos_short_integer ')'", "varying_keyword : VARCHAR", "varying_keyword : CHARACTER VARYING", "varying_keyword : KW_CHAR VARYING", "character_keyword : CHARACTER", "character_keyword : KW_CHAR", "national_character_keyword : NCHAR", "national_character_keyword : NATIONAL CHARACTER", "national_character_keyword : NATIONAL KW_CHAR", "numeric_type : KW_NUMERIC prec_scale", "numeric_type : decimal_keyword prec_scale", "ordinal : pos_short_integer", "prec_scale :", "prec_scale : '(' signed_long_integer ')'", "prec_scale : '(' signed_long_integer ',' signed_long_integer ')'", "decimal_keyword : DECIMAL", "decimal_keyword : KW_DEC", "float_type : KW_FLOAT precision_opt", "float_type : KW_LONG KW_FLOAT precision_opt", "float_type : REAL", "float_type : KW_DOUBLE PRECISION", "precision_opt : '(' nonneg_short_integer ')'", "precision_opt :", "set : set_transaction", "set : set_generator", "set : set_statistics", "set_generator : SET GENERATOR symbol_generator_name TO signed_long_integer", "set_generator : SET GENERATOR symbol_generator_name TO NUMBER64BIT", "set_generator : SET GENERATOR symbol_generator_name TO '-' NUMBER64BIT", "commit : COMMIT optional_work optional_retain", "rollback : ROLLBACK optional_work", "optional_work : WORK", "optional_work :", "optional_retain : RETAIN opt_snapshot", "optional_retain :", "opt_snapshot : SNAPSHOT", "opt_snapshot :", "set_transaction : SET TRANSACTION tran_opt_list_m", "tran_opt_list_m : tran_opt_list", "tran_opt_list_m :", "tran_opt_list : tran_opt", "tran_opt_list : tran_opt_list tran_opt", "tran_opt : access_mode", "tran_opt : lock_wait", "tran_opt : isolation_mode", "tran_opt : tbl_reserve_options", "access_mode : READ ONLY", "access_mode : READ WRITE", "lock_wait : WAIT", "lock_wait : NO WAIT", "isolation_mode : ISOLATION LEVEL iso_mode", "isolation_mode : iso_mode", "iso_mode : snap_shot", "iso_mode : READ UNCOMMITTED version_mode", "iso_mode : READ COMMITTED version_mode", "snap_shot : SNAPSHOT", "snap_shot : SNAPSHOT TABLE", "snap_shot : SNAPSHOT TABLE STABILITY", "version_mode : VERSION", "version_mode : NO VERSION", "version_mode :", "tbl_reserve_options : RESERVING restr_list", "lock_type : SHARED", "lock_type : PROTECTED", "lock_type :", "lock_mode : READ", "lock_mode : WRITE", "restr_list : restr_option", "restr_list : restr_list ',' restr_option", "restr_option : table_list table_lock", "table_lock : FOR lock_type lock_mode", "table_lock :", "table_list : simple_table_name", "table_list : table_list ',' simple_table_name", "set_statistics : SET STATISTICS INDEX symbol_index_name", "select : union_expr order_clause for_update_clause", "union_expr : select_expr", "union_expr : union_expr UNION select_expr", "union_expr : union_expr UNION ALL select_expr", "order_clause : ORDER BY order_list", "order_clause :", "order_list : order_item", "order_list : order_list ',' order_item", "order_item : column_name collate_clause order_direction", "order_item : ordinal collate_clause order_direction", "order_direction : ASC", "order_direction : DESC", "order_direction :", "for_update_clause : FOR UPDATE for_update_list", "for_update_clause :", "for_update_list : OF column_list", "for_update_list :", "select_expr : SELECT distinct_clause select_list from_clause where_clause group_clause having_clause limit_clause plan_clause", "distinct_clause : DISTINCT", "distinct_clause : all_noise", "select_list : select_items", "select_list : '*'", "select_items : select_item", "select_items : select_items ',' select_item", "select_item : rhs", "select_item : rhs symbol_item_alias_name", "select_item : rhs AS symbol_item_alias_name", "from_clause : FROM from_list", "from_list : table_reference", "from_list : from_list ',' table_reference", "table_reference : joined_table", "table_reference : table_proc", "joined_table : table_reference join_type JOIN table_reference ON search_condition", "joined_table : '(' joined_table ')'", "table_proc : symbol_procedure_name proc_table_inputs symbol_table_alias_name", "table_proc : symbol_procedure_name proc_table_inputs", "proc_table_inputs : '(' null_or_value_list ')'", "proc_table_inputs :", "null_or_value_list : null_or_value", "null_or_value_list : null_or_value_list ',' null_or_value", "null_or_value : null_value", "null_or_value : value", "table_name : simple_table_name", "table_name : symbol_table_name symbol_table_alias_name", "simple_table_name : symbol_table_name", "join_type : INNER", "join_type : LEFT", "join_type : LEFT OUTER", "join_type : RIGHT", "join_type : RIGHT OUTER", "join_type : FULL", "join_type : FULL OUTER", "join_type :", "group_clause : GROUP BY grp_column_list", "group_clause :", "grp_column_list : grp_column_elem", "grp_column_list : grp_column_list ',' grp_column_elem", "grp_column_elem : column_name", "grp_column_elem : udf", "grp_column_elem : column_name COLLATE symbol_collation_name", "having_clause : HAVING search_condition", "having_clause :", "where_clause : WHERE search_condition", "where_clause :", "limit_clause : LIMIT limit_range", "limit_clause :", "limit_range : '(' long_integer ')'", "limit_range : '(' long_integer ':' long_integer ')'", "limit_range :", "plan_clause : PLAN plan_expression", "plan_clause :", "plan_expression : plan_type '(' plan_item_list ')'", "plan_type : JOIN", "plan_type : SORT MERGE", "plan_type : MERGE", "plan_type : SORT", "plan_type :", "plan_item_list : plan_item", "plan_item_list : plan_item ',' plan_item_list", "plan_item : table_or_alias_list access_type", "plan_item : plan_expression", "table_or_alias_list : symbol_table_name", "table_or_alias_list : symbol_table_name table_or_alias_list", "access_type : NATURAL", "access_type : INDEX '(' index_list ')'", "access_type : ORDER symbol_index_name", "index_list : symbol_index_name", "index_list : symbol_index_name ',' index_list", "insert : INSERT INTO simple_table_name column_parens_opt VALUES '(' insert_value_list ')'", "insert : INSERT INTO simple_table_name column_parens_opt select_expr", "insert_value_list : rhs", "insert_value_list : insert_value_list ',' rhs", "delete : delete_searched", "delete : delete_positioned", "delete_searched : DELETE FROM table_name where_clause", "delete_positioned : DELETE FROM table_name cursor_clause", "cursor_clause : WHERE CURRENT OF symbol_cursor_name", "update : update_searched", "update : update_positioned", "update_searched : UPDATE table_name SET assignments where_clause", "update_positioned : UPDATE table_name SET assignments cursor_clause", "assignments : assignment", "assignments : assignments ',' assignment", "assignment : column_name '=' rhs", "rhs : value", "rhs : null_value", "blob : READ BLOB simple_column_name FROM simple_table_name filter_clause segment_clause", "blob : INSERT BLOB simple_column_name INTO simple_table_name filter_clause segment_clause", "filter_clause : FILTER FROM blob_subtype_value TO blob_subtype_value", "filter_clause : FILTER TO blob_subtype_value", "filter_clause :", "blob_subtype_value : blob_subtype", "blob_subtype_value : parameter", "blob_subtype : signed_short_integer", "segment_clause : MAX_SEGMENT segment_length", "segment_clause :", "segment_length : unsigned_short_integer", "segment_length : parameter", "column_parens_opt : column_parens", "column_parens_opt :", "column_parens : '(' column_list ')'", "column_list : column_name", "column_list : column_list ',' column_name", "column_name : simple_column_name", "column_name : symbol_table_alias_name '.' symbol_column_name", "column_name : symbol_table_alias_name '.' '*'", "simple_column_name : symbol_column_name", "search_condition : predicate", "search_condition : search_condition OR search_condition", "search_condition : search_condition AND search_condition", "search_condition : NOT search_condition", "predicate : comparison_predicate", "predicate : between_predicate", "predicate : like_predicate", "predicate : in_predicate", "predicate : null_predicate", "predicate : quantified_predicate", "predicate : exists_predicate", "predicate : containing_predicate", "predicate : starting_predicate", "predicate : unique_predicate", "predicate : '(' search_condition ')'", "comparison_predicate : value '=' value", "comparison_predicate : value '<' value", "comparison_predicate : value '>' value", "comparison_predicate : value GEQ value", "comparison_predicate : value LEQ value", "comparison_predicate : value NOT_GTR value", "comparison_predicate : value NOT_LSS value", "comparison_predicate : value NEQ value", "quantified_predicate : value '=' ALL '(' column_select ')'", "quantified_predicate : value '<' ALL '(' column_select ')'", "quantified_predicate : value '>' ALL '(' column_select ')'", "quantified_predicate : value GEQ ALL '(' column_select ')'", "quantified_predicate : value LEQ ALL '(' column_select ')'", "quantified_predicate : value NOT_GTR ALL '(' column_select ')'", "quantified_predicate : value NOT_LSS ALL '(' column_select ')'", "quantified_predicate : value NEQ ALL '(' column_select ')'", "quantified_predicate : value '=' some '(' column_select ')'", "quantified_predicate : value '<' some '(' column_select ')'", "quantified_predicate : value '>' some '(' column_select ')'", "quantified_predicate : value GEQ some '(' column_select ')'", "quantified_predicate : value LEQ some '(' column_select ')'", "quantified_predicate : value NOT_GTR some '(' column_select ')'", "quantified_predicate : value NOT_LSS some '(' column_select ')'", "quantified_predicate : value NEQ some '(' column_select ')'", "some : SOME", "some : ANY", "between_predicate : value BETWEEN value AND value", "between_predicate : value NOT BETWEEN value AND value", "like_predicate : value LIKE value", "like_predicate : value NOT LIKE value", "like_predicate : value LIKE value ESCAPE value", "like_predicate : value NOT LIKE value ESCAPE value", "in_predicate : value IN scalar_set", "in_predicate : value NOT IN scalar_set", "containing_predicate : value CONTAINING value", "containing_predicate : value NOT CONTAINING value", "starting_predicate : value STARTING value", "starting_predicate : value NOT STARTING value", "starting_predicate : value STARTING WITH value", "starting_predicate : value NOT STARTING WITH value", "exists_predicate : EXISTS '(' select_expr ')'", "unique_predicate : SINGULAR '(' select_expr ')'", "null_predicate : value IS KW_NULL", "null_predicate : value IS NOT KW_NULL", "scalar_set : '(' constant_list ')'", "scalar_set : '(' column_select ')'", "column_select : SELECT distinct_clause value from_clause where_clause group_clause having_clause plan_clause", "column_singleton : SELECT distinct_clause value from_clause where_clause group_clause having_clause plan_clause", "value : column_name", "value : array_element", "value : function", "value : u_constant", "value : parameter", "value : variable", "value : udf", "value : '-' value", "value : '+' value", "value : value '+' value", "value : value CONCATENATE value", "value : value COLLATE symbol_collation_name", "value : value '-' value", "value : value '*' value", "value : value '/' value", "value : '(' value ')'", "value : '(' column_singleton ')'", "value : USER", "value : DB_KEY", "value : symbol_table_alias_name '.' DB_KEY", "value : KW_VALUE", "value : datetime_value_expression", "datetime_value_expression : CURRENT_DATE", "datetime_value_expression : CURRENT_TIME", "datetime_value_expression : CURRENT_TIMESTAMP", "array_element : column_name '[' value_list ']'", "value_list : value", "value_list : value_list ',' value", "constant : u_constant", "constant : '-' u_numeric_constant", "u_numeric_constant : NUMERIC", "u_numeric_constant : NUMBER", "u_numeric_constant : FLOAT", "u_numeric_constant : NUMBER64BIT", "u_numeric_constant : SCALEDINT", "u_constant : u_numeric_constant", "u_constant : sql_string", "u_constant : DATE STRING", "u_constant : TIME STRING", "u_constant : TIMESTAMP STRING", "constant_list : constant", "constant_list : parameter", "constant_list : current_user", "constant_list : constant_list ',' constant", "constant_list : constant_list ',' parameter", "constant_list : constant_list ',' current_user", "parameter : '?'", "current_user : USER", "sql_string : STRING", "sql_string : INTRODUCER STRING", "signed_short_integer : nonneg_short_integer", "signed_short_integer : '-' neg_short_integer", "nonneg_short_integer : NUMBER", "neg_short_integer : NUMBER", "pos_short_integer : nonneg_short_integer", "unsigned_short_integer : NUMBER", "signed_long_integer : long_integer", "signed_long_integer : '-' long_integer", "long_integer : NUMBER", "function : COUNT '(' '*' ')'", "function : COUNT '(' all_noise value ')'", "function : COUNT '(' DISTINCT value ')'", "function : SUM '(' all_noise value ')'", "function : SUM '(' DISTINCT value ')'", "function : AVG '(' all_noise value ')'", "function : AVG '(' DISTINCT value ')'", "function : MINIMUM '(' all_noise value ')'", "function : MINIMUM '(' DISTINCT value ')'", "function : MAXIMUM '(' all_noise value ')'", "function : MAXIMUM '(' DISTINCT value ')'", "function : CAST '(' rhs AS data_type_descriptor ')'", "function : KW_UPPER '(' value ')'", "function : GEN_ID '(' symbol_generator_name ',' value ')'", "function : EXTRACT '(' timestamp_part FROM value ')'", "udf : symbol_UDF_name '(' value_list ')'", "udf : symbol_UDF_name '(' ')'", "timestamp_part : YEAR", "timestamp_part : MONTH", "timestamp_part : DAY", "timestamp_part : HOUR", "timestamp_part : MINUTE", "timestamp_part : SECOND", "timestamp_part : WEEKDAY", "timestamp_part : YEARDAY", "all_noise : ALL", "all_noise :", "null_value : KW_NULL", "symbol_UDF_name : SYMBOL", "symbol_blob_subtype_name : SYMBOL", "symbol_character_set_name : SYMBOL", "symbol_collation_name : SYMBOL", "symbol_column_name : SYMBOL", "symbol_constraint_name : SYMBOL", "symbol_cursor_name : SYMBOL", "symbol_domain_name : SYMBOL", "symbol_exception_name : SYMBOL", "symbol_filter_name : SYMBOL", "symbol_gdscode_name : SYMBOL", "symbol_generator_name : SYMBOL", "symbol_index_name : SYMBOL", "symbol_item_alias_name : SYMBOL", "symbol_procedure_name : SYMBOL", "symbol_role_name : SYMBOL", "symbol_table_alias_name : SYMBOL", "symbol_table_name : SYMBOL", "symbol_trigger_name : SYMBOL", "symbol_user_name : SYMBOL", "symbol_variable_name : SYMBOL", "symbol_view_name : SYMBOL", }; #endif #ifndef YYSTYPE typedef int YYSTYPE; #endif #ifdef YYSTACKSIZE #undef YYMAXDEPTH #define YYMAXDEPTH YYSTACKSIZE #else #ifdef YYMAXDEPTH #define YYSTACKSIZE YYMAXDEPTH #else #define YYSTACKSIZE 500 #define YYMAXDEPTH 500 #endif #endif static int yydebug; static int yynerrs; #ifndef SHLIB_DEFS int DSQL_yyerrflag; #endif #ifndef SHLIB_DEFS int DSQL_yychar; #endif short *DSQL_DSQL_yyssp; static YYSTYPE *yyvsp; static YYSTYPE yyval; static YYSTYPE yylval; static short DSQL_yyss[YYSTACKSIZE]; static YYSTYPE yyvs[YYSTACKSIZE]; #define yystacksize YYSTACKSIZE /* * PROGRAM: Dynamic SQL runtime support * MODULE: lex.c * DESCRIPTION: Lexical routine * */ #include "../dsql/chars.h" #define MAX_TOKEN_LEN 256 #define CHECK_BOUND(to)\ {\ if ((to - string) >= MAX_TOKEN_LEN) \ yyabandon (-104, isc_token_too_long); \ } #define CHECK_COPY_INCR(to,ch){CHECK_BOUND(to); *to++=ch;} static TEXT *lex_position (void); static BOOLEAN long_int (NOD, SLONG *); static FLD make_field (NOD); static FIL make_file (void); static NOD make_list (NOD); static NOD make_node (NOD_TYPE, int, ...); static NOD make_flag_node (NOD_TYPE, SSHORT, int, ...); static BOOLEAN short_int (NOD, SLONG *, SSHORT); static void stack_nodes (NOD, DLLS*); static int yylex (USHORT, USHORT, USHORT, BOOLEAN *); static void yyerror (TEXT*); static void yyabandon (SSHORT, STATUS); static void check_log_file_attrs (void); static TEXT *ptr, *end, *last_token, *line_start; static SSHORT lines, att_charset; // TMN: Temp hack #if (defined(_MSC_VER) || defined(__BORLANDC__)) && defined(CONST) #undef CONST #define CONST #endif typedef struct tok { USHORT tok_ident; CONST SCHAR *tok_string; CONST USHORT tok_version; } TOK; static CONST TOK tokens [] = { #include "../dsql/keywords.h" {0, 0, 0} }; void LEX_dsql_init (void) { /************************************** * * L E X _ d s q l _ i n i t * ************************************** * * Functional description * Initialize LEX for processing. This is called only once * per session. * **************************************/ CONST TOK *token; for (token = tokens; token->tok_string; ++token) { SYM symbol; STR str_; symbol = new(*DSQL_permanent_pool, 0) sym; symbol->sym_string = (TEXT *) token->tok_string; symbol->sym_length = strlen (token->tok_string); symbol->sym_type = SYM_keyword; symbol->sym_keyword = token->tok_ident; symbol->sym_version = token->tok_version; str_ = new(*DSQL_permanent_pool, symbol->sym_length) str; str_->str_length = symbol->sym_length; strncpy ((char*)str_->str_data, (char*)symbol->sym_string, symbol->sym_length); symbol->sym_object = (void *) str_; HSHD_insert (symbol); } } void LEX_string ( TEXT *string, USHORT length, SSHORT character_set) { /************************************** * * L E X _ s t r i n g * ************************************** * * Functional description * Initialize LEX to process a string. * **************************************/ line_start = ptr = string; end = string + length; lines = 1; att_charset = character_set; } static void check_log_file_attrs (void) { /********************************************** * * c h e c k _ l o g _ f i l e _ a t t r s * ********************************************** * * Functional description * Check if log file attributes are valid * *********************************************/ if (file->fil_partitions) { if (!file->fil_length) { yyabandon (-261, isc_log_length_spec); /* Total length of a partitioned log must be specified */ } if (PARTITION_SIZE (OneK*file->fil_length,file->fil_partitions) < (OneK*MIN_LOG_LENGTH)) { yyabandon (-239, isc_partition_too_small); /* Log partition size too small */ } } else { if ((file->fil_length) && (file->fil_length < MIN_LOG_LENGTH)) { yyabandon (-239, isc_log_too_small); /* Log size too small */ } } } static TEXT *lex_position (void) { /************************************** * * l e x _ p o s i t i o n * ************************************** * * Functional description * Return the current position of LEX * in the input string. * **************************************/ return ptr; } static BOOLEAN long_int ( NOD string, SLONG *long_value) { /************************************* * * l o n g _ i n t * ************************************* * * Functional description * checks for all digits in the * number and return an atol(). * *************************************/ UCHAR *p; for (p = ((STR) string)->str_data; classes [*p] & CHR_DIGIT; p++) if (!(classes [*p] & CHR_DIGIT)) return FALSE; *long_value = atol ((char *)((STR) string)->str_data); return TRUE; } static FLD make_field ( NOD field_name) { /************************************** * * m a k e _ f i e l d * ************************************** * * Functional description * Make a field block of given name. * **************************************/ FLD field; STR string; TSQL tdsql; tdsql = GET_THREAD_DATA; if (field_name == NULL) { field = new(*tdsql->tsql_default, sizeof (INTERNAL_FIELD_NAME)) fld; strcpy (field->fld_name, (TEXT*) INTERNAL_FIELD_NAME); return field; } string = (STR) field_name->nod_arg [1]; field = new(*tdsql->tsql_default, strlen ((SCHAR*) string->str_data)) fld; strcpy (field->fld_name, (TEXT*) string->str_data); return field; } static FIL make_file (void) { /************************************** * * m a k e _ f i l e * ************************************** * * Functional description * Make a file block * **************************************/ FIL temp_file; TSQL tdsql; tdsql = GET_THREAD_DATA; temp_file = new(*tdsql->tsql_default) fil; return temp_file; } static NOD make_list ( NOD node) { /************************************** * * m a k e _ l i s t * ************************************** * * Functional description * Collapse nested list nodes into single list. * **************************************/ NOD* ptr; DLLS stack, temp; USHORT l; NOD old; TSQL tdsql; tdsql = GET_THREAD_DATA; if (!node) return node; stack = 0; stack_nodes (node, &stack); for (l = 0, temp = stack; temp; temp = temp->lls_next) l++; old = node; node = new(*tdsql->tsql_default, l) nod; node->nod_count = l; node->nod_type = nod_list; node->nod_flags = old->nod_flags; ptr = node->nod_arg + node->nod_count; while (stack) *--ptr = (NOD) LLS_POP (&stack); return node; } static NOD make_node ( NOD_TYPE type, int count, ...) { /************************************** * * m a k e _ n o d e * ************************************** * * Functional description * Make a node of given type. * Any change should also be made to function below * **************************************/ NOD node, *p; va_list ptr; TSQL tdsql; tdsql = GET_THREAD_DATA; node = new (*tdsql->tsql_default, count) nod; node->nod_type = type; node->nod_count = count; p = node->nod_arg; VA_START (ptr, count); while (--count >= 0) *p++ = va_arg (ptr, NOD); return node; } static NOD make_flag_node ( NOD_TYPE type, SSHORT flag, int count, ...) { /************************************** * * m a k e _ f l a g _ n o d e * ************************************** * * Functional description * Make a node of given type. Set flag field * **************************************/ NOD node, *p; va_list ptr; TSQL tdsql; tdsql = GET_THREAD_DATA; node = new(*tdsql->tsql_default, count) nod; node->nod_type = type; node->nod_flags = flag; node->nod_count = count; p = node->nod_arg; VA_START (ptr, count); while (--count >= 0) *p++ = va_arg (ptr, NOD); return node; } static BOOLEAN short_int ( NOD string, SLONG *long_value, SSHORT range) { /************************************* * * s h o r t _ i n t * ************************************* * * Functional description * is the string a valid representation * of a positive short int? * *************************************/ UCHAR *p; SCHAR buf [10]; BOOLEAN return_value; if (((STR) string)->str_length > 5) return FALSE; for (p = ((STR) string)->str_data; classes [*p] & CHR_DIGIT; p++) if (!(classes [*p] & CHR_DIGIT)) return FALSE; /* there are 5 or fewer digits, it's value may still be greater * than 32767... */ buf [0] = ((STR) string)->str_data[0]; buf [1] = ((STR) string)->str_data[1]; buf [2] = ((STR) string)->str_data[2]; buf [3] = ((STR) string)->str_data[3]; buf [4] = ((STR) string)->str_data[4]; buf [5] = '\0'; *long_value = atoi (buf); switch (range) { case POSITIVE: return_value = *long_value > SHRT_POS_MAX; break; case NEGATIVE: return_value = *long_value > SHRT_NEG_MAX; break; case UNSIGNED: return_value = *long_value > SHRT_UNSIGNED_MAX; break; } return !return_value; } static void stack_nodes ( NOD node, DLLS *stack) { /************************************** * * s t a c k _ n o d e s * ************************************** * * Functional description * Assist in turning a tree of misc nodes into a clean list. * **************************************/ NOD *ptr, *end; NOD curr_node, next_node, start_chain, end_chain, save_link; if (node->nod_type != nod_list) { LLS_PUSH (node, stack); return; } /* To take care of cases where long lists of nodes are in a chain of list nodes with exactly one entry, this algorithm will look for a pattern of repeated list nodes with two entries, the first being a list node and the second being a non-list node. Such a list will be reverse linked, and then re-reversed, stacking the non-list nodes in the process. The purpose of this is to avoid massive recursion of this function. */ start_chain = node; end_chain = (NOD) NULL; curr_node = node; next_node = node->nod_arg[0]; while ( curr_node->nod_count == 2 && curr_node->nod_arg[0]->nod_type == nod_list && curr_node->nod_arg[1]->nod_type != nod_list && next_node->nod_arg[0]->nod_type == nod_list && next_node->nod_arg[1]->nod_type != nod_list) { /* pattern was found so reverse the links and go to next node */ save_link = next_node->nod_arg[0]; next_node->nod_arg[0] = curr_node; curr_node = next_node; next_node = save_link; end_chain = curr_node; } /* see if any chain was found */ if ( end_chain) { /* first, handle the rest of the nodes */ /* note that next_node still points to the first non-pattern node */ stack_nodes( next_node, stack); /* stack the non-list nodes and reverse the chain on the way back */ curr_node = end_chain; while ( TRUE) { LLS_PUSH( curr_node->nod_arg[1], stack); if ( curr_node == start_chain) break; save_link = curr_node->nod_arg[0]; curr_node->nod_arg[0] = next_node; next_node = curr_node; curr_node = save_link; } return; } for (ptr = node->nod_arg, end = ptr + node->nod_count; ptr < end; ptr++) stack_nodes (*ptr, stack); } static int yylex ( USHORT client_dialect, USHORT db_dialect, USHORT parser_version, BOOLEAN *stmt_ambiguous) { /************************************** * * y y l e x * ************************************** * * Functional description * **************************************/ UCHAR *p, tok_class, string [MAX_TOKEN_LEN], *buffer, *buffer_end, *new_buffer; SYM sym; SSHORT c; USHORT buffer_len; STR delimited_id_str; /* Find end of white space and skip comments */ for (;;) { if (ptr >= end) return -1; c = *ptr++; if (c == '\n') { lines++; line_start = ptr + 1; } if ((c == '/') && (*ptr == '*')) { ptr++; while (ptr < end) { if ((c = *ptr++) == '*') { if (*ptr == '/') break; } if (c == '\n') { lines++; line_start = ptr + 1; } } if (ptr >= end) return -1; ptr++; continue; } #if (! ( defined JPN_SJIS || defined JPN_EUC) ) tok_class = classes [c]; #else c = c & 0xff; tok_class = (JPN1_CHAR(c) ? CHR_LETTER : classes[c]); #endif /*JPN_SJIS || JPN_EUC */ if (!(tok_class & CHR_WHITE)) break; } /* Depending on tok_class of token, parse token */ last_token = ptr - 1; if (tok_class & CHR_INTRODUCER) { /* The Introducer (_) is skipped, all other idents are copied * to become the name of the character set */ p = string; for (; ptr < end && classes [*ptr] & CHR_IDENT; ptr++) { if (ptr >= end) return -1; CHECK_COPY_INCR(p, UPPER7(*ptr)); } CHECK_BOUND(p); *p = 0; /* make a string value to hold the name, the name * is resolved in pass1_constant */ yylval = (NOD) (MAKE_string (string, p - string))->str_data; return INTRODUCER; } /* parse a quoted string, being sure to look for double quotes */ if (tok_class & CHR_QUOTE) { buffer = string; buffer_len = sizeof (string); buffer_end = buffer + buffer_len - 1; for (p = buffer; ; p++) { if (ptr >= end) { if (buffer != string) gds__free (buffer); return -1; } /* *ptr is quote - if next != quote we're at the end */ if ((*ptr == c) && ((++ptr == end) || (*ptr != c))) break; if (p > buffer_end) { new_buffer = (UCHAR *) gds__alloc (2 * buffer_len); /* FREE: at outer block */ if (!new_buffer) /* NOMEM: */ { if (buffer != string) gds__free (buffer); return -1; } memcpy (new_buffer, buffer, buffer_len); if (buffer != string) gds__free (buffer); buffer = new_buffer; p = buffer + buffer_len; buffer_len = 2 * buffer_len; buffer_end = buffer + buffer_len - 1; } *p = *ptr++; } if (c == '"') { *stmt_ambiguous = TRUE; /* string delimited by double quotes could be ** either a string constant or a SQL delimited ** identifier, therefore marks the SQL ** statement as ambiguous */ if (client_dialect == SQL_DIALECT_V6_TRANSITION) { if (buffer != string) gds__free (buffer); yyabandon (-104, isc_invalid_string_constant); } else if (client_dialect >= SQL_DIALECT_V6) { if ((p - buffer) >= MAX_TOKEN_LEN) { if (buffer != string) gds__free (buffer); yyabandon (-104, isc_token_too_long); } yylval = (NOD) MAKE_string (buffer, p - buffer); delimited_id_str = (STR) yylval; delimited_id_str->str_flags |= STR_delimited_id; if (buffer != string) gds__free (buffer); return SYMBOL; } } yylval = (NOD) MAKE_string (buffer, p - buffer); if (buffer != string) gds__free (buffer); return STRING; } /* * Check for a numeric constant, which starts either with a digit or with * a decimal point followed by a digit. * * This code recognizes the following token types: * * NUMBER: string of digits which fits into a 32-bit integer * * NUMBER64BIT: string of digits whose value might fit into an SINT64, * depending on whether or not there is a preceding '-', which is to * say that "9223372036854775808" is accepted here. * * SCALEDINT: string of digits and a single '.', where the digits * represent a value which might fit into an SINT64, depending on * whether or not there is a preceding '-'. * * FLOAT: string of digits with an optional '.', and followed by an "e" * or "E" and an optionally-signed exponent. * * NOTE: we swallow leading or trailing blanks, but we do NOT accept * embedded blanks: * * Another note: c is the first character which need to be considered, * ptr points to the next character. */ assert(ptr <= end); if ((tok_class & CHR_DIGIT) || ((c == '.') && (ptr < end) && (classes [*ptr] & CHR_DIGIT))) { /* The following variables are used to recognize kinds of numbers. */ BOOLEAN have_error = FALSE; /* syntax error or value too large */ BOOLEAN have_digit = FALSE; /* we've seen a digit */ BOOLEAN have_decimal = FALSE; /* we've seen a '.' */ BOOLEAN have_exp = FALSE; /* digit ... [eE] */ BOOLEAN have_exp_sign = FALSE; /* digit ... [eE] {+-] */ BOOLEAN have_exp_digit = FALSE; /* digit ... [eE] ... digit */ UINT64 number = 0; UINT64 limit_by_10 = MAX_SINT64 / 10; for (--ptr ; ptr < end ; ptr++) { c = *ptr; if (have_exp_digit && (! (classes [c] & CHR_DIGIT))) /* First non-digit after exponent and digit terminates the token. */ break; else if (have_exp_sign && (! (classes [c] & CHR_DIGIT))) { /* only digits can be accepted after "1E-" */ have_error = TRUE; break; } else if (have_exp) { /* We've seen e or E, but nothing beyond that. */ if ( ('-' == c) || ('+' == c) ) have_exp_sign = TRUE; else if ( classes [c] & CHR_DIGIT ) /* We have a digit: we haven't seen a sign yet, but it's too late now. */ have_exp_digit = have_exp_sign = TRUE; else { /* end of the token */ have_error = TRUE; break; } } else if ('.' == c) { if (!have_decimal) have_decimal = TRUE; else { have_error = TRUE; break; } } else if (classes [c] & CHR_DIGIT) { /* Before computing the next value, make sure there will be no overflow. */ have_digit = TRUE; if (number >= limit_by_10) /* possibility of an overflow */ if ((number > limit_by_10) || (c > '8')) { have_error = TRUE; break; } number = number * 10 + (c - '0'); } else if ( (('E' == c) || ('e' == c)) && have_digit ) have_exp = TRUE; else /* Unexpected character: this is the end of the number. */ break; } /* We're done scanning the characters: now return the right kind of number token, if any fits the bill. */ if (!have_error) { assert(have_digit); if (have_exp_digit) { yylval = (NOD) MAKE_string ((UCHAR *) last_token, ptr - last_token); return FLOAT; } else if (!have_exp) { /* We should return some kind (scaled-) integer type except perhaps in dialect 1. */ if (!have_decimal && (number <= MAX_SLONG)) { yylval = (NOD) number; return NUMBER; } else { /* We have either a decimal point with no exponent or a string of digits whose value exceeds MAX_SLONG: the returned type depends on the client dialect, so warn of the difference if the client dialect is SQL_DIALECT_V6_TRANSITION. */ if (SQL_DIALECT_V6_TRANSITION == client_dialect) { /* Issue a warning about the ambiguity of the numeric * numeric literal. There are multiple calls because * the message text exceeds the 119-character limit * of our message database. */ ERRD_post_warning( isc_dsql_warning_number_ambiguous, gds_arg_string, ERR_string( last_token, ptr - last_token ), gds_arg_end ); ERRD_post_warning( isc_dsql_warning_number_ambiguous1, gds_arg_end ); } yylval = (NOD) MAKE_string ((UCHAR *) last_token, ptr - last_token); if (client_dialect < SQL_DIALECT_V6_TRANSITION) return FLOAT; else if (have_decimal) return SCALEDINT; else return NUMBER64BIT; } } /* else if (!have_exp) */ } /* if (!have_error) */ /* we got some kind of error or overflow, so don't recognize this * as a number: just pass it through to the next part of the lexer. */ } /* Restore the status quo ante, before we started our unsuccessful attempt to recognize a number. */ ptr = last_token; c = *ptr++; /* We never touched tok_class, so it doesn't need to be restored. */ /* end of number-recognition code */ if (tok_class & CHR_LETTER) { #if (! ( defined JPN_SJIS || defined JPN_EUC) ) p = string; CHECK_COPY_INCR(p,UPPER (c)); for (; ptr < end && classes [*ptr] & CHR_IDENT; ptr++) { if (ptr >= end) return -1; CHECK_COPY_INCR(p, UPPER (*ptr)); } #else for (; ptr <= end ; c = *ptr++ , c = c & 0xff) { if (KANJI1(c)) { CHECK_COPY_INCR(p, UPPER (c)); if (ptr >= end) break; c = *ptr++; c = c & 0xff; if (!KANJI2(c)) { ptr--; break; } else CHECK_COPY_INCR(p,c); } else { #ifdef JPN_SJIS if ((SJIS_SINGLE(c)) || (classes[c] & CHR_IDENT) ) #else if (classes[c] & CHR_IDENT) #endif { CHECK_COPY_INCR(p, UPPER(c)); if (ptr >= end) break; } else { ptr--; break; } } } #endif /* JPN_SJIS || JPN_EUC */ CHECK_BOUND(p); *p = 0; sym = HSHD_lookup (NULL_PTR, (TEXT *) string, (SSHORT)(p - string), SYM_keyword, parser_version); if (sym) { yylval = (NOD) sym->sym_object; return sym->sym_keyword; }; yylval = (NOD) MAKE_string (string, p - string); return SYMBOL; } /* Must be punctuation -- test for double character punctuation */ if (last_token + 1 < end) { sym = HSHD_lookup (NULL_PTR, last_token, (SSHORT) 2, SYM_keyword, (USHORT) parser_version); if (sym) { ++ptr; return sym->sym_keyword; } } /* Single character punctuation are simply passed on */ return c; } static void yyerror ( TEXT *error_string) { /************************************** * * y y e r r o r * ************************************** * * Functional description * Print a syntax error. * **************************************/ if (DSQL_yychar < 1) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, gds_command_end_err, /* Unexpected end of command */ 0); else { ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, gds_dsql_token_unk_err, gds_arg_number, (SLONG) lines, gds_arg_number, (SLONG) (last_token - line_start), /* Token unknown - line %d, char %d */ gds_arg_gds, gds_random, gds_arg_cstring, (int) (ptr - last_token), last_token, 0); } } static void yyabandon ( SSHORT sql_code, STATUS error_symbol) { /************************************** * * y y a b a n d o n * ************************************** * * Functional description * Abandon the parsing outputting the supplied string * **************************************/ ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) sql_code, gds_arg_gds, error_symbol, 0); } #define YYABORT goto yyabort #define YYREJECT goto yyabort #define YYACCEPT goto yyaccept #define YYERROR goto yyerrlab int dsql_yyparse(USHORT client_dialect, USHORT db_dialect, USHORT parser_version, BOOLEAN *stmt_ambiguous) { register int yym, yyn, yystate; #if YYDEBUG register char *yys; if (yys = getenv("YYDEBUG")) { yyn = *yys; if (yyn >= '0' && yyn <= '9') yydebug = yyn - '0'; } #endif yynerrs = 0; DSQL_yyerrflag = 0; DSQL_yychar = (-1); DSQL_DSQL_yyssp = DSQL_yyss; yyvsp = yyvs; *DSQL_DSQL_yyssp = yystate = 0; yyloop: if (yyn = yydefred[yystate]) goto yyreduce; if (DSQL_yychar < 0) { if ((DSQL_yychar = yylex(client_dialect, db_dialect, parser_version, stmt_ambiguous)) < 0) DSQL_yychar = 0; #if YYDEBUG if (yydebug) { yys = 0; if (DSQL_yychar <= YYMAXTOKEN) yys = yyname[DSQL_yychar]; if (!yys) yys = "illegal-symbol"; printf("%sdebug: state %d, reading %d (%s)\n", YYPREFIX, yystate, DSQL_yychar, yys); } #endif } if ((yyn = yysindex[yystate]) && (yyn += DSQL_yychar) >= 0 && yyn <= YYTABLESIZE && yycheck[yyn] == DSQL_yychar) { #if YYDEBUG if (yydebug) printf("%sdebug: state %d, shifting to state %d\n", YYPREFIX, yystate, yytable[yyn]); #endif if (DSQL_DSQL_yyssp >= DSQL_yyss + yystacksize - 1) { goto yyoverflow; } *++DSQL_DSQL_yyssp = yystate = yytable[yyn]; *++yyvsp = yylval; DSQL_yychar = (-1); if (DSQL_yyerrflag > 0) --DSQL_yyerrflag; goto yyloop; } if ((yyn = yyrindex[yystate]) && (yyn += DSQL_yychar) >= 0 && yyn <= YYTABLESIZE && yycheck[yyn] == DSQL_yychar) { yyn = yytable[yyn]; goto yyreduce; } if (DSQL_yyerrflag) goto yyinrecovery; #ifdef lint goto yynewerror; yynewerror: #endif yyerror("syntax error"); #ifdef lint goto yyerrlab; yyerrlab: #endif ++yynerrs; yyinrecovery: if (DSQL_yyerrflag < 3) { DSQL_yyerrflag = 3; for (;;) { if ((yyn = yysindex[*DSQL_DSQL_yyssp]) && (yyn += YYERRCODE) >= 0 && yyn <= YYTABLESIZE && yycheck[yyn] == YYERRCODE) { #if YYDEBUG if (yydebug) printf("%sdebug: state %d, error recovery shifting\ to state %d\n", YYPREFIX, *DSQL_DSQL_yyssp, yytable[yyn]); #endif if (DSQL_DSQL_yyssp >= DSQL_yyss + yystacksize - 1) { goto yyoverflow; } *++DSQL_DSQL_yyssp = yystate = yytable[yyn]; *++yyvsp = yylval; goto yyloop; } else { #if YYDEBUG if (yydebug) printf("%sdebug: error recovery discarding state %d\n", YYPREFIX, *DSQL_DSQL_yyssp); #endif if (DSQL_DSQL_yyssp <= DSQL_yyss) goto yyabort; --DSQL_DSQL_yyssp; --yyvsp; } } } else { if (DSQL_yychar == 0) goto yyabort; #if YYDEBUG if (yydebug) { yys = 0; if (DSQL_yychar <= YYMAXTOKEN) yys = yyname[DSQL_yychar]; if (!yys) yys = "illegal-symbol"; printf("%sdebug: state %d, error recovery discards token %d (%s)\n", YYPREFIX, yystate, DSQL_yychar, yys); } #endif DSQL_yychar = (-1); goto yyloop; } yyreduce: #if YYDEBUG if (yydebug) printf("%sdebug: state %d, reducing by rule %d (%s)\n", YYPREFIX, yystate, yyn, yyrule[yyn]); #endif yym = yylen[yyn]; yyval = yyvsp[1-yym]; switch (yyn) { case 1: { DSQL_parse = yyvsp[0]; } break; case 2: { DSQL_parse = yyvsp[-1]; } break; case 18: { DSQL_debug = (int) yyvsp[0]; if (DSQL_debug > 10) yydebug = DSQL_debug; yyval = make_node (nod_null, (int) 0, NULL); } break; case 19: { yyval = make_node (nod_grant, (int) e_grant_count, yyvsp[-5], yyvsp[-3], make_list(yyvsp[-1]), yyvsp[0]); } break; case 20: { yyval = make_node (nod_grant, (int) e_grant_count, yyvsp[-6], yyvsp[-3], make_list(yyvsp[-1]), yyvsp[0]); } break; case 21: { yyval = make_node (nod_grant, (int) e_grant_count, yyvsp[-4], yyvsp[-2], make_list(yyvsp[0]), NULL); } break; case 22: { yyval = make_node (nod_grant, (int) e_grant_count, yyvsp[-5], yyvsp[-2], make_list(yyvsp[0]), NULL); } break; case 23: { yyval = make_node (nod_grant, (int) e_grant_count, make_list(yyvsp[-3]), make_list(yyvsp[-1]), NULL, yyvsp[0]); } break; case 25: { yyval = yyvsp[0]; } break; case 26: { yyval = make_node (nod_all, (int) 0, NULL); } break; case 27: { yyval = make_node (nod_all, (int) 0, NULL); } break; case 28: { yyval = make_list (yyvsp[0]); } break; case 30: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 31: { yyval = make_list (make_node (nod_execute, (int) 0, NULL)); } break; case 32: { yyval = make_node (nod_select, (int) 0, NULL); } break; case 33: { yyval = make_node (nod_insert, (int) 0, NULL); } break; case 34: { yyval = make_node (nod_delete, (int) 0, NULL); } break; case 35: { yyval = make_node (nod_update, (int) 1, yyvsp[0]); } break; case 36: { yyval = make_node (nod_references, (int) 1, yyvsp[0]); } break; case 37: { yyval = make_node (nod_grant, (int) 0, NULL); } break; case 38: { yyval = 0; } break; case 39: { yyval = make_node (nod_grant_admin, (int) 0, NULL); } break; case 40: { yyval = 0; } break; case 41: { yyval = make_node (nod_procedure_name, (int) 1, yyvsp[0]); } break; case 42: { yyval = make_node (nod_revoke, (int) e_grant_count, yyvsp[-4], yyvsp[-2], make_list(yyvsp[0]), yyvsp[-5]); } break; case 43: { yyval = make_node (nod_revoke, (int) e_grant_count, yyvsp[-5], yyvsp[-2], make_list(yyvsp[0]), yyvsp[-6]); } break; case 44: { yyval = make_node (nod_revoke, (int) e_grant_count, yyvsp[-4], yyvsp[-2], make_list(yyvsp[0]), NULL); } break; case 45: { yyval = make_node (nod_revoke, (int) e_grant_count, yyvsp[-5], yyvsp[-2], make_list(yyvsp[0]), NULL); } break; case 46: { yyval = make_node (nod_revoke, (int) e_grant_count, yyvsp[-4], yyvsp[-2], make_list(yyvsp[0]), NULL); } break; case 47: { yyval = make_node (nod_revoke, (int) e_grant_count, yyvsp[-5], yyvsp[-2], make_list(yyvsp[0]), NULL); } break; case 48: { yyval = make_node (nod_revoke, (int) e_grant_count, make_list(yyvsp[-2]), make_list(yyvsp[0]), NULL, NULL); } break; case 49: { yyval = make_node (nod_grant, (int) 0, NULL); } break; case 51: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 52: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 53: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 54: { yyval = make_node (nod_proc_obj, (int) 1, yyvsp[0]); } break; case 55: { yyval = make_node (nod_trig_obj, (int) 1, yyvsp[0]); } break; case 56: { yyval = make_node (nod_view_obj, (int) 1, yyvsp[0]); } break; case 58: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 59: { yyval = make_node (nod_user_name, (int) 1, yyvsp[0]); } break; case 60: { yyval = make_node (nod_user_name, (int) 1, yyvsp[0]); } break; case 61: { yyval = make_node (nod_user_group, (int) 1, yyvsp[0]); } break; case 63: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 64: { yyval = make_node (nod_role_name, (int) 1, yyvsp[0]); } break; case 66: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 67: { yyval = make_node (nod_user_name, (int) 1, yyvsp[0]); } break; case 68: { yyval = make_node (nod_user_name, (int) 1, yyvsp[0]); } break; case 69: { yyval = yyvsp[0];} break; case 70: { yyval = yyvsp[0]; } break; case 71: { yyval = yyvsp[0]; } break; case 72: { yyval = make_node (nod_def_udf, (int) e_udf_count, yyvsp[-7], yyvsp[-2], yyvsp[0], make_list (yyvsp[-6]), yyvsp[-4]); } break; case 74: { field->fld_dtype = dtype_blob; } break; case 75: { field->fld_dtype = dtype_cstring; field->fld_character_length = (USHORT) yyvsp[-2]; } break; case 76: { yyval = (NOD) NULL; } break; case 78: { yyval = yyvsp[-1]; } break; case 80: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 81: { yyval = yyvsp[-1]; } break; case 83: { yyval = yyvsp[-1]; } break; case 84: { yyval = make_node (nod_udf_return_value, (int) 2, yyvsp[-1], MAKE_constant ((STR) FUN_reference, CONSTANT_SLONG));} break; case 85: { yyval = make_node (nod_udf_return_value, (int) 2, yyvsp[-2], MAKE_constant ((STR) (-1 * FUN_reference), CONSTANT_SLONG));} break; case 86: { yyval = make_node (nod_udf_return_value, (int) 2, yyvsp[-3], MAKE_constant ((STR) FUN_value, CONSTANT_SLONG));} break; case 87: { yyval = make_node (nod_udf_return_value, (int) 2, (NOD) NULL, MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG));} break; case 88: { yyval = make_node (nod_def_filter, (int) e_filter_count, yyvsp[-8], yyvsp[-6], yyvsp[-4], yyvsp[-2], yyvsp[0]); } break; case 89: { yyval = yyvsp[0]; } break; case 90: { yyval = make_node (nod_def_exception, (int) e_xcp_count, yyvsp[-1], yyvsp[0]); } break; case 91: { yyval = make_node (nod_def_index, (int) e_idx_count, yyvsp[-6], yyvsp[-5], yyvsp[-3], yyvsp[-1], yyvsp[0]); } break; case 92: { yyval = yyvsp[0]; } break; case 93: { yyval = yyvsp[0]; } break; case 94: { yyval = yyvsp[0]; } break; case 95: { yyval = yyvsp[0]; } break; case 96: { yyval = yyvsp[0]; } break; case 97: { yyval = yyvsp[0]; } break; case 98: { yyval = yyvsp[0]; } break; case 99: { yyval = yyvsp[0]; } break; case 100: { yyval = yyvsp[0]; } break; case 101: { yyval = make_node (nod_unique, (int) 0, NULL); } break; case 102: { yyval = NULL; } break; case 103: { yyval = make_list (yyvsp[0]); } break; case 105: { yyval = make_node (nod_def_computed, 2, yyvsp[-2], yyvsp[-1]); } break; case 106: { yyval = make_node (nod_def_shadow, (int) e_shadow_count, yyvsp[-5], yyvsp[-4], yyvsp[-3], yyvsp[-2], yyvsp[-1], make_list (yyvsp[0])); } break; case 107: { yyval = MAKE_constant ((STR) 1, CONSTANT_SLONG); } break; case 108: { yyval = MAKE_constant ((STR) 0, CONSTANT_SLONG); } break; case 109: { yyval = MAKE_constant ((STR) 0, CONSTANT_SLONG); } break; case 110: { yyval = MAKE_constant ((STR) 0, CONSTANT_SLONG); } break; case 111: { yyval = MAKE_constant ((STR) 1, CONSTANT_SLONG); } break; case 112: { yyval = (NOD) 0;} break; case 113: { yyval = yyvsp[-1]; } break; case 114: { yyval = (NOD) NULL; } break; case 117: { yyval = make_node (nod_list, (int) 2, yyvsp[-1], yyvsp[0]); } break; case 118: { yyval = make_node (nod_def_domain, (int) e_dom_count, yyvsp[-7], yyvsp[-3], yyvsp[-2], make_list (yyvsp[-1]), yyvsp[0]); } break; case 119: { yyval = NULL; } break; case 120: { yyval = NULL; } break; case 121: { yyval = yyvsp[0]; } break; case 122: { yyval = (NOD) NULL; } break; case 123: { yyval = (NOD) NULL; } break; case 126: { yyval = make_node (nod_list, (int) 2, yyvsp[-1], yyvsp[0]); } break; case 127: { yyval = make_node (nod_rel_constraint, (int) 2, NULL, yyvsp[0]);} break; case 130: { yyval = make_node (nod_null, (int) 0, NULL); } break; case 131: { yyval = make_node (nod_def_constraint, (int) e_cnstr_count, MAKE_string (NULL_STRING, 0), NULL, NULL, NULL, yyvsp[-2], NULL, yyvsp[0], NULL, NULL); } break; case 132: { yyval = make_node (nod_def_generator, (int) e_gen_count, yyvsp[0]); } break; case 133: { yyval = make_node (nod_def_role, (int) 1, yyvsp[0]); } break; case 134: { yyval = make_node (nod_def_database, (int) e_cdb_count, yyvsp[-2], make_list(yyvsp[-1]), make_list (yyvsp[0]));} break; case 137: { log_defined = FALSE; cache_defined = FALSE; yyval = (NOD) yyvsp[0]; } break; case 138: {yyval = (NOD) NULL;} break; case 141: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 142: { yyval = make_node (nod_page_size, 1, yyvsp[0]);} break; case 143: { yyval = make_node (nod_file_length, 1, yyvsp[-1]);} break; case 144: { yyval = make_node (nod_user_name, 1, yyvsp[0]);} break; case 145: { yyval = make_node (nod_password, 1, yyvsp[0]);} break; case 146: { yyval = make_node (nod_lc_ctype, 1, yyvsp[0]);} break; case 147: {yyval = (NOD) NULL;} break; case 150: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 154: { yyval = make_node (nod_dfl_charset, 1, yyvsp[0]);} break; case 155: { yyval = make_node (nod_group_commit_wait, 1, yyvsp[0]);} break; case 156: { yyval = make_node (nod_check_point_len, 1, yyvsp[0]);} break; case 157: { yyval = make_node (nod_num_log_buffers, 1, yyvsp[0]);} break; case 158: { yyval = make_node (nod_log_buffer_size, 1, yyvsp[0]);} break; case 159: { if (log_defined) yyabandon (-260, isc_log_redef); /* Log redefined */ log_defined = TRUE; yyval = yyvsp[0]; } break; case 160: { if (log_defined) yyabandon (-260, isc_log_redef); log_defined = TRUE; yyval = yyvsp[0]; } break; case 161: { file->fil_flags |= LOG_serial | LOG_overflow; if (file->fil_partitions) yyabandon (-261, isc_partition_not_supp); /* Partitions not supported in series of log file specification */ yyval = make_node (nod_list, 2, yyvsp[-3], yyvsp[0]); } break; case 162: { file->fil_flags |= LOG_serial; if (file->fil_partitions) yyabandon (-261, isc_partition_not_supp); yyval = yyvsp[0]; } break; case 163: { file = make_file(); file->fil_flags = LOG_serial | LOG_default; yyval = make_node (nod_log_file_desc, (int) 1, (NOD) file);} break; case 164: { file->fil_name = (STR) yyvsp[-1]; yyval = (NOD) make_node (nod_file_desc, (int) 1, (NOD) file); } break; case 166: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 167: { check_log_file_attrs(); yyval = (NOD) make_node (nod_log_file_desc, (int) 1, (NOD) file); } break; case 168: { file = make_file(); file->fil_name = (STR) yyvsp[0]; } break; case 171: { file->fil_length = (SLONG) yyvsp[0]; } break; case 172: { file = make_file ();} break; case 177: { file->fil_start = (SLONG) yyvsp[0];} break; case 178: { file->fil_length = (SLONG) yyvsp[-1];} break; case 185: { yyval = make_node (nod_def_relation, (int) e_drl_count, yyvsp[-4], make_list (yyvsp[-1]), yyvsp[-3]); } break; case 186: { yyval = yyvsp[0]; } break; case 187: { yyval = yyvsp[0]; } break; case 188: { yyval = (NOD) NULL; } break; case 190: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 193: { yyval = make_node (nod_def_field, (int) e_dfl_count, yyvsp[-5], yyvsp[-3], yyvsp[-2], make_list (yyvsp[-1]), yyvsp[0], yyvsp[-4], NULL); } break; case 194: { yyval = make_node (nod_def_field, (int) e_dfl_count, yyvsp[-2], NULL, NULL, NULL, NULL, NULL, yyvsp[0]); } break; case 195: { yyval = make_node (nod_def_field, (int) e_dfl_count, yyvsp[-1], NULL, NULL, NULL, NULL, NULL, yyvsp[0]); } break; case 196: { field->fld_flags |= FLD_computed; yyval = make_node (nod_def_computed, 2, yyvsp[-2], yyvsp[-1]); } break; case 199: { yyval = NULL; } break; case 200: { yyval = make_node (nod_def_domain, (int) e_dom_count, yyvsp[-1], NULL, NULL, NULL, NULL); } break; case 201: { yyval = yyvsp[0]; } break; case 202: { yyval = (NOD) NULL; } break; case 203: { field_name = yyvsp[0]; field = make_field (yyvsp[0]); yyval = (NOD) field; } break; case 204: { field = make_field (yyvsp[0]); yyval = (NOD) field; } break; case 205: { yyval = yyvsp[-1]; } break; case 206: { field = make_field (NULL); yyval = (NOD) field; } break; case 207: { yyval = yyvsp[0]; } break; case 208: { yyval = (NOD) NULL; } break; case 209: { yyval = yyvsp[0]; } break; case 210: { yyval = make_node (nod_user_name, (int) 0, NULL); } break; case 211: { yyval = yyvsp[0]; } break; case 212: { yyval = yyvsp[0]; } break; case 213: { yyval = (NOD) NULL; } break; case 216: { yyval = make_node (nod_list, (int) 2, yyvsp[-1], yyvsp[0]); } break; case 217: { yyval = make_node (nod_rel_constraint, (int) 2, yyvsp[-1], yyvsp[0]);} break; case 218: { yyval = make_node (nod_null, (int) 1, NULL); } break; case 219: { yyval = make_node (nod_foreign, e_for_count, make_node (nod_list, (int) 1, field_name), yyvsp[-2], yyvsp[-1], yyvsp[0]); } break; case 221: { yyval = make_node (nod_unique, (int) 0, NULL); } break; case 222: { yyval = make_node (nod_primary, (int) 0, NULL); } break; case 223: { yyval = make_node (nod_rel_constraint, (int) 2, yyvsp[-1], yyvsp[0]);} break; case 224: { yyval = yyvsp[0]; } break; case 225: { yyval = NULL ;} break; case 230: { yyval = make_node (nod_unique, 1, yyvsp[0]); } break; case 231: { yyval = make_node (nod_primary, e_pri_count, yyvsp[0]); } break; case 232: { yyval = make_node (nod_foreign, e_for_count, yyvsp[-4], yyvsp[-2], yyvsp[-1], yyvsp[0]); } break; case 233: { yyval = make_node (nod_def_constraint, (int) e_cnstr_count, MAKE_string (NULL_STRING, 0), NULL, NULL, NULL, yyvsp[-2], NULL, yyvsp[0], NULL, NULL); } break; case 234: { yyval = make_node (nod_ref_upd_del, e_ref_upd_del_count, yyvsp[0], NULL);} break; case 235: { yyval = make_node (nod_ref_upd_del, e_ref_upd_del_count, NULL, yyvsp[0]);} break; case 236: { yyval = make_node (nod_ref_upd_del, e_ref_upd_del_count, yyvsp[0], yyvsp[-1]); } break; case 237: { yyval = make_node (nod_ref_upd_del, e_ref_upd_del_count, yyvsp[-1], yyvsp[0]);} break; case 238: { yyval = NULL;} break; case 239: { yyval = yyvsp[0];} break; case 240: { yyval = yyvsp[0];} break; case 241: { yyval = make_flag_node (nod_ref_trig_action, REF_ACTION_CASCADE, e_ref_trig_action_count, NULL);} break; case 242: { yyval = make_flag_node (nod_ref_trig_action, REF_ACTION_SET_DEFAULT, e_ref_trig_action_count, NULL);} break; case 243: { yyval = make_flag_node (nod_ref_trig_action, REF_ACTION_SET_NULL, e_ref_trig_action_count, NULL);} break; case 244: { yyval = make_flag_node (nod_ref_trig_action, REF_ACTION_NONE, e_ref_trig_action_count, NULL);} break; case 245: { yyval = make_node (nod_def_procedure, (int) e_prc_count, yyvsp[-7], yyvsp[-6], yyvsp[-5], yyvsp[-2], yyvsp[-1], yyvsp[0], NULL); } break; case 246: { yyval = make_node (nod_mod_procedure, (int) e_prc_count, yyvsp[-7], yyvsp[-6], yyvsp[-5], yyvsp[-2], yyvsp[-1], yyvsp[0], NULL); } break; case 247: { yyval = make_list (yyvsp[-1]); } break; case 248: { yyval = NULL; } break; case 249: { yyval = yyvsp[0]; } break; case 250: { yyval = NULL; } break; case 252: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 253: { yyval = make_node (nod_def_field, (int) e_dfl_count, yyvsp[-1], NULL, NULL, NULL, NULL, NULL, NULL); } break; case 254: { yyval = make_list (yyvsp[0]); } break; case 255: { yyval = NULL; } break; case 257: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 258: { yyval = make_node (nod_def_field, (int) e_dfl_count, yyvsp[-2], NULL, NULL, NULL, NULL, NULL, NULL); } break; case 261: { yyval = make_node (nod_block, e_blk_count, make_list (yyvsp[-1]), NULL);} break; case 262: { yyval = make_node (nod_block, e_blk_count, make_list (yyvsp[-2]), make_list (yyvsp[-1]));} break; case 264: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 267: { yyval = make_node (nod_exception_stmt, 1, yyvsp[-1]); } break; case 272: { yyval = make_node (nod_post, e_pst_count, yyvsp[-1]); } break; case 276: { yyval = make_node (nod_return, e_rtn_count, NULL); } break; case 277: { yyval = make_node (nod_exit, 0, NULL); } break; case 278: { yyval = make_node (nod_exec_procedure, e_exe_count, yyvsp[-3], yyvsp[-2], yyvsp[-1]); } break; case 279: { yyval = make_node (nod_for_select, e_flp_count, yyvsp[-5], make_list (yyvsp[-3]), yyvsp[-2], yyvsp[0]); } break; case 280: { yyval = make_node (nod_if, e_if_count, yyvsp[-5], yyvsp[-2], yyvsp[0]); } break; case 281: { yyval = make_node (nod_if, e_if_count, yyvsp[-3], yyvsp[0], NULL); } break; case 282: { yyval = make_node (nod_for_select, e_flp_count, yyvsp[-3], make_list (yyvsp[-1]), NULL, NULL); } break; case 283: { yyval = make_node (nod_var_name, (int) e_vrn_count, yyvsp[0]); } break; case 284: { yyval = make_list (yyvsp[0]); } break; case 285: { yyval = make_list (yyvsp[-1]); } break; case 286: { yyval = NULL; } break; case 287: { yyval = make_list (yyvsp[0]); } break; case 288: { yyval = make_list (yyvsp[-1]); } break; case 289: { yyval = NULL; } break; case 294: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 295: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 296: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 297: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 300: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 301: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 302: { yyval = make_node (nod_while, e_while_count, yyvsp[-3], yyvsp[0], NULL); } break; case 303: { yyval = make_node (nod_cursor, e_cur_count, yyvsp[0], NULL, NULL); } break; case 304: { yyval = NULL; } break; case 306: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 307: { yyval = make_node (nod_on_error, e_err_count, make_list (yyvsp[-2]), yyvsp[0]); } break; case 309: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 310: { yyval = make_node (nod_sqlcode, 1, yyvsp[0]); } break; case 311: { yyval = make_node (nod_gdscode, 1, yyvsp[0]); } break; case 312: { yyval = make_node (nod_exception, 1, yyvsp[0]); } break; case 313: { yyval = make_node (nod_default, 1, NULL); } break; case 314: { yyval = make_node (nod_exec_procedure, e_exe_count, yyvsp[-1], yyvsp[0], make_node (nod_all, (int) 0, NULL)); } break; case 315: { yyval = make_list (yyvsp[0]); } break; case 316: { yyval = make_list (yyvsp[-1]); } break; case 317: { yyval = NULL; } break; case 321: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 322: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 323: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 324: { yyval = make_node (nod_def_view, (int) e_view_count, yyvsp[-6], yyvsp[-5], yyvsp[-2], yyvsp[-1], yyvsp[0]); } break; case 325: { yyval = make_node (nod_select, (int) 2, yyvsp[0], NULL); } break; case 326: { yyval = make_node (nod_list, (int) 1, yyvsp[0]); } break; case 327: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 328: { yyval = make_flag_node (nod_list, NOD_UNION_ALL, 2, yyvsp[-3], yyvsp[0]); } break; case 329: { yyval = make_node (nod_select_expr, e_sel_count, yyvsp[-6], yyvsp[-5], yyvsp[-4], yyvsp[-3], yyvsp[-2], yyvsp[-1], yyvsp[0], NULL); } break; case 330: { yyval = make_list (yyvsp[0]); } break; case 332: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 335: { yyval = make_node (nod_join, (int) e_join_count, yyvsp[-5], yyvsp[-4], yyvsp[-2], yyvsp[0]); } break; case 336: { yyval = yyvsp[-1]; } break; case 337: { beginning = lex_position(); } break; case 338: { yyval = (NOD) MAKE_string ((UCHAR *) beginning, (lex_position() == end) ? lex_position()-beginning : last_token-beginning);} break; case 339: { beginning = last_token; } break; case 340: { yyval = (NOD) MAKE_string ((UCHAR *) beginning, lex_position()-beginning); } break; case 341: { yyval = make_node (nod_def_constraint, (int) e_cnstr_count, MAKE_string (NULL_STRING, 0), NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); } break; case 342: { yyval = 0; } break; case 343: { yyval = make_node (nod_def_trigger, (int) e_trg_count, yyvsp[-8], yyvsp[-6], yyvsp[-5], yyvsp[-4], yyvsp[-3], yyvsp[-1], yyvsp[0], NULL); } break; case 344: { yyval = MAKE_constant ((STR) 0, CONSTANT_SLONG); } break; case 345: { yyval = MAKE_constant ((STR) 1, CONSTANT_SLONG); } break; case 346: { yyval = NULL; } break; case 347: { yyval = MAKE_constant ((STR) 1, CONSTANT_SLONG); } break; case 348: { yyval = MAKE_constant ((STR) 2, CONSTANT_SLONG); } break; case 349: { yyval = MAKE_constant ((STR) 3, CONSTANT_SLONG); } break; case 350: { yyval = MAKE_constant ((STR) 4, CONSTANT_SLONG); } break; case 351: { yyval = MAKE_constant ((STR) 5, CONSTANT_SLONG); } break; case 352: { yyval = MAKE_constant ((STR) 6, CONSTANT_SLONG); } break; case 353: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG); } break; case 354: { yyval = NULL; } break; case 355: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 356: { yyval = yyvsp[0]; } break; case 357: { yyval = make_node (nod_mod_exception, (int) e_xcp_count, yyvsp[-1], yyvsp[0]); } break; case 358: { yyval = make_node (nod_mod_relation, (int) e_alt_count, yyvsp[-1], make_list (yyvsp[0])); } break; case 359: { yyval = yyvsp[0]; } break; case 360: { yyval = yyvsp[0]; } break; case 361: { yyval = make_node (nod_mod_database, (int) e_adb_count, make_list (yyvsp[0])); } break; case 362: { yyval = make_node (nod_mod_domain, (int) e_alt_count, yyvsp[-1], make_list (yyvsp[0])); } break; case 363: { yyval = make_node (nod_mod_index, (int) e_mod_idx_count, yyvsp[0]); } break; case 365: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 366: { yyval = make_node (nod_def_default, (int) e_dft_count, yyvsp[-1], yyvsp[0]); } break; case 367: { yyval = yyvsp[0]; } break; case 368: { yyval = yyvsp[0]; } break; case 369: {yyval = make_node (nod_del_default, (int) 0, NULL); } break; case 370: { yyval = make_node (nod_delete_rel_constraint, (int) 1, NULL); } break; case 371: { yyval = yyvsp[0]; } break; case 372: { yyval = make_node (nod_mod_domain_type, 2, yyvsp[-1]); } break; case 374: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 375: { yyval = make_node (nod_del_field, 2, yyvsp[-1], yyvsp[0]); } break; case 376: { yyval = make_node (nod_delete_rel_constraint, (int) 1, yyvsp[0]);} break; case 377: { yyval = yyvsp[0]; } break; case 378: { yyval = yyvsp[0]; } break; case 379: { yyval = make_node (nod_mod_field_pos, 2, yyvsp[-2], MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG)); } break; case 380: { yyval = make_node (nod_mod_field_name, 2, yyvsp[-2], yyvsp[0]); } break; case 381: { yyval = make_node (nod_mod_field_type, 3, yyvsp[-3], yyvsp[0], yyvsp[-1]); } break; case 382: { yyval = make_node (nod_field_name, (int) e_fln_count, NULL, yyvsp[0]); } break; case 400: { yyval = NULL; } break; case 401: { yyval = NULL; } break; case 402: { yyval = NULL; } break; case 403: { yyval = make_node (nod_def_domain, (int) e_dom_count, yyvsp[-1], NULL, NULL, NULL, NULL); } break; case 404: { field_name = yyvsp[0]; field = make_field (yyvsp[0]); yyval = (NOD) field; } break; case 405: { yyval = make_node (nod_restrict, 0, NULL); } break; case 406: { yyval = make_node (nod_cascade, 0, NULL); } break; case 407: { yyval = make_node (nod_restrict, 0, NULL); } break; case 408: { yyval = make_node (nod_idx_active, 1, yyvsp[-1]); } break; case 409: { yyval = make_node (nod_idx_inactive, 1, yyvsp[-1]); } break; case 410: { log_defined = FALSE; cache_defined = FALSE; yyval = (NOD) NULL; } break; case 412: { yyval = make_node (nod_list, (int) 2, yyvsp[-1], yyvsp[0]); } break; case 413: { yyval = yyvsp[0]; } break; case 414: { yyval = make_node (nod_drop_log, (int) 0, NULL); } break; case 415: { yyval = yyvsp[0]; } break; case 416: { yyval = yyvsp[0]; } break; case 418: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 419: { yyval = make_node (nod_mod_trigger, (int) e_trg_count, yyvsp[-6], NULL, yyvsp[-5], yyvsp[-4], yyvsp[-3], yyvsp[-1], yyvsp[0], NULL); } break; case 421: { yyval = NULL; } break; case 423: { yyval = NULL; } break; case 424: { yyval = yyvsp[0]; } break; case 425: { yyval = make_node (nod_del_exception, 1, yyvsp[0]); } break; case 426: { yyval = make_node (nod_del_index, (int) 1, yyvsp[0]); } break; case 427: { yyval = make_node (nod_del_procedure, (int) 1, yyvsp[0]); } break; case 428: { yyval = make_node (nod_del_relation, (int) 1, yyvsp[0]); } break; case 429: { yyval = make_node (nod_del_trigger, (int) 1, yyvsp[0]); } break; case 430: { yyval = make_node (nod_del_relation, (int) 1, yyvsp[0]); } break; case 431: { yyval = make_node (nod_del_filter, (int) 1, yyvsp[0]); } break; case 432: { yyval = make_node (nod_del_domain, (int) 1, yyvsp[0]); } break; case 433: { yyval = make_node (nod_del_udf, (int) 1, yyvsp[0]); } break; case 434: { yyval = make_node (nod_del_shadow, (int) 1, yyvsp[0]); } break; case 435: { yyval = make_node (nod_del_role, (int) 1, yyvsp[0]); } break; case 440: { field->fld_ranges = make_list (yyvsp[-1]); field->fld_dimensions = field->fld_ranges->nod_count / 2; field->fld_element_dtype = field->fld_dtype; yyval = yyvsp[-3]; } break; case 441: { field->fld_ranges = make_list (yyvsp[-2]); field->fld_dimensions = field->fld_ranges->nod_count / 2; field->fld_element_dtype = field->fld_dtype; yyval = yyvsp[-4]; } break; case 443: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 444: { if ((SLONG) yyvsp[0] < 1) yyval = make_node (nod_list, (int) 2, MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG), MAKE_constant ((STR) 1, CONSTANT_SLONG)); else yyval = make_node (nod_list, (int) 2, MAKE_constant ((STR) 1, CONSTANT_SLONG), MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG) ); } break; case 445: { yyval = make_node (nod_list, (int) 2, MAKE_constant ((STR) yyvsp[-2], CONSTANT_SLONG), MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG)); } break; case 451: { field->fld_dtype = dtype_long; field->fld_length = sizeof (SLONG); } break; case 452: { field->fld_dtype = dtype_short; field->fld_length = sizeof (SSHORT); } break; case 453: { *stmt_ambiguous = TRUE; if (client_dialect <= SQL_DIALECT_V5) { /* Post warning saying that DATE is equivalent to TIMESTAMP */ ERRD_post_warning (isc_sqlwarn, gds_arg_number, (SLONG) 301, isc_arg_warning, isc_dtype_renamed, 0); field->fld_dtype = dtype_timestamp; field->fld_length = sizeof (GDS_TIMESTAMP); } else if (client_dialect == SQL_DIALECT_V6_TRANSITION) yyabandon (-104, isc_transitional_date); else { field->fld_dtype = dtype_sql_date; field->fld_length = sizeof (ULONG); } } break; case 454: { if (client_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_dialect_datatype_unsupport, gds_arg_number, client_dialect, gds_arg_string, "TIME", 0); if (db_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_db_dialect_dtype_unsupport, gds_arg_number, db_dialect, gds_arg_string, "TIME", 0); field->fld_dtype = dtype_sql_time; field->fld_length = sizeof (SLONG); } break; case 455: { field->fld_dtype = dtype_timestamp; field->fld_length = sizeof (GDS_TIMESTAMP); } break; case 458: { field->fld_dtype = dtype_blob; } break; case 459: { field->fld_dtype = dtype_blob; field->fld_seg_length = (USHORT) yyvsp[-1]; field->fld_sub_type = 0; } break; case 460: { field->fld_dtype = dtype_blob; field->fld_seg_length = (USHORT) yyvsp[-3]; field->fld_sub_type = (USHORT) yyvsp[-1]; } break; case 461: { field->fld_dtype = dtype_blob; field->fld_seg_length = 80; field->fld_sub_type = (USHORT) yyvsp[-1]; } break; case 462: { field->fld_seg_length = (USHORT) yyvsp[0]; } break; case 463: { field->fld_seg_length = (USHORT) 80; } break; case 464: { field->fld_sub_type = (USHORT) yyvsp[0]; } break; case 465: { field->fld_sub_type_name = yyvsp[0]; } break; case 466: { field->fld_sub_type = (USHORT) 0; } break; case 467: { field->fld_character_set = yyvsp[0]; } break; case 469: { field->fld_dtype = dtype_text; field->fld_character_length = (USHORT) yyvsp[-1]; field->fld_flags |= FLD_national; } break; case 470: { field->fld_dtype = dtype_text; field->fld_character_length = 1; field->fld_flags |= FLD_national; } break; case 471: { field->fld_dtype = dtype_varying; field->fld_character_length = (USHORT) yyvsp[-1]; field->fld_flags |= FLD_national; } break; case 472: { field->fld_dtype = dtype_text; field->fld_character_length = (USHORT) yyvsp[-1]; } break; case 473: { field->fld_dtype = dtype_text; field->fld_character_length = 1; } break; case 474: { field->fld_dtype = dtype_varying; field->fld_character_length = (USHORT) yyvsp[-1]; } break; case 483: { field->fld_sub_type = dsc_num_type_numeric; } break; case 484: { field->fld_sub_type = dsc_num_type_decimal; if (field->fld_dtype == dtype_short) { field->fld_dtype = dtype_long; field->fld_length = sizeof (SLONG); }; } break; case 485: { yyval = make_node (nod_position, 1, yyvsp[0]); } break; case 486: { field->fld_dtype = dtype_long; field->fld_length = sizeof (SLONG); field->fld_precision = 9; } break; case 487: { if ( ((SLONG) yyvsp[-1] < 1) || ((SLONG) yyvsp[-1] > 18) ) yyabandon (-842, isc_precision_err); /* Precision most be between 1 and 18. */ if ((SLONG) yyvsp[-1] > 9) { if ( ( (client_dialect <= SQL_DIALECT_V5) && (db_dialect > SQL_DIALECT_V5) ) || ( (client_dialect > SQL_DIALECT_V5) && (db_dialect <= SQL_DIALECT_V5) ) ) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -817, gds_arg_gds, isc_ddl_not_allowed_by_db_sql_dial, gds_arg_number, (SLONG) db_dialect, 0); if (client_dialect <= SQL_DIALECT_V5) { field->fld_dtype = dtype_double; field->fld_length = sizeof (double); } else { if (client_dialect == SQL_DIALECT_V6_TRANSITION) { ERRD_post_warning ( isc_dsql_warn_precision_ambiguous, gds_arg_end ); ERRD_post_warning ( isc_dsql_warn_precision_ambiguous1, gds_arg_end ); ERRD_post_warning ( isc_dsql_warn_precision_ambiguous2, gds_arg_end ); } field->fld_dtype = dtype_int64; field->fld_length = sizeof (SINT64); } } else if ((SLONG) yyvsp[-1] < 5) { field->fld_dtype = dtype_short; field->fld_length = sizeof (SSHORT); } else { field->fld_dtype = dtype_long; field->fld_length = sizeof (SLONG); } field->fld_precision = (USHORT) yyvsp[-1]; } break; case 488: { if ( ((SLONG) yyvsp[-3] < 1) || ((SLONG) yyvsp[-3] > 18) ) yyabandon (-842, isc_precision_err); /* Precision should be between 1 and 18 */ if (((SLONG) yyvsp[-1] > (SLONG) yyvsp[-3]) || ((SLONG) yyvsp[-1] < 0)) yyabandon (-842, isc_scale_nogt); /* Scale must be between 0 and precision */ if ((SLONG) yyvsp[-3] > 9) { if ( ( (client_dialect <= SQL_DIALECT_V5) && (db_dialect > SQL_DIALECT_V5) ) || ( (client_dialect > SQL_DIALECT_V5) && (db_dialect <= SQL_DIALECT_V5) ) ) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -817, gds_arg_gds, isc_ddl_not_allowed_by_db_sql_dial, gds_arg_number, (SLONG) db_dialect, 0); if (client_dialect <= SQL_DIALECT_V5) { field->fld_dtype = dtype_double; field->fld_length = sizeof (double); } else { if (client_dialect == SQL_DIALECT_V6_TRANSITION) { ERRD_post_warning ( isc_dsql_warn_precision_ambiguous, gds_arg_end ); ERRD_post_warning ( isc_dsql_warn_precision_ambiguous1, gds_arg_end ); ERRD_post_warning ( isc_dsql_warn_precision_ambiguous2, gds_arg_end ); } /* client_dialect >= SQL_DIALECT_V6 */ field->fld_dtype = dtype_int64; field->fld_length = sizeof (SINT64); } } else { if ((SLONG) yyvsp[-3] < 5) { field->fld_dtype = dtype_short; field->fld_length = sizeof (SSHORT); } else { field->fld_dtype = dtype_long; field->fld_length = sizeof (SLONG); } } field->fld_precision = (USHORT) yyvsp[-3]; field->fld_scale = - (SSHORT) yyvsp[-1]; } break; case 491: { if ((SLONG) yyvsp[0] > 7) { field->fld_dtype = dtype_double; field->fld_length = sizeof (double); } else { field->fld_dtype = dtype_real; field->fld_length = sizeof (float); } } break; case 492: { field->fld_dtype = dtype_double; field->fld_length = sizeof (double); } break; case 493: { field->fld_dtype = dtype_real; field->fld_length = sizeof (float); } break; case 494: { field->fld_dtype = dtype_double; field->fld_length = sizeof (double); } break; case 495: { yyval = yyvsp[-1]; } break; case 496: { yyval = 0; } break; case 500: { yyval = make_node (nod_set_generator2,e_gen_id_count,yyvsp[-2], MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG)); } break; case 501: { yyval = make_node (nod_set_generator2,e_gen_id_count,yyvsp[-2], MAKE_constant((STR)yyvsp[0], CONSTANT_SINT64)); } break; case 502: { yyval = make_node (nod_set_generator2, e_gen_id_count, yyvsp[-3], make_node(nod_negate, 1, MAKE_constant((STR)yyvsp[0], CONSTANT_SINT64))); } break; case 503: { yyval = make_node (nod_commit, 1, yyvsp[0]); } break; case 504: { yyval = make_node (nod_rollback, 0, NULL); } break; case 507: { yyval = make_node (nod_commit_retain, 0, NULL); } break; case 508: { yyval = (NOD) NULL; } break; case 510: { yyval = (NOD) NULL; } break; case 511: {yyval = make_node (nod_trans, 1, make_list (yyvsp[0])); } break; case 513: { yyval = (NOD) NULL; } break; case 515: { yyval = make_node (nod_list, (int) 2, yyvsp[-1], yyvsp[0]); } break; case 520: { yyval = make_flag_node (nod_access, NOD_READ_ONLY, (int) 0, NULL); } break; case 521: { yyval = make_flag_node (nod_access, NOD_READ_WRITE, (int) 0, NULL); } break; case 522: { yyval = make_flag_node (nod_wait, NOD_WAIT, (int) 0, NULL); } break; case 523: { yyval = make_flag_node (nod_wait, NOD_NO_WAIT, (int) 0, NULL); } break; case 524: { yyval = yyvsp[0];} break; case 526: { yyval = yyvsp[0];} break; case 527: { yyval = make_flag_node (nod_isolation, NOD_READ_COMMITTED, 1, yyvsp[0]); } break; case 528: { yyval = make_flag_node (nod_isolation, NOD_READ_COMMITTED, 1, yyvsp[0]); } break; case 529: { yyval = make_flag_node (nod_isolation, NOD_CONCURRENCY, 0, NULL); } break; case 530: { yyval = make_flag_node (nod_isolation, NOD_CONSISTENCY, 0, NULL); } break; case 531: { yyval = make_flag_node (nod_isolation, NOD_CONSISTENCY, 0, NULL); } break; case 532: { yyval = make_flag_node (nod_version, NOD_VERSION, 0, NULL); } break; case 533: { yyval = make_flag_node (nod_version, NOD_NO_VERSION, 0, NULL); } break; case 534: { yyval = 0; } break; case 535: { yyval = make_node (nod_reserve, 1, make_list (yyvsp[0])); } break; case 536: { yyval = (NOD) NOD_SHARED; } break; case 537: { yyval = (NOD) NOD_PROTECTED ; } break; case 538: { yyval = (NOD) 0; } break; case 539: { yyval = (NOD) NOD_READ; } break; case 540: { yyval = (NOD) NOD_WRITE; } break; case 542: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 543: { yyval = make_node (nod_table_lock, (int) 2, make_list (yyvsp[-1]), yyvsp[0]); } break; case 544: { yyval = make_flag_node (nod_lock_mode, (SSHORT) ((SSHORT) yyvsp[-1] | (SSHORT) yyvsp[0]), (SSHORT) 0, NULL); } break; case 545: { yyval = 0; } break; case 547: { yyval = make_node (nod_list, (int) 2, yyvsp[-2], yyvsp[0]); } break; case 548: {yyval = make_node (nod_set_statistics, (int)e_stat_count, yyvsp[0]); } break; case 549: { yyval = make_node (nod_select, 3, yyvsp[-2], yyvsp[-1], yyvsp[0]); } break; case 550: { yyval = make_node (nod_list, 1, yyvsp[0]); } break; case 551: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 552: { yyval = make_flag_node (nod_list, NOD_UNION_ALL, 2, yyvsp[-3], yyvsp[0]); } break; case 553: { yyval = make_list (yyvsp[0]); } break; case 554: { yyval = 0; } break; case 556: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 557: { yyval = make_node (nod_order, e_order_count, yyvsp[-2], yyvsp[0], yyvsp[-1]); } break; case 558: { yyval = make_node (nod_order, e_order_count, yyvsp[-2], yyvsp[0], yyvsp[-1]); } break; case 559: { yyval = 0; } break; case 560: { yyval = make_node (nod_flag, 0, NULL); } break; case 561: { yyval = 0; } break; case 562: { yyval = yyvsp[0]; } break; case 563: { yyval = 0; } break; case 564: { yyval = yyvsp[0]; } break; case 565: { yyval = make_node (nod_flag, 0, NULL); } break; case 566: { yyval = make_node (nod_select_expr, e_sel_count, yyvsp[-7], yyvsp[-6], yyvsp[-5], yyvsp[-4], yyvsp[-3], yyvsp[-2], yyvsp[-1], yyvsp[0], NULL); } break; case 567: { yyval = make_node (nod_flag, 0, NULL); } break; case 568: { yyval = 0; } break; case 569: { yyval = make_list (yyvsp[0]); } break; case 570: { yyval = 0; } break; case 572: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 574: { yyval = make_node (nod_alias, 2, yyvsp[-1], yyvsp[0]); } break; case 575: { yyval = make_node (nod_alias, 2, yyvsp[-2], yyvsp[0]); } break; case 576: { yyval = make_list (yyvsp[0]); } break; case 578: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 581: { yyval = make_node (nod_join, (int) e_join_count, yyvsp[-5], yyvsp[-4], yyvsp[-2], yyvsp[0]); } break; case 582: { yyval = yyvsp[-1]; } break; case 583: { yyval = make_node (nod_rel_proc_name, (int) e_rpn_count, yyvsp[-2], yyvsp[0], yyvsp[-1]); } break; case 584: { yyval = make_node (nod_rel_proc_name, (int) e_rpn_count, yyvsp[-1], NULL, yyvsp[0]); } break; case 585: { yyval = make_list (yyvsp[-1]); } break; case 586: { yyval = NULL; } break; case 588: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 592: { yyval = make_node (nod_relation_name, (int) e_rln_count, yyvsp[-1], yyvsp[0]); } break; case 593: { yyval = make_node (nod_relation_name, (int) e_rln_count, yyvsp[0], NULL); } break; case 594: { yyval = make_node (nod_join_inner, (int) 0, NULL); } break; case 595: { yyval = make_node (nod_join_left, (int) 0, NULL); } break; case 596: { yyval = make_node (nod_join_left, (int) 0, NULL); } break; case 597: { yyval = make_node (nod_join_right, (int) 0, NULL); } break; case 598: { yyval = make_node (nod_join_right, (int) 0, NULL); } break; case 599: { yyval = make_node (nod_join_full, (int) 0, NULL); } break; case 600: { yyval = make_node (nod_join_full, (int) 0, NULL); } break; case 601: { yyval = make_node (nod_join_inner, (int) 0, NULL); } break; case 602: { yyval = make_list (yyvsp[0]); } break; case 603: { yyval = 0; } break; case 605: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 608: { yyval = make_node (nod_collate, e_coll_count, (NOD) yyvsp[0], yyvsp[-2]); } break; case 609: { yyval = yyvsp[0]; } break; case 610: { yyval = 0; } break; case 611: { yyval = yyvsp[0]; } break; case 612: { yyval = 0; } break; case 613: { yyval = yyvsp[0]; } break; case 614: { yyval = 0;} break; case 615: { yyval = make_node (nod_top, 1, yyvsp[-2]);} break; case 616: { yyval = make_node (nod_top, 2, yyvsp[-4], yyvsp[-3]);} break; case 617: { yyval = 0;} break; case 618: { yyval = yyvsp[0]; } break; case 619: { yyval = 0; } break; case 620: { yyval = make_node (nod_plan_expr, 2, yyvsp[-3], make_list (yyvsp[-1])); } break; case 621: { yyval = 0; } break; case 622: { yyval = make_node (nod_merge, (int) 0, NULL); } break; case 623: { yyval = make_node (nod_merge, (int) 0, NULL); } break; case 624: { yyval = 0; } break; case 625: { yyval = 0; } break; case 627: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 628: { yyval = make_node (nod_plan_item, 2, make_list (yyvsp[-1]), yyvsp[0]); } break; case 631: { yyval = make_node (nod_list, 2, yyvsp[-1], yyvsp[0]); } break; case 632: { yyval = make_node (nod_natural, (int) 0, NULL); } break; case 633: { yyval = make_node (nod_index, 1, make_list (yyvsp[-1])); } break; case 634: { yyval = make_node (nod_index_order, 1, yyvsp[0]); } break; case 636: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 637: { yyval = make_node (nod_insert, e_ins_count, yyvsp[-5], make_list (yyvsp[-4]), make_list (yyvsp[-1]), NULL); } break; case 638: { yyval = make_node (nod_insert, e_ins_count, yyvsp[-2], yyvsp[-1], NULL, yyvsp[0]); } break; case 640: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 643: { yyval = make_node (nod_delete, e_del_count, yyvsp[-1], yyvsp[0], NULL); } break; case 644: { yyval = make_node (nod_delete, e_del_count, yyvsp[-1], NULL, yyvsp[0]); } break; case 645: { yyval = make_node (nod_cursor, e_cur_count, yyvsp[0], NULL, NULL); } break; case 648: { yyval = make_node (nod_update, e_upd_count, yyvsp[-3], make_list (yyvsp[-1]), yyvsp[0], NULL); } break; case 649: { yyval = make_node (nod_update, e_upd_count, yyvsp[-3], make_list (yyvsp[-1]), NULL, yyvsp[0]); } break; case 651: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 652: { yyval = make_node (nod_assign, 2, yyvsp[0], yyvsp[-2]); } break; case 655: { yyval = make_node (nod_get_segment, e_blb_count, yyvsp[-4], yyvsp[-2], yyvsp[-1], yyvsp[0]); } break; case 656: { yyval = make_node (nod_put_segment, e_blb_count, yyvsp[-4], yyvsp[-2], yyvsp[-1], yyvsp[0]); } break; case 657: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 658: { yyval = make_node (nod_list, 2, NULL, yyvsp[0]); } break; case 662: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG); } break; case 663: { yyval = yyvsp[0]; } break; case 665: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG); } break; case 668: { yyval = NULL; } break; case 669: { yyval = make_list (yyvsp[-1]); } break; case 671: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 673: { yyval = make_node (nod_field_name, (int) e_fln_count, yyvsp[-2], yyvsp[0]); } break; case 674: { yyval = make_node (nod_field_name, (int) e_fln_count, yyvsp[-2], NULL); } break; case 675: { yyval = make_node (nod_field_name, (int) e_fln_count, NULL, yyvsp[0]); } break; case 677: { yyval = make_node (nod_or, 2, yyvsp[-2], yyvsp[0]); } break; case 678: { yyval = make_node (nod_and, 2, yyvsp[-2], yyvsp[0]); } break; case 679: { yyval = make_node (nod_not, 1, yyvsp[0]); } break; case 690: { yyval = yyvsp[-1]; } break; case 691: { yyval = make_node (nod_eql, 2, yyvsp[-2], yyvsp[0]); } break; case 692: { yyval = make_node (nod_lss, 2, yyvsp[-2], yyvsp[0]); } break; case 693: { yyval = make_node (nod_gtr, 2, yyvsp[-2], yyvsp[0]); } break; case 694: { yyval = make_node (nod_geq, 2, yyvsp[-2], yyvsp[0]); } break; case 695: { yyval = make_node (nod_leq, 2, yyvsp[-2], yyvsp[0]); } break; case 696: { yyval = make_node (nod_leq, 2, yyvsp[-2], yyvsp[0]); } break; case 697: { yyval = make_node (nod_geq, 2, yyvsp[-2], yyvsp[0]); } break; case 698: { yyval = make_node (nod_neq, 2, yyvsp[-2], yyvsp[0]); } break; case 699: { yyval = make_node (nod_eql_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 700: { yyval = make_node (nod_lss_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 701: { yyval = make_node (nod_gtr_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 702: { yyval = make_node (nod_geq_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 703: { yyval = make_node (nod_leq_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 704: { yyval = make_node (nod_leq_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 705: { yyval = make_node (nod_geq_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 706: { yyval = make_node (nod_neq_all, 2, yyvsp[-5], yyvsp[-1]); } break; case 707: { yyval = make_node (nod_eql_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 708: { yyval = make_node (nod_lss_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 709: { yyval = make_node (nod_gtr_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 710: { yyval = make_node (nod_geq_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 711: { yyval = make_node (nod_leq_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 712: { yyval = make_node (nod_leq_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 713: { yyval = make_node (nod_geq_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 714: { yyval = make_node (nod_neq_any, 2, yyvsp[-5], yyvsp[-1]); } break; case 717: { yyval = make_node (nod_between, 3, yyvsp[-4], yyvsp[-2], yyvsp[0]); } break; case 718: { yyval = make_node (nod_not, 1, make_node (nod_between, 3, yyvsp[-5], yyvsp[-2], yyvsp[0])); } break; case 719: { yyval = make_node (nod_like, 2, yyvsp[-2], yyvsp[0]); } break; case 720: { yyval = make_node (nod_not, 1, make_node (nod_like, 2, yyvsp[-3], yyvsp[0])); } break; case 721: { yyval = make_node (nod_like, 3, yyvsp[-4], yyvsp[-2], yyvsp[0]); } break; case 722: { yyval = make_node (nod_not, 1, make_node (nod_like, 3, yyvsp[-5], yyvsp[-2], yyvsp[0])); } break; case 723: { yyval = make_node (nod_eql_any, 2, yyvsp[-2], yyvsp[0]); } break; case 724: { yyval = make_node (nod_not, 1, make_node (nod_eql_any, 2, yyvsp[-3], yyvsp[0])); } break; case 725: { yyval = make_node (nod_containing, 2, yyvsp[-2], yyvsp[0]); } break; case 726: { yyval = make_node (nod_not, 1, make_node (nod_containing, 2, yyvsp[-3], yyvsp[0])); } break; case 727: { yyval = make_node (nod_starting, 2, yyvsp[-2], yyvsp[0]); } break; case 728: { yyval = make_node (nod_not, 1, make_node (nod_starting, 2, yyvsp[-3], yyvsp[0])); } break; case 729: { yyval = make_node (nod_starting, 2, yyvsp[-3], yyvsp[0]); } break; case 730: { yyval = make_node (nod_not, 1, make_node (nod_starting, 2, yyvsp[-4], yyvsp[0])); } break; case 731: { yyval = make_node (nod_exists, 1, yyvsp[-1]); } break; case 732: { yyval = make_node (nod_singular, 1, yyvsp[-1]); } break; case 733: { yyval = make_node (nod_missing, 1, yyvsp[-2]); } break; case 734: { yyval = make_node (nod_not, 1, make_node (nod_missing, 1, yyvsp[-3])); } break; case 735: { yyval = make_list (yyvsp[-1]); } break; case 736: { yyval = yyvsp[-1]; } break; case 737: { yyval = make_node (nod_select_expr, e_sel_count, yyvsp[-6], make_list (yyvsp[-5]), yyvsp[-4], yyvsp[-3], yyvsp[-2], yyvsp[-1], yyvsp[0], NULL); } break; case 738: { yyval = make_node (nod_select_expr, e_sel_count, yyvsp[-6], make_list (yyvsp[-5]), yyvsp[-4], yyvsp[-3], yyvsp[-2], yyvsp[-1], yyvsp[0], MAKE_constant ((STR) 1, CONSTANT_SLONG)); } break; case 746: { yyval = make_node (nod_negate, 1, yyvsp[0]); } break; case 747: { yyval = yyvsp[0]; } break; case 748: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_add2, 2, yyvsp[-2], yyvsp[0]); else yyval = make_node (nod_add, 2, yyvsp[-2], yyvsp[0]); } break; case 749: { yyval = make_node (nod_concatenate, 2, yyvsp[-2], yyvsp[0]); } break; case 750: { yyval = make_node (nod_collate, e_coll_count, (NOD) yyvsp[0], yyvsp[-2]); } break; case 751: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_subtract2, 2, yyvsp[-2], yyvsp[0]); else yyval = make_node (nod_subtract, 2, yyvsp[-2], yyvsp[0]); } break; case 752: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_multiply2, 2, yyvsp[-2], yyvsp[0]); else yyval = make_node (nod_multiply, 2, yyvsp[-2], yyvsp[0]); } break; case 753: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_divide2, 2, yyvsp[-2], yyvsp[0]); else yyval = make_node (nod_divide, 2, yyvsp[-2], yyvsp[0]); } break; case 754: { yyval = yyvsp[-1]; } break; case 755: { yyval = yyvsp[-1]; } break; case 756: { yyval = make_node (nod_user_name, 0, NULL); } break; case 757: { yyval = make_node (nod_dbkey, 1, NULL); } break; case 758: { yyval = make_node (nod_dbkey, 1, yyvsp[-2]); } break; case 759: { yyval = make_node (nod_dom_value, 0, NULL); } break; case 760: { yyval = yyvsp[0]; } break; case 761: { if (client_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_dialect_datatype_unsupport, gds_arg_number, client_dialect, gds_arg_string, "DATE", 0); if (db_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_db_dialect_dtype_unsupport, gds_arg_number, db_dialect, gds_arg_string, "DATE", 0); yyval = make_node (nod_current_date, 0, NULL); } break; case 762: { if (client_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_dialect_datatype_unsupport, gds_arg_number, client_dialect, gds_arg_string, "TIME", 0); if (db_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_db_dialect_dtype_unsupport, gds_arg_number, db_dialect, gds_arg_string, "TIME", 0); yyval = make_node (nod_current_time, 0, NULL); } break; case 763: { yyval = make_node (nod_current_timestamp, 0, NULL); } break; case 764: { yyval = make_node (nod_array, 2, yyvsp[-3], make_list (yyvsp[-1])); } break; case 766: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 768: { yyval = make_node (nod_negate, 1, yyvsp[0]); } break; case 769: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_STRING); } break; case 770: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_SLONG); } break; case 771: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_DOUBLE); } break; case 772: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_SINT64); } break; case 773: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_SINT64); } break; case 775: { yyval = MAKE_str_constant ((STR) yyvsp[0], att_charset); } break; case 776: { if (client_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_dialect_datatype_unsupport, gds_arg_number, client_dialect, gds_arg_string, "DATE", 0); if (db_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_db_dialect_dtype_unsupport, gds_arg_number, db_dialect, gds_arg_string, "DATE", 0); yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_DATE); } break; case 777: { if (client_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_dialect_datatype_unsupport, gds_arg_number, client_dialect, gds_arg_string, "TIME", 0); if (db_dialect < SQL_DIALECT_V6_TRANSITION) ERRD_post (gds_sqlerr, gds_arg_number, (SLONG) -104, gds_arg_gds, isc_sql_db_dialect_dtype_unsupport, gds_arg_number, db_dialect, gds_arg_string, "TIME", 0); yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_TIME); } break; case 778: { yyval = MAKE_constant ((STR) yyvsp[0], CONSTANT_TIMESTAMP); } break; case 782: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 783: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 784: { yyval = make_node (nod_list, 2, yyvsp[-2], yyvsp[0]); } break; case 785: { yyval = make_node (nod_parameter, 0, NULL); } break; case 786: { yyval = make_node (nod_user_name, 0, NULL); } break; case 787: { yyval = yyvsp[0]; } break; case 788: { ((STR) yyvsp[0])->str_charset = (TEXT *) yyvsp[-1]; yyval = yyvsp[0]; } break; case 790: { yyval = (NOD) - (SLONG) yyvsp[0]; } break; case 791: { if ((SLONG) yyvsp[0] > SHRT_POS_MAX) yyabandon (-842, isc_expec_short); /* Short integer expected */ yyval = yyvsp[0];} break; case 792: { if ((SLONG) yyvsp[0] > SHRT_NEG_MAX) yyabandon (-842, isc_expec_short); /* Short integer expected */ yyval = yyvsp[0];} break; case 793: { if ((SLONG) yyvsp[0] == 0) yyabandon (-842, isc_expec_positive); /* Positive number expected */ yyval = yyvsp[0];} break; case 794: { if ((SLONG) yyvsp[0] > SHRT_UNSIGNED_MAX) yyabandon (-842, isc_expec_ushort); /* Unsigned short integer expected */ yyval = yyvsp[0];} break; case 796: { yyval = (NOD) - (SLONG) yyvsp[0]; } break; case 797: { yyval = yyvsp[0];} break; case 798: { yyval = make_node (nod_agg_count, 0, NULL); } break; case 799: { yyval = make_node (nod_agg_count, 1, yyvsp[-1]); } break; case 800: { yyval = make_flag_node (nod_agg_count, NOD_AGG_DISTINCT, 1, yyvsp[-1]); } break; case 801: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_agg_total2, 1, yyvsp[-1]); else yyval = make_node (nod_agg_total, 1, yyvsp[-1]); } break; case 802: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_flag_node (nod_agg_total2, NOD_AGG_DISTINCT, 1, yyvsp[-1]); else yyval = make_flag_node (nod_agg_total, NOD_AGG_DISTINCT, 1, yyvsp[-1]); } break; case 803: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_agg_average2, 1, yyvsp[-1]); else yyval = make_node (nod_agg_average, 1, yyvsp[-1]); } break; case 804: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_flag_node (nod_agg_average2, NOD_AGG_DISTINCT, 1, yyvsp[-1]); else yyval = make_flag_node (nod_agg_average, NOD_AGG_DISTINCT, 1, yyvsp[-1]); } break; case 805: { yyval = make_node (nod_agg_min, 1, yyvsp[-1]); } break; case 806: { yyval = make_node (nod_agg_min, 1, yyvsp[-1]); } break; case 807: { yyval = make_node (nod_agg_max, 1, yyvsp[-1]); } break; case 808: { yyval = make_node (nod_agg_max, 1, yyvsp[-1]); } break; case 809: { yyval = make_node (nod_cast, e_cast_count, yyvsp[-1], yyvsp[-3]); } break; case 810: { yyval = make_node (nod_upcase, 1, yyvsp[-1]); } break; case 811: { if (client_dialect >= SQL_DIALECT_V6_TRANSITION) yyval = make_node (nod_gen_id2, 2, yyvsp[-3], yyvsp[-1]); else yyval = make_node (nod_gen_id, 2, yyvsp[-3], yyvsp[-1]); } break; case 812: { yyval = make_node (nod_extract, e_extract_count, yyvsp[-3], yyvsp[-1]); } break; case 813: { yyval = make_node (nod_udf, 2, yyvsp[-3], yyvsp[-1]); } break; case 814: { yyval = make_node (nod_udf, 1, yyvsp[-2]); } break; case 815: { yyval = MAKE_constant ((STR)blr_extract_year, CONSTANT_SLONG); } break; case 816: { yyval = MAKE_constant ((STR)blr_extract_month, CONSTANT_SLONG); } break; case 817: { yyval = MAKE_constant ((STR)blr_extract_day, CONSTANT_SLONG); } break; case 818: { yyval = MAKE_constant ((STR)blr_extract_hour, CONSTANT_SLONG); } break; case 819: { yyval = MAKE_constant ((STR)blr_extract_minute, CONSTANT_SLONG); } break; case 820: { yyval = MAKE_constant ((STR)blr_extract_second, CONSTANT_SLONG); } break; case 821: { yyval = MAKE_constant ((STR)blr_extract_weekday, CONSTANT_SLONG); } break; case 822: { yyval = MAKE_constant ((STR)blr_extract_yearday, CONSTANT_SLONG); } break; case 825: { yyval = make_node (nod_null, 0, NULL); } break; } DSQL_DSQL_yyssp -= yym; yystate = *DSQL_DSQL_yyssp; yyvsp -= yym; yym = yylhs[yyn]; if (yystate == 0 && yym == 0) { #if YYDEBUG if (yydebug) printf("%sdebug: after reduction, shifting from state 0 to\ state %d\n", YYPREFIX, YYFINAL); #endif yystate = YYFINAL; *++DSQL_DSQL_yyssp = YYFINAL; *++yyvsp = yyval; if (DSQL_yychar < 0) { if ((DSQL_yychar = yylex(client_dialect, db_dialect, parser_version, stmt_ambiguous)) < 0) DSQL_yychar = 0; #if YYDEBUG if (yydebug) { yys = 0; if (DSQL_yychar <= YYMAXTOKEN) yys = yyname[DSQL_yychar]; if (!yys) yys = "illegal-symbol"; printf("%sdebug: state %d, reading %d (%s)\n", YYPREFIX, YYFINAL, DSQL_yychar, yys); } #endif } if (DSQL_yychar == 0) goto yyaccept; goto yyloop; } if ((yyn = yygindex[yym]) && (yyn += yystate) >= 0 && yyn <= YYTABLESIZE && yycheck[yyn] == yystate) yystate = yytable[yyn]; else yystate = yydgoto[yym]; #if YYDEBUG if (yydebug) printf("%sdebug: after reduction, shifting from state %d \ to state %d\n", YYPREFIX, *DSQL_DSQL_yyssp, yystate); #endif if (DSQL_DSQL_yyssp >= DSQL_yyss + yystacksize - 1) { goto yyoverflow; } *++DSQL_DSQL_yyssp = yystate; *++yyvsp = yyval; goto yyloop; yyoverflow: yyerror("yacc stack overflow"); yyabort: return (1); yyaccept: return (0); }