From fb8c78399ca481fd9b2a5fb969abe93c1a23dad99e5541ff824042d0ec3e5765 Mon Sep 17 00:00:00 2001 From: Benjamin Greiner Date: Tue, 28 Dec 2021 15:28:24 +0000 Subject: [PATCH] Accepting request 942935 from home:bnavigator:branches:devel:languages:python:numeric - Update to version 5.0 * https://docs.astropy.org/en/stable/whatsnew/5.0.html * Astropy 5.0 is a major release that adds significant new functionality since the 4.3.x series of releases. In addition, it is a long-term support release (LTS) which will be supported with bug fixes for two years. In particular, this release includes: * Support for reading, writing, and converting Cosmology * Cosmology units module * New Models * Added support for dask arrays in tables * Added support for registering array-like objects as mixin columns * Support for reading and writing tables to Parquet format * Support for reading and writing tables to MRT format * Support for masked quantity columns, including masked FITS columns with units * Converting SkyCoord to QTable * New Unified I/O architecture * In addition to these major changes, Astropy v5.0 includes a large number of smaller improvements and bug fixes, which are described in the Full Changelog. https://docs.astropy.org/en/stable/changelog.html#changelog - Drop patches fixed upstream * astropy-pr12006-cfitsio4.patch * astropy-pr12159-py310.patch OBS-URL: https://build.opensuse.org/request/show/942935 OBS-URL: https://build.opensuse.org/package/show/devel:languages:python:numeric/python-astropy?expand=0&rev=62 --- astropy-4.3.1.tar.gz | 3 - astropy-5.0.tar.gz | 3 + astropy-pr12006-cfitsio4.patch | 6061 -------------------------------- astropy-pr12159-py310.patch | 137 - python-astropy-rpmlintrc | 4 +- python-astropy.changes | 30 + python-astropy.spec | 42 +- 7 files changed, 58 insertions(+), 6222 deletions(-) delete mode 100644 astropy-4.3.1.tar.gz create mode 100644 astropy-5.0.tar.gz delete mode 100644 astropy-pr12006-cfitsio4.patch delete mode 100644 astropy-pr12159-py310.patch diff --git a/astropy-4.3.1.tar.gz b/astropy-4.3.1.tar.gz deleted file mode 100644 index 873b81a..0000000 --- a/astropy-4.3.1.tar.gz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:2d3951223b4eb7f368fcad8c8340d27374c5d8e3b635a636275acdb38f35cd51 -size 7632486 diff --git a/astropy-5.0.tar.gz b/astropy-5.0.tar.gz new file mode 100644 index 0000000..07563bc --- /dev/null +++ b/astropy-5.0.tar.gz @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:70203e151e13292586a817b4069ce1aad4643567aff38b1d191c173bc54f3927 +size 7823746 diff --git a/astropy-pr12006-cfitsio4.patch b/astropy-pr12006-cfitsio4.patch deleted file mode 100644 index f76b43f..0000000 --- a/astropy-pr12006-cfitsio4.patch +++ /dev/null @@ -1,6061 +0,0 @@ -From 78f20d5e7ba0f257d0caab324b8a4f8e411082a0 Mon Sep 17 00:00:00 2001 -From: Simon Conseil -Date: Thu, 29 Jul 2021 22:27:58 +0200 -Subject: [PATCH 1/3] Update cfitsio to v4.0.0 - ---- - cextern/cfitsio/docs/changes.txt | 44 + - cextern/cfitsio/lib/cfileio.c | 8 +- - cextern/cfitsio/lib/eval_defs.h | 4 +- - cextern/cfitsio/lib/eval_f.c | 16 +- - cextern/cfitsio/lib/eval_l.c | 91 +- - cextern/cfitsio/lib/eval_tab.h | 145 +- - cextern/cfitsio/lib/eval_y.c | 3278 ++++++++++--------- - cextern/cfitsio/lib/fitscore.c | 51 +- - cextern/cfitsio/lib/fitsio.h | 7 +- - cextern/cfitsio/lib/getcolb.c | 38 +- - cextern/cfitsio/lib/getkey.c | 7 +- - cextern/cfitsio/lib/putcol.c | 10 +- - cextern/cfitsio/lib/putcolb.c | 20 +- - cextern/cfitsio/lib/putkey.c | 44 +- - cextern/cfitsio/lib/region.c | 51 +- - cextern/cfitsio/{zlib => lib}/zcompress.c | 0 - cextern/cfitsio/{zlib => lib}/zuncompress.c | 0 - 17 files changed, 2092 insertions(+), 1722 deletions(-) - rename cextern/cfitsio/{zlib => lib}/zcompress.c (100%) - rename cextern/cfitsio/{zlib => lib}/zuncompress.c (100%) - -diff --git a/cextern/cfitsio/docs/changes.txt b/cextern/cfitsio/docs/changes.txt -index 8b5957fbed3..a17730a281d 100644 ---- a/cextern/cfitsio/docs/changes.txt -+++ b/cextern/cfitsio/docs/changes.txt -@@ -1,4 +1,48 @@ - Log of Changes Made to CFITSIO -+ -+Version 4.0.0 - May 2021 -+ -+ - Removed separate directory for zlib/gzip code, and updated -+ configuration to check for zlib on the user's system (required). -+ When use of cURL is enabled, it may also pull in zlib such -+ that user applications may not need to link with it separately. -+ -+ - Changed version numbering to 3-field format. -+ -+ - Added new calculator functions SETNULL(x,y) to allow substitution of -+ NULL values into tables, and GTIOVERLAP() for calculating the amount -+ of GTI overlap exposure for a time bin. -+ -+ - Fix added for proper handling of string columns with zero repeat -+ count. -+ -+ - Fix to column filtering expressions which write #NULL values to -+ columns of type (J) format. -+ -+ - Fix to memory clearing when using polygon shapes in region files. -+ -+ - Fix to fits_str2time function so that it now flags a particular case -+ of bad syntax which was previously getting through. -+ -+ - In ffgclb and ffpclb (read/write byte columns), the "undocumented" -+ feature of being able to transfer columns 'A' string columnss as -+ byte arrays is now handled correctly, with improved error checking -+ via updates to ffgcprll. More documentation on string handling is -+ in cfitsio.tex. -+ -+ - Fix bug in 'colfilter' functionality. When performing a -+ column deletion of the form -COLNAM*, and multiple matches -+ existed, then none of the matches got deleted. Now the -+ first is deleted as expected. -+ -+ - Improved handling of corner case in ffpkn functions. -+ -+ - In ffgky, modified TULONG case to allow it to read unsigned -+ values greater than the 8-byte signed limit. -+ -+ - Fix to parsing of corner case of extended file syntax. -+ -+ - Major updates to CMake configuration. - - Version 3.49 - Aug 2020 - -diff --git a/cextern/cfitsio/lib/cfileio.c b/cextern/cfitsio/lib/cfileio.c -index 209da61460a..c3732dda7b8 100644 ---- a/cextern/cfitsio/lib/cfileio.c -+++ b/cextern/cfitsio/lib/cfileio.c -@@ -2081,9 +2081,11 @@ int ffedit_columns( - Note no leading '#' - */ - } else if (clause1[0] && clause1[0] != '#' && -- ffgcno(*fptr, CASEINSEN, clause1, &colnum, status) <= 0) -+ ((ffgcno(*fptr, CASEINSEN, clause1, &colnum, status) <= 0) || -+ *status == COL_NOT_UNIQUE)) - { - /* a column with this name exists, so try to delete it */ -+ *status = 0; /* Clear potential status=COL_NOT_UNIQUE */ - if (ffdcol(*fptr, colnum, status) > 0) - { - ffpmsg("failed to delete column in input file:"); -@@ -2301,7 +2303,7 @@ int ffedit_columns( - - /* look for matching column */ - ffgcno(*fptr, CASEINSEN, colname, &testnum, status); -- -+ - while (*status == COL_NOT_UNIQUE) - { - /* the column name contained wild cards, and it */ -@@ -7071,7 +7073,7 @@ int ffexts(char *extspec, - - - ptr1 = strchr(ptr2, ')'); -- if (!ptr2) -+ if (!ptr1) - { - ffpmsg("illegal specification of image in table cell in input URL:"); - ffpmsg(" missing closing ')' character in row expression"); -diff --git a/cextern/cfitsio/lib/eval_defs.h b/cextern/cfitsio/lib/eval_defs.h -index 09c066b1da5..ba7a238f2cc 100644 ---- a/cextern/cfitsio/lib/eval_defs.h -+++ b/cextern/cfitsio/lib/eval_defs.h -@@ -143,7 +143,9 @@ typedef enum { - gasrnd_fct, - poirnd_fct, - strmid_fct, -- strpos_fct -+ strpos_fct, -+ setnull_fct, -+ gtiover_fct - } funcOp; - - extern ParseData gParse; -diff --git a/cextern/cfitsio/lib/eval_f.c b/cextern/cfitsio/lib/eval_f.c -index f4cd41a2e5e..464014ac698 100644 ---- a/cextern/cfitsio/lib/eval_f.c -+++ b/cextern/cfitsio/lib/eval_f.c -@@ -640,8 +640,12 @@ int ffcalc_rng( fitsfile *infptr, /* I - Input FITS file */ - nullVal = SHRT_MIN; - else if( typecode==TINT ) - nullVal = INT_MIN; -- else if( typecode==TLONG ) -- nullVal = LONG_MIN; -+ else if( typecode==TLONG ) { -+ if (sizeof(long) == 8 && sizeof(int) == 4) -+ nullVal = INT_MIN; -+ else -+ nullVal = LONG_MIN; -+ } - else if( typecode==TLONGLONG ) - nullVal = LONGLONG_MIN; - -@@ -2748,8 +2752,12 @@ int fits_pixel_filter (PixelFilter * filter, int * status) - nullVal = UCHAR_MAX; - else if (bitpix == SHORT_IMG) - nullVal = SHRT_MIN; -- else if (bitpix == LONG_IMG) -- nullVal = LONG_MIN; -+ else if (bitpix == LONG_IMG) { -+ if (sizeof(long) == 8 && sizeof(int) == 4) -+ nullVal = INT_MIN; -+ else -+ nullVal = LONG_MIN; -+ } - else - printf("unhandled positive output BITPIX %d\n", bitpix); - } -diff --git a/cextern/cfitsio/lib/eval_l.c b/cextern/cfitsio/lib/eval_l.c -index c5f91e454ff..deafa011f37 100644 ---- a/cextern/cfitsio/lib/eval_l.c -+++ b/cextern/cfitsio/lib/eval_l.c -@@ -46,6 +46,7 @@ typedef int16_t flex_int16_t; - typedef uint16_t flex_uint16_t; - typedef int32_t flex_int32_t; - typedef uint32_t flex_uint32_t; -+typedef uint64_t flex_uint64_t; - #else - typedef signed char flex_int8_t; - typedef short int flex_int16_t; -@@ -152,7 +153,12 @@ typedef unsigned int flex_uint32_t; - typedef struct ff_buffer_state *FF_BUFFER_STATE; - #endif - --extern int ffleng; -+#ifndef FF_TYPEDEF_FF_SIZE_T -+#define FF_TYPEDEF_FF_SIZE_T -+typedef size_t ff_size_t; -+#endif -+ -+extern ff_size_t ffleng; - - extern FILE *ffin, *ffout; - -@@ -178,11 +184,6 @@ extern FILE *ffin, *ffout; - - #define unput(c) ffunput( c, (fftext_ptr) ) - --#ifndef FF_TYPEDEF_FF_SIZE_T --#define FF_TYPEDEF_FF_SIZE_T --typedef size_t ff_size_t; --#endif -- - #ifndef FF_STRUCT_FF_BUFFER_STATE - #define FF_STRUCT_FF_BUFFER_STATE - struct ff_buffer_state -@@ -200,7 +201,7 @@ struct ff_buffer_state - /* Number of characters read into ff_ch_buf, not including EOB - * characters. - */ -- int ff_n_chars; -+ ff_size_t ff_n_chars; - - /* Whether we "own" the buffer - i.e., we know we created it, - * and can realloc() it to grow it, and should free() it to -@@ -270,8 +271,8 @@ static FF_BUFFER_STATE * ff_buffer_stack = 0; /**< Stack as an array. */ - - /* ff_hold_char holds the character lost when fftext is formed. */ - static char ff_hold_char; --static int ff_n_chars; /* number of characters read into ff_ch_buf */ --int ffleng; -+static ff_size_t ff_n_chars; /* number of characters read into ff_ch_buf */ -+ff_size_t ffleng; - - /* Points to current character in buffer. */ - static char *ff_c_buf_p = (char *) 0; -@@ -299,7 +300,7 @@ static void ff_init_buffer (FF_BUFFER_STATE b,FILE *file ); - - FF_BUFFER_STATE ff_scan_buffer (char *base,ff_size_t size ); - FF_BUFFER_STATE ff_scan_string (ffconst char *ff_str ); --FF_BUFFER_STATE ff_scan_bytes (ffconst char *bytes,int len ); -+FF_BUFFER_STATE ff_scan_bytes (ffconst char *bytes,ff_size_t len ); - - void *ffalloc (ff_size_t ); - void *ffrealloc (void *,ff_size_t ); -@@ -354,7 +355,7 @@ static void ff_fatal_error (ffconst char msg[] ); - */ - #define FF_DO_BEFORE_ACTION \ - (fftext_ptr) = ff_bp; \ -- ffleng = (size_t) (ff_cp - ff_bp); \ -+ ffleng = (ff_size_t) (ff_cp - ff_bp); \ - (ff_hold_char) = *ff_cp; \ - *ff_cp = '\0'; \ - (ff_c_buf_p) = ff_cp; -@@ -724,7 +725,7 @@ static int expr_read( char *buf, int nbytes ); - if ( (result = expr_read( (char *) buf, max_size )) < 0 ) \ - FF_FATAL_ERROR( "read() in flex scanner failed" ); - --#line 728 "" -+#line 729 "" - - #define INITIAL 0 - -@@ -763,7 +764,7 @@ FILE *ffget_out (void ); - - void ffset_out (FILE * out_str ); - --int ffget_leng (void ); -+ff_size_t ffget_leng (void ); - - char *ffget_text (void ); - -@@ -824,7 +825,7 @@ static int input (void ); - if ( FF_CURRENT_BUFFER_LVALUE->ff_is_interactive ) \ - { \ - int c = '*'; \ -- int n; \ -+ ff_size_t n; \ - for ( n = 0; n < max_size && \ - (c = getc( ffin )) != EOF && c != '\n'; ++n ) \ - buf[n] = (char) c; \ -@@ -909,7 +910,7 @@ FF_DECL - #line 146 "eval.l" - - --#line 913 "" -+#line 914 "" - - if ( !(ff_init) ) - { -@@ -1327,6 +1328,9 @@ FF_RULE_SETUP - else if( FSTRCMP(fname,"GTIFILTER(")==0 ) - return( GTIFILTER ); - -+ else if( FSTRCMP(fname,"GTIOVERLAP(")==0 ) -+ return( GTIOVERLAP ); -+ - else if( FSTRCMP(fname,"REGFILTER(")==0 ) - return( REGFILTER ); - -@@ -1339,86 +1343,86 @@ FF_RULE_SETUP - FF_BREAK - case 15: - FF_RULE_SETUP --#line 439 "eval.l" -+#line 442 "eval.l" - { return( INTCAST ); } - FF_BREAK - case 16: - FF_RULE_SETUP --#line 440 "eval.l" -+#line 443 "eval.l" - { return( FLTCAST ); } - FF_BREAK - case 17: - FF_RULE_SETUP --#line 441 "eval.l" -+#line 444 "eval.l" - { return( POWER ); } - FF_BREAK - case 18: - FF_RULE_SETUP --#line 442 "eval.l" -+#line 445 "eval.l" - { return( NOT ); } - FF_BREAK - case 19: - FF_RULE_SETUP --#line 443 "eval.l" -+#line 446 "eval.l" - { return( OR ); } - FF_BREAK - case 20: - FF_RULE_SETUP --#line 444 "eval.l" -+#line 447 "eval.l" - { return( AND ); } - FF_BREAK - case 21: - FF_RULE_SETUP --#line 445 "eval.l" -+#line 448 "eval.l" - { return( EQ ); } - FF_BREAK - case 22: - FF_RULE_SETUP --#line 446 "eval.l" -+#line 449 "eval.l" - { return( NE ); } - FF_BREAK - case 23: - FF_RULE_SETUP --#line 447 "eval.l" -+#line 450 "eval.l" - { return( GT ); } - FF_BREAK - case 24: - FF_RULE_SETUP --#line 448 "eval.l" -+#line 451 "eval.l" - { return( LT ); } - FF_BREAK - case 25: - FF_RULE_SETUP --#line 449 "eval.l" -+#line 452 "eval.l" - { return( GTE ); } - FF_BREAK - case 26: - FF_RULE_SETUP --#line 450 "eval.l" -+#line 453 "eval.l" - { return( LTE ); } - FF_BREAK - case 27: - FF_RULE_SETUP --#line 451 "eval.l" -+#line 454 "eval.l" - { return( XOR ); } - FF_BREAK - case 28: - /* rule 28 can match eol */ - FF_RULE_SETUP --#line 452 "eval.l" -+#line 455 "eval.l" - { return( '\n' ); } - FF_BREAK - case 29: - FF_RULE_SETUP --#line 453 "eval.l" -+#line 456 "eval.l" - { return( fftext[0] ); } - FF_BREAK - case 30: - FF_RULE_SETUP --#line 454 "eval.l" -+#line 457 "eval.l" - ECHO; - FF_BREAK --#line 1422 "" -+#line 1426 "" - case FF_STATE_EOF(INITIAL): - ffterminate(); - -@@ -1604,7 +1608,7 @@ static int ff_get_next_buffer (void) - - else - { -- int num_to_read = -+ ff_size_t num_to_read = - FF_CURRENT_BUFFER_LVALUE->ff_buf_size - number_to_move - 1; - - while ( num_to_read <= 0 ) -@@ -1618,7 +1622,7 @@ static int ff_get_next_buffer (void) - - if ( b->ff_is_our_buffer ) - { -- int new_size = b->ff_buf_size * 2; -+ ff_size_t new_size = b->ff_buf_size * 2; - - if ( new_size <= 0 ) - b->ff_buf_size += b->ff_buf_size / 8; -@@ -1649,7 +1653,7 @@ static int ff_get_next_buffer (void) - - /* Read in more data. */ - FF_INPUT( (&FF_CURRENT_BUFFER_LVALUE->ff_ch_buf[number_to_move]), -- (ff_n_chars), (size_t) num_to_read ); -+ (ff_n_chars), num_to_read ); - - FF_CURRENT_BUFFER_LVALUE->ff_n_chars = (ff_n_chars); - } -@@ -1759,7 +1763,7 @@ static int ff_get_next_buffer (void) - if ( ff_cp < FF_CURRENT_BUFFER_LVALUE->ff_ch_buf + 2 ) - { /* need to shift things up to make room */ - /* +2 for EOB chars. */ -- register int number_to_move = (ff_n_chars) + 2; -+ register ff_size_t number_to_move = (ff_n_chars) + 2; - register char *dest = &FF_CURRENT_BUFFER_LVALUE->ff_ch_buf[ - FF_CURRENT_BUFFER_LVALUE->ff_buf_size + 2]; - register char *source = -@@ -1808,7 +1812,7 @@ static int ff_get_next_buffer (void) - - else - { /* need more input */ -- int offset = (ff_c_buf_p) - (fftext_ptr); -+ ff_size_t offset = (ff_c_buf_p) - (fftext_ptr); - ++(ff_c_buf_p); - - switch ( ff_get_next_buffer( ) ) -@@ -1832,7 +1836,7 @@ static int ff_get_next_buffer (void) - case EOB_ACT_END_OF_FILE: - { - if ( ffwrap( ) ) -- return EOF; -+ return 0; - - if ( ! (ff_did_buffer_switch_on_eof) ) - FF_NEW_FILE; -@@ -2084,7 +2088,7 @@ void ffpop_buffer_state (void) - */ - static void ffensure_buffer_stack (void) - { -- int num_to_alloc; -+ ff_size_t num_to_alloc; - - if (!(ff_buffer_stack)) { - -@@ -2181,12 +2185,11 @@ FF_BUFFER_STATE ff_scan_string (ffconst char * ffstr ) - * - * @return the newly allocated buffer state object. - */ --FF_BUFFER_STATE ff_scan_bytes (ffconst char * ffbytes, int _ffbytes_len ) -+FF_BUFFER_STATE ff_scan_bytes (ffconst char * ffbytes, ff_size_t _ffbytes_len ) - { - FF_BUFFER_STATE b; - char *buf; -- ff_size_t n; -- int i; -+ ff_size_t n, i; - - /* Get memory for full buffer, including space for trailing EOB's. */ - n = _ffbytes_len + 2; -@@ -2268,7 +2271,7 @@ FILE *ffget_out (void) - /** Get the length of the current token. - * - */ --int ffget_leng (void) -+ff_size_t ffget_leng (void) - { - return ffleng; - } -@@ -2416,7 +2419,7 @@ void yyfffree (void * ptr ) - - #define FFTABLES_NAME "fftables" - --#line 454 "eval.l" -+#line 457 "eval.l" - - - -diff --git a/cextern/cfitsio/lib/eval_tab.h b/cextern/cfitsio/lib/eval_tab.h -index 16560547d44..401a4be3e93 100644 ---- a/cextern/cfitsio/lib/eval_tab.h -+++ b/cextern/cfitsio/lib/eval_tab.h -@@ -1,8 +1,9 @@ --/* A Bison parser, made by GNU Bison 3.0.5. */ -+/* A Bison parser, made by GNU Bison 3.7.4. */ - - /* Bison interface for Yacc-like parsers in C - -- Copyright (C) 1984, 1989-1990, 2000-2015, 2018 Free Software Foundation, Inc. -+ Copyright (C) 1984, 1989-1990, 2000-2015, 2018-2020 Free Software Foundation, -+ Inc. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by -@@ -30,6 +31,10 @@ - This special exception was added by the Free Software Foundation in - version 2.2 of Bison. */ - -+/* DO NOT RELY ON FEATURES THAT ARE NOT DOCUMENTED in the manual, -+ especially those whose name start with FF_ or ff_. They are -+ private implementation details that can be changed or removed. */ -+ - #ifndef FF_FF_Y_TAB_H_INCLUDED - # define FF_FF_Y_TAB_H_INCLUDED - /* Debug traces. */ -@@ -40,47 +45,57 @@ - extern int ffdebug; - #endif - --/* Token type. */ -+/* Token kinds. */ - #ifndef FFTOKENTYPE - # define FFTOKENTYPE - enum fftokentype - { -- BOOLEAN = 258, -- LONG = 259, -- DOUBLE = 260, -- STRING = 261, -- BITSTR = 262, -- FUNCTION = 263, -- BFUNCTION = 264, -- IFUNCTION = 265, -- GTIFILTER = 266, -- REGFILTER = 267, -- COLUMN = 268, -- BCOLUMN = 269, -- SCOLUMN = 270, -- BITCOL = 271, -- ROWREF = 272, -- NULLREF = 273, -- SNULLREF = 274, -- OR = 275, -- AND = 276, -- EQ = 277, -- NE = 278, -- GT = 279, -- LT = 280, -- LTE = 281, -- GTE = 282, -- XOR = 283, -- POWER = 284, -- NOT = 285, -- INTCAST = 286, -- FLTCAST = 287, -- UMINUS = 288, -- ACCUM = 289, -- DIFF = 290 -+ FFEMPTY = -2, -+ FFEOF = 0, /* "end of file" */ -+ FFerror = 256, /* error */ -+ FFUNDEF = 257, /* "invalid token" */ -+ BOOLEAN = 258, /* BOOLEAN */ -+ LONG = 259, /* LONG */ -+ DOUBLE = 260, /* DOUBLE */ -+ STRING = 261, /* STRING */ -+ BITSTR = 262, /* BITSTR */ -+ FUNCTION = 263, /* FUNCTION */ -+ BFUNCTION = 264, /* BFUNCTION */ -+ IFUNCTION = 265, /* IFUNCTION */ -+ GTIFILTER = 266, /* GTIFILTER */ -+ GTIOVERLAP = 267, /* GTIOVERLAP */ -+ REGFILTER = 268, /* REGFILTER */ -+ COLUMN = 269, /* COLUMN */ -+ BCOLUMN = 270, /* BCOLUMN */ -+ SCOLUMN = 271, /* SCOLUMN */ -+ BITCOL = 272, /* BITCOL */ -+ ROWREF = 273, /* ROWREF */ -+ NULLREF = 274, /* NULLREF */ -+ SNULLREF = 275, /* SNULLREF */ -+ OR = 276, /* OR */ -+ AND = 277, /* AND */ -+ EQ = 278, /* EQ */ -+ NE = 279, /* NE */ -+ GT = 280, /* GT */ -+ LT = 281, /* LT */ -+ LTE = 282, /* LTE */ -+ GTE = 283, /* GTE */ -+ XOR = 284, /* XOR */ -+ POWER = 285, /* POWER */ -+ NOT = 286, /* NOT */ -+ INTCAST = 287, /* INTCAST */ -+ FLTCAST = 288, /* FLTCAST */ -+ UMINUS = 289, /* UMINUS */ -+ ACCUM = 290, /* ACCUM */ -+ DIFF = 291 /* DIFF */ - }; -+ typedef enum fftokentype fftoken_kind_t; - #endif --/* Tokens. */ -+/* Token kinds. */ -+#define FFEMPTY -2 -+#define FFEOF 0 -+#define FFerror 256 -+#define FFUNDEF 257 - #define BOOLEAN 258 - #define LONG 259 - #define DOUBLE 260 -@@ -90,37 +105,37 @@ extern int ffdebug; - #define BFUNCTION 264 - #define IFUNCTION 265 - #define GTIFILTER 266 --#define REGFILTER 267 --#define COLUMN 268 --#define BCOLUMN 269 --#define SCOLUMN 270 --#define BITCOL 271 --#define ROWREF 272 --#define NULLREF 273 --#define SNULLREF 274 --#define OR 275 --#define AND 276 --#define EQ 277 --#define NE 278 --#define GT 279 --#define LT 280 --#define LTE 281 --#define GTE 282 --#define XOR 283 --#define POWER 284 --#define NOT 285 --#define INTCAST 286 --#define FLTCAST 287 --#define UMINUS 288 --#define ACCUM 289 --#define DIFF 290 -+#define GTIOVERLAP 267 -+#define REGFILTER 268 -+#define COLUMN 269 -+#define BCOLUMN 270 -+#define SCOLUMN 271 -+#define BITCOL 272 -+#define ROWREF 273 -+#define NULLREF 274 -+#define SNULLREF 275 -+#define OR 276 -+#define AND 277 -+#define EQ 278 -+#define NE 279 -+#define GT 280 -+#define LT 281 -+#define LTE 282 -+#define GTE 283 -+#define XOR 284 -+#define POWER 285 -+#define NOT 286 -+#define INTCAST 287 -+#define FLTCAST 288 -+#define UMINUS 289 -+#define ACCUM 290 -+#define DIFF 291 - - /* Value type. */ - #if ! defined FFSTYPE && ! defined FFSTYPE_IS_DECLARED -- - union FFSTYPE - { --#line 192 "eval.y" /* yacc.c:1910 */ -+#line 199 "eval.y" - - int Node; /* Index of Node */ - double dbl; /* real value */ -@@ -128,9 +143,9 @@ union FFSTYPE - char log; /* logical value */ - char str[MAX_STRLEN]; /* string value */ - --#line 132 "y.tab.h" /* yacc.c:1910 */ --}; -+#line 147 "y.tab.h" - -+}; - typedef union FFSTYPE FFSTYPE; - # define FFSTYPE_IS_TRIVIAL 1 - # define FFSTYPE_IS_DECLARED 1 -diff --git a/cextern/cfitsio/lib/eval_y.c b/cextern/cfitsio/lib/eval_y.c -index f1e48bae9c3..0e136dfd17c 100644 ---- a/cextern/cfitsio/lib/eval_y.c -+++ b/cextern/cfitsio/lib/eval_y.c -@@ -1,8 +1,9 @@ --/* A Bison parser, made by GNU Bison 3.0.5. */ -+/* A Bison parser, made by GNU Bison 3.7.4. */ - - /* Bison implementation for Yacc-like parsers in C - -- Copyright (C) 1984, 1989-1990, 2000-2015, 2018 Free Software Foundation, Inc. -+ Copyright (C) 1984, 1989-1990, 2000-2015, 2018-2020 Free Software Foundation, -+ Inc. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by -@@ -33,6 +34,10 @@ - /* C LALR(1) parser skeleton written by Richard Stallman, by - simplifying the original so-called "semantic" parser. */ - -+/* DO NOT RELY ON FEATURES THAT ARE NOT DOCUMENTED in the manual, -+ especially those whose name start with FF_ or ff_. They are -+ private implementation details that can be changed or removed. */ -+ - /* All symbols defined below should begin with ff or FF, to avoid - infringing on user name space. This should be done even for local - variables, as they might otherwise be expanded by user macros. -@@ -40,11 +45,11 @@ - define necessary library symbols; they are noted "INFRINGES ON - USER NAME SPACE" below. */ - --/* Identify Bison output. */ --#define FFBISON 1 -+/* Identify Bison output, and Bison version. */ -+#define FFBISON 30704 - --/* Bison version. */ --#define FFBISON_VERSION "3.0.5" -+/* Bison version string. */ -+#define FFBISON_VERSION "3.7.4" - - /* Skeleton name. */ - #define FFSKELETON_NAME "yacc.c" -@@ -61,8 +66,8 @@ - - - --/* Copy the first part of user declarations. */ --#line 1 "eval.y" /* yacc.c:339 */ -+/* First part of user prologue. */ -+#line 1 "eval.y" - - /************************************************************************/ - /* */ -@@ -128,6 +133,9 @@ - /* determine the output dimensions */ - /* Craig B Markwardt Aug 2009 Add substring STRMID() and string search*/ - /* STRSTR() functions; more overflow checks*/ -+/* Craig B Markwardt Dec 2019 Add bit/hex/oct literal strings and */ -+/* bitwise operatiosn between integers */ -+/* Craig B Markwardt Mar 2021 Add SETNULL() function */ - /* */ - /************************************************************************/ - -@@ -205,7 +213,7 @@ static int New_FuncSize( int returnType, funcOp Op, int nNodes, - int Node5, int Node6, int Node7, int Size); - static int New_Deref ( int Var, int nDim, - int Dim1, int Dim2, int Dim3, int Dim4, int Dim5 ); --static int New_GTI ( char *fname, int Node1, char *start, char *stop ); -+static int New_GTI ( funcOp Op, char *fname, int Node1, int Node2, char *start, char *stop ); - static int New_REG ( char *fname, int NodeX, int NodeY, char *colNames ); - static int New_Vector( int subNode ); - static int Close_Vec ( int vecNode ); -@@ -224,11 +232,15 @@ static void Do_BinOp_dbl ( Node *this ); - static void Do_Func ( Node *this ); - static void Do_Deref ( Node *this ); - static void Do_GTI ( Node *this ); -+static void Do_GTI_Over ( Node *this ); - static void Do_REG ( Node *this ); - static void Do_Vector ( Node *this ); - - static long Search_GTI ( double evtTime, long nGTI, double *start, -- double *stop, int ordered ); -+ double *stop, int ordered, long *nextGTI ); -+static double GTI_Over(double evtStart, double evtStop, -+ long nGTI, double *start, double *stop, -+ long *gtiout); - - static char saobox (double xcen, double ycen, double xwid, double ywid, - double rot, double xcol, double ycol); -@@ -253,26 +265,31 @@ static void fferror(char *msg); - #endif - - --#line 257 "y.tab.c" /* yacc.c:339 */ -+#line 269 "y.tab.c" - -+# ifndef FF_CAST -+# ifdef __cplusplus -+# define FF_CAST(Type, Val) static_cast (Val) -+# define FF_REINTERPRET_CAST(Type, Val) reinterpret_cast (Val) -+# else -+# define FF_CAST(Type, Val) ((Type) (Val)) -+# define FF_REINTERPRET_CAST(Type, Val) ((Type) (Val)) -+# endif -+# endif - # ifndef FF_NULLPTR --# if defined __cplusplus && 201103L <= __cplusplus --# define FF_NULLPTR nullptr -+# if defined __cplusplus -+# if 201103L <= __cplusplus -+# define FF_NULLPTR nullptr -+# else -+# define FF_NULLPTR 0 -+# endif - # else --# define FF_NULLPTR 0 -+# define FF_NULLPTR ((void*)0) - # endif - # endif - --/* Enabling verbose error messages. */ --#ifdef FFERROR_VERBOSE --# undef FFERROR_VERBOSE --# define FFERROR_VERBOSE 1 --#else --# define FFERROR_VERBOSE 0 --#endif -- --/* In a future release of Bison, this section will be replaced -- by #include "y.tab.h". */ -+/* Use api.header.include to #include this header -+ instead of duplicating it here. */ - #ifndef FF_FF_Y_TAB_H_INCLUDED - # define FF_FF_Y_TAB_H_INCLUDED - /* Debug traces. */ -@@ -283,47 +300,57 @@ static void fferror(char *msg); - extern int ffdebug; - #endif - --/* Token type. */ -+/* Token kinds. */ - #ifndef FFTOKENTYPE - # define FFTOKENTYPE - enum fftokentype - { -- BOOLEAN = 258, -- LONG = 259, -- DOUBLE = 260, -- STRING = 261, -- BITSTR = 262, -- FUNCTION = 263, -- BFUNCTION = 264, -- IFUNCTION = 265, -- GTIFILTER = 266, -- REGFILTER = 267, -- COLUMN = 268, -- BCOLUMN = 269, -- SCOLUMN = 270, -- BITCOL = 271, -- ROWREF = 272, -- NULLREF = 273, -- SNULLREF = 274, -- OR = 275, -- AND = 276, -- EQ = 277, -- NE = 278, -- GT = 279, -- LT = 280, -- LTE = 281, -- GTE = 282, -- XOR = 283, -- POWER = 284, -- NOT = 285, -- INTCAST = 286, -- FLTCAST = 287, -- UMINUS = 288, -- ACCUM = 289, -- DIFF = 290 -+ FFEMPTY = -2, -+ FFEOF = 0, /* "end of file" */ -+ FFerror = 256, /* error */ -+ FFUNDEF = 257, /* "invalid token" */ -+ BOOLEAN = 258, /* BOOLEAN */ -+ LONG = 259, /* LONG */ -+ DOUBLE = 260, /* DOUBLE */ -+ STRING = 261, /* STRING */ -+ BITSTR = 262, /* BITSTR */ -+ FUNCTION = 263, /* FUNCTION */ -+ BFUNCTION = 264, /* BFUNCTION */ -+ IFUNCTION = 265, /* IFUNCTION */ -+ GTIFILTER = 266, /* GTIFILTER */ -+ GTIOVERLAP = 267, /* GTIOVERLAP */ -+ REGFILTER = 268, /* REGFILTER */ -+ COLUMN = 269, /* COLUMN */ -+ BCOLUMN = 270, /* BCOLUMN */ -+ SCOLUMN = 271, /* SCOLUMN */ -+ BITCOL = 272, /* BITCOL */ -+ ROWREF = 273, /* ROWREF */ -+ NULLREF = 274, /* NULLREF */ -+ SNULLREF = 275, /* SNULLREF */ -+ OR = 276, /* OR */ -+ AND = 277, /* AND */ -+ EQ = 278, /* EQ */ -+ NE = 279, /* NE */ -+ GT = 280, /* GT */ -+ LT = 281, /* LT */ -+ LTE = 282, /* LTE */ -+ GTE = 283, /* GTE */ -+ XOR = 284, /* XOR */ -+ POWER = 285, /* POWER */ -+ NOT = 286, /* NOT */ -+ INTCAST = 287, /* INTCAST */ -+ FLTCAST = 288, /* FLTCAST */ -+ UMINUS = 289, /* UMINUS */ -+ ACCUM = 290, /* ACCUM */ -+ DIFF = 291 /* DIFF */ - }; -+ typedef enum fftokentype fftoken_kind_t; - #endif --/* Tokens. */ -+/* Token kinds. */ -+#define FFEMPTY -2 -+#define FFEOF 0 -+#define FFerror 256 -+#define FFUNDEF 257 - #define BOOLEAN 258 - #define LONG 259 - #define DOUBLE 260 -@@ -333,37 +360,37 @@ extern int ffdebug; - #define BFUNCTION 264 - #define IFUNCTION 265 - #define GTIFILTER 266 --#define REGFILTER 267 --#define COLUMN 268 --#define BCOLUMN 269 --#define SCOLUMN 270 --#define BITCOL 271 --#define ROWREF 272 --#define NULLREF 273 --#define SNULLREF 274 --#define OR 275 --#define AND 276 --#define EQ 277 --#define NE 278 --#define GT 279 --#define LT 280 --#define LTE 281 --#define GTE 282 --#define XOR 283 --#define POWER 284 --#define NOT 285 --#define INTCAST 286 --#define FLTCAST 287 --#define UMINUS 288 --#define ACCUM 289 --#define DIFF 290 -+#define GTIOVERLAP 267 -+#define REGFILTER 268 -+#define COLUMN 269 -+#define BCOLUMN 270 -+#define SCOLUMN 271 -+#define BITCOL 272 -+#define ROWREF 273 -+#define NULLREF 274 -+#define SNULLREF 275 -+#define OR 276 -+#define AND 277 -+#define EQ 278 -+#define NE 279 -+#define GT 280 -+#define LT 281 -+#define LTE 282 -+#define GTE 283 -+#define XOR 284 -+#define POWER 285 -+#define NOT 286 -+#define INTCAST 287 -+#define FLTCAST 288 -+#define UMINUS 289 -+#define ACCUM 290 -+#define DIFF 291 - - /* Value type. */ - #if ! defined FFSTYPE && ! defined FFSTYPE_IS_DECLARED -- - union FFSTYPE - { --#line 192 "eval.y" /* yacc.c:355 */ -+#line 199 "eval.y" - - int Node; /* Index of Node */ - double dbl; /* real value */ -@@ -371,9 +398,9 @@ union FFSTYPE - char log; /* logical value */ - char str[MAX_STRLEN]; /* string value */ - --#line 375 "y.tab.c" /* yacc.c:355 */ --}; -+#line 402 "y.tab.c" - -+}; - typedef union FFSTYPE FFSTYPE; - # define FFSTYPE_IS_TRIVIAL 1 - # define FFSTYPE_IS_DECLARED 1 -@@ -385,37 +412,154 @@ extern FFSTYPE fflval; - int ffparse (void); - - #endif /* !FF_FF_Y_TAB_H_INCLUDED */ -+/* Symbol kind. */ -+enum ffsymbol_kind_t -+{ -+ FFSYMBOL_FFEMPTY = -2, -+ FFSYMBOL_FFEOF = 0, /* "end of file" */ -+ FFSYMBOL_FFerror = 1, /* error */ -+ FFSYMBOL_FFUNDEF = 2, /* "invalid token" */ -+ FFSYMBOL_BOOLEAN = 3, /* BOOLEAN */ -+ FFSYMBOL_LONG = 4, /* LONG */ -+ FFSYMBOL_DOUBLE = 5, /* DOUBLE */ -+ FFSYMBOL_STRING = 6, /* STRING */ -+ FFSYMBOL_BITSTR = 7, /* BITSTR */ -+ FFSYMBOL_FUNCTION = 8, /* FUNCTION */ -+ FFSYMBOL_BFUNCTION = 9, /* BFUNCTION */ -+ FFSYMBOL_IFUNCTION = 10, /* IFUNCTION */ -+ FFSYMBOL_GTIFILTER = 11, /* GTIFILTER */ -+ FFSYMBOL_GTIOVERLAP = 12, /* GTIOVERLAP */ -+ FFSYMBOL_REGFILTER = 13, /* REGFILTER */ -+ FFSYMBOL_COLUMN = 14, /* COLUMN */ -+ FFSYMBOL_BCOLUMN = 15, /* BCOLUMN */ -+ FFSYMBOL_SCOLUMN = 16, /* SCOLUMN */ -+ FFSYMBOL_BITCOL = 17, /* BITCOL */ -+ FFSYMBOL_ROWREF = 18, /* ROWREF */ -+ FFSYMBOL_NULLREF = 19, /* NULLREF */ -+ FFSYMBOL_SNULLREF = 20, /* SNULLREF */ -+ FFSYMBOL_21_ = 21, /* ',' */ -+ FFSYMBOL_22_ = 22, /* '=' */ -+ FFSYMBOL_23_ = 23, /* ':' */ -+ FFSYMBOL_24_ = 24, /* '{' */ -+ FFSYMBOL_25_ = 25, /* '}' */ -+ FFSYMBOL_26_ = 26, /* '?' */ -+ FFSYMBOL_OR = 27, /* OR */ -+ FFSYMBOL_AND = 28, /* AND */ -+ FFSYMBOL_EQ = 29, /* EQ */ -+ FFSYMBOL_NE = 30, /* NE */ -+ FFSYMBOL_31_ = 31, /* '~' */ -+ FFSYMBOL_GT = 32, /* GT */ -+ FFSYMBOL_LT = 33, /* LT */ -+ FFSYMBOL_LTE = 34, /* LTE */ -+ FFSYMBOL_GTE = 35, /* GTE */ -+ FFSYMBOL_36_ = 36, /* '+' */ -+ FFSYMBOL_37_ = 37, /* '-' */ -+ FFSYMBOL_38_ = 38, /* '%' */ -+ FFSYMBOL_39_ = 39, /* '*' */ -+ FFSYMBOL_40_ = 40, /* '/' */ -+ FFSYMBOL_41_ = 41, /* '|' */ -+ FFSYMBOL_42_ = 42, /* '&' */ -+ FFSYMBOL_XOR = 43, /* XOR */ -+ FFSYMBOL_POWER = 44, /* POWER */ -+ FFSYMBOL_NOT = 45, /* NOT */ -+ FFSYMBOL_INTCAST = 46, /* INTCAST */ -+ FFSYMBOL_FLTCAST = 47, /* FLTCAST */ -+ FFSYMBOL_UMINUS = 48, /* UMINUS */ -+ FFSYMBOL_49_ = 49, /* '[' */ -+ FFSYMBOL_ACCUM = 50, /* ACCUM */ -+ FFSYMBOL_DIFF = 51, /* DIFF */ -+ FFSYMBOL_52_n_ = 52, /* '\n' */ -+ FFSYMBOL_53_ = 53, /* ']' */ -+ FFSYMBOL_54_ = 54, /* '(' */ -+ FFSYMBOL_55_ = 55, /* ')' */ -+ FFSYMBOL_FFACCEPT = 56, /* $accept */ -+ FFSYMBOL_lines = 57, /* lines */ -+ FFSYMBOL_line = 58, /* line */ -+ FFSYMBOL_bvector = 59, /* bvector */ -+ FFSYMBOL_vector = 60, /* vector */ -+ FFSYMBOL_expr = 61, /* expr */ -+ FFSYMBOL_bexpr = 62, /* bexpr */ -+ FFSYMBOL_bits = 63, /* bits */ -+ FFSYMBOL_sexpr = 64 /* sexpr */ -+}; -+typedef enum ffsymbol_kind_t ffsymbol_kind_t; -+ - --/* Copy the second part of user declarations. */ - --#line 392 "y.tab.c" /* yacc.c:358 */ - - #ifdef short - # undef short - #endif - --#ifdef FFTYPE_UINT8 --typedef FFTYPE_UINT8 fftype_uint8; --#else --typedef unsigned char fftype_uint8; -+/* On compilers that do not define __PTRDIFF_MAX__ etc., make sure -+ and (if available) are included -+ so that the code can choose integer types of a good width. */ -+ -+#ifndef __PTRDIFF_MAX__ -+# include /* INFRINGES ON USER NAME SPACE */ -+# if defined __STDC_VERSION__ && 199901 <= __STDC_VERSION__ -+# include /* INFRINGES ON USER NAME SPACE */ -+# define FF_STDINT_H -+# endif - #endif - --#ifdef FFTYPE_INT8 --typedef FFTYPE_INT8 fftype_int8; -+/* Narrow types that promote to a signed type and that can represent a -+ signed or unsigned integer of at least N bits. In tables they can -+ save space and decrease cache pressure. Promoting to a signed type -+ helps avoid bugs in integer arithmetic. */ -+ -+#ifdef __INT_LEAST8_MAX__ -+typedef __INT_LEAST8_TYPE__ fftype_int8; -+#elif defined FF_STDINT_H -+typedef int_least8_t fftype_int8; - #else - typedef signed char fftype_int8; - #endif - --#ifdef FFTYPE_UINT16 --typedef FFTYPE_UINT16 fftype_uint16; -+#ifdef __INT_LEAST16_MAX__ -+typedef __INT_LEAST16_TYPE__ fftype_int16; -+#elif defined FF_STDINT_H -+typedef int_least16_t fftype_int16; -+#else -+typedef short fftype_int16; -+#endif -+ -+#if defined __UINT_LEAST8_MAX__ && __UINT_LEAST8_MAX__ <= __INT_MAX__ -+typedef __UINT_LEAST8_TYPE__ fftype_uint8; -+#elif (!defined __UINT_LEAST8_MAX__ && defined FF_STDINT_H \ -+ && UINT_LEAST8_MAX <= INT_MAX) -+typedef uint_least8_t fftype_uint8; -+#elif !defined __UINT_LEAST8_MAX__ && UCHAR_MAX <= INT_MAX -+typedef unsigned char fftype_uint8; - #else --typedef unsigned short int fftype_uint16; -+typedef short fftype_uint8; - #endif - --#ifdef FFTYPE_INT16 --typedef FFTYPE_INT16 fftype_int16; -+#if defined __UINT_LEAST16_MAX__ && __UINT_LEAST16_MAX__ <= __INT_MAX__ -+typedef __UINT_LEAST16_TYPE__ fftype_uint16; -+#elif (!defined __UINT_LEAST16_MAX__ && defined FF_STDINT_H \ -+ && UINT_LEAST16_MAX <= INT_MAX) -+typedef uint_least16_t fftype_uint16; -+#elif !defined __UINT_LEAST16_MAX__ && USHRT_MAX <= INT_MAX -+typedef unsigned short fftype_uint16; - #else --typedef short int fftype_int16; -+typedef int fftype_uint16; -+#endif -+ -+#ifndef FFPTRDIFF_T -+# if defined __PTRDIFF_TYPE__ && defined __PTRDIFF_MAX__ -+# define FFPTRDIFF_T __PTRDIFF_TYPE__ -+# define FFPTRDIFF_MAXIMUM __PTRDIFF_MAX__ -+# elif defined PTRDIFF_MAX -+# ifndef ptrdiff_t -+# include /* INFRINGES ON USER NAME SPACE */ -+# endif -+# define FFPTRDIFF_T ptrdiff_t -+# define FFPTRDIFF_MAXIMUM PTRDIFF_MAX -+# else -+# define FFPTRDIFF_T long -+# define FFPTRDIFF_MAXIMUM LONG_MAX -+# endif - #endif - - #ifndef FFSIZE_T -@@ -423,15 +567,28 @@ typedef short int fftype_int16; - # define FFSIZE_T __SIZE_TYPE__ - # elif defined size_t - # define FFSIZE_T size_t --# elif ! defined FFSIZE_T -+# elif defined __STDC_VERSION__ && 199901 <= __STDC_VERSION__ - # include /* INFRINGES ON USER NAME SPACE */ - # define FFSIZE_T size_t - # else --# define FFSIZE_T unsigned int -+# define FFSIZE_T unsigned - # endif - #endif - --#define FFSIZE_MAXIMUM ((FFSIZE_T) -1) -+#define FFSIZE_MAXIMUM \ -+ FF_CAST (FFPTRDIFF_T, \ -+ (FFPTRDIFF_MAXIMUM < FF_CAST (FFSIZE_T, -1) \ -+ ? FFPTRDIFF_MAXIMUM \ -+ : FF_CAST (FFSIZE_T, -1))) -+ -+#define FFSIZEOF(X) FF_CAST (FFPTRDIFF_T, sizeof (X)) -+ -+ -+/* Stored state numbers (used for stacks). */ -+typedef fftype_int16 ff_state_t; -+ -+/* State numbers in computations. */ -+typedef int ff_state_fast_t; - - #ifndef FF_ - # if defined FFENABLE_NLS && FFENABLE_NLS -@@ -445,30 +602,20 @@ typedef short int fftype_int16; - # endif - #endif - --#ifndef FF_ATTRIBUTE --# if (defined __GNUC__ \ -- && (2 < __GNUC__ || (__GNUC__ == 2 && 96 <= __GNUC_MINOR__))) \ -- || defined __SUNPRO_C && 0x5110 <= __SUNPRO_C --# define FF_ATTRIBUTE(Spec) __attribute__(Spec) --# else --# define FF_ATTRIBUTE(Spec) /* empty */ --# endif --#endif - - #ifndef FF_ATTRIBUTE_PURE --# define FF_ATTRIBUTE_PURE FF_ATTRIBUTE ((__pure__)) -+# if defined __GNUC__ && 2 < __GNUC__ + (96 <= __GNUC_MINOR__) -+# define FF_ATTRIBUTE_PURE __attribute__ ((__pure__)) -+# else -+# define FF_ATTRIBUTE_PURE -+# endif - #endif - - #ifndef FF_ATTRIBUTE_UNUSED --# define FF_ATTRIBUTE_UNUSED FF_ATTRIBUTE ((__unused__)) --#endif -- --#if !defined _Noreturn \ -- && (!defined __STDC_VERSION__ || __STDC_VERSION__ < 201112) --# if defined _MSC_VER && 1200 <= _MSC_VER --# define _Noreturn __declspec (noreturn) -+# if defined __GNUC__ && 2 < __GNUC__ + (7 <= __GNUC_MINOR__) -+# define FF_ATTRIBUTE_UNUSED __attribute__ ((__unused__)) - # else --# define _Noreturn FF_ATTRIBUTE ((__noreturn__)) -+# define FF_ATTRIBUTE_UNUSED - # endif - #endif - -@@ -479,13 +626,13 @@ typedef short int fftype_int16; - # define FFUSE(E) /* empty */ - #endif - --#if defined __GNUC__ && 407 <= __GNUC__ * 100 + __GNUC_MINOR__ -+#if defined __GNUC__ && ! defined __ICC && 407 <= __GNUC__ * 100 + __GNUC_MINOR__ - /* Suppress an incorrect diagnostic about fflval being uninitialized. */ --# define FF_IGNORE_MAYBE_UNINITIALIZED_BEGIN \ -- _Pragma ("GCC diagnostic push") \ -- _Pragma ("GCC diagnostic ignored \"-Wuninitialized\"")\ -+# define FF_IGNORE_MAYBE_UNINITIALIZED_BEGIN \ -+ _Pragma ("GCC diagnostic push") \ -+ _Pragma ("GCC diagnostic ignored \"-Wuninitialized\"") \ - _Pragma ("GCC diagnostic ignored \"-Wmaybe-uninitialized\"") --# define FF_IGNORE_MAYBE_UNINITIALIZED_END \ -+# define FF_IGNORE_MAYBE_UNINITIALIZED_END \ - _Pragma ("GCC diagnostic pop") - #else - # define FF_INITIAL_VALUE(Value) Value -@@ -498,8 +645,22 @@ typedef short int fftype_int16; - # define FF_INITIAL_VALUE(Value) /* Nothing. */ - #endif - -+#if defined __cplusplus && defined __GNUC__ && ! defined __ICC && 6 <= __GNUC__ -+# define FF_IGNORE_USELESS_CAST_BEGIN \ -+ _Pragma ("GCC diagnostic push") \ -+ _Pragma ("GCC diagnostic ignored \"-Wuseless-cast\"") -+# define FF_IGNORE_USELESS_CAST_END \ -+ _Pragma ("GCC diagnostic pop") -+#endif -+#ifndef FF_IGNORE_USELESS_CAST_BEGIN -+# define FF_IGNORE_USELESS_CAST_BEGIN -+# define FF_IGNORE_USELESS_CAST_END -+#endif -+ - --#if ! defined ffoverflow || FFERROR_VERBOSE -+#define FF_ASSERT(E) ((void) (0 && (E))) -+ -+#if !defined ffoverflow - - /* The parser invokes alloca or malloc; define the necessary symbols. */ - -@@ -564,8 +725,7 @@ void free (void *); /* INFRINGES ON USER NAME SPACE */ - # endif - # endif - # endif --#endif /* ! defined ffoverflow || FFERROR_VERBOSE */ -- -+#endif /* !defined ffoverflow */ - - #if (! defined ffoverflow \ - && (! defined __cplusplus \ -@@ -574,17 +734,17 @@ void free (void *); /* INFRINGES ON USER NAME SPACE */ - /* A type that is properly aligned for any stack member. */ - union ffalloc - { -- fftype_int16 ffss_alloc; -+ ff_state_t ffss_alloc; - FFSTYPE ffvs_alloc; - }; - - /* The size of the maximum gap between one aligned stack and the next. */ --# define FFSTACK_GAP_MAXIMUM (sizeof (union ffalloc) - 1) -+# define FFSTACK_GAP_MAXIMUM (FFSIZEOF (union ffalloc) - 1) - - /* The size of an array large to enough to hold all stacks, each with - N elements. */ - # define FFSTACK_BYTES(N) \ -- ((N) * (sizeof (fftype_int16) + sizeof (FFSTYPE)) \ -+ ((N) * (FFSIZEOF (ff_state_t) + FFSIZEOF (FFSTYPE)) \ - + FFSTACK_GAP_MAXIMUM) - - # define FFCOPY_NEEDED 1 -@@ -597,11 +757,11 @@ union ffalloc - # define FFSTACK_RELOCATE(Stack_alloc, Stack) \ - do \ - { \ -- FFSIZE_T ffnewbytes; \ -+ FFPTRDIFF_T ffnewbytes; \ - FFCOPY (&ffptr->Stack_alloc, Stack, ffsize); \ - Stack = &ffptr->Stack_alloc; \ -- ffnewbytes = ffstacksize * sizeof (*Stack) + FFSTACK_GAP_MAXIMUM; \ -- ffptr += ffnewbytes / sizeof (*ffptr); \ -+ ffnewbytes = ffstacksize * FFSIZEOF (*Stack) + FFSTACK_GAP_MAXIMUM; \ -+ ffptr += ffnewbytes / FFSIZEOF (*ffptr); \ - } \ - while (0) - -@@ -613,12 +773,12 @@ union ffalloc - # ifndef FFCOPY - # if defined __GNUC__ && 1 < __GNUC__ - # define FFCOPY(Dst, Src, Count) \ -- __builtin_memcpy (Dst, Src, (Count) * sizeof (*(Src))) -+ __builtin_memcpy (Dst, Src, FF_CAST (FFSIZE_T, (Count)) * sizeof (*(Src))) - # else - # define FFCOPY(Dst, Src, Count) \ - do \ - { \ -- FFSIZE_T ffi; \ -+ FFPTRDIFF_T ffi; \ - for (ffi = 0; ffi < (Count); ffi++) \ - (Dst)[ffi] = (Src)[ffi]; \ - } \ -@@ -630,42 +790,45 @@ union ffalloc - /* FFFINAL -- State number of the termination state. */ - #define FFFINAL 2 - /* FFLAST -- Last index in FFTABLE. */ --#define FFLAST 1630 -+#define FFLAST 1725 - - /* FFNTOKENS -- Number of terminals. */ --#define FFNTOKENS 55 -+#define FFNTOKENS 56 - /* FFNNTS -- Number of nonterminals. */ - #define FFNNTS 9 - /* FFNRULES -- Number of rules. */ --#define FFNRULES 128 -+#define FFNRULES 130 - /* FFNSTATES -- Number of states. */ --#define FFNSTATES 296 -+#define FFNSTATES 308 - --/* FFTRANSLATE[FFX] -- Symbol number corresponding to FFX as returned -- by fflex, with out-of-bounds checking. */ --#define FFUNDEFTOK 2 --#define FFMAXUTOK 290 -+/* FFMAXUTOK -- Last valid token kind. */ -+#define FFMAXUTOK 291 - --#define FFTRANSLATE(FFX) \ -- ((unsigned int) (FFX) <= FFMAXUTOK ? fftranslate[FFX] : FFUNDEFTOK) -+ -+/* FFTRANSLATE(TOKEN-NUM) -- Symbol number corresponding to TOKEN-NUM -+ as returned by fflex, with out-of-bounds checking. */ -+#define FFTRANSLATE(FFX) \ -+ (0 <= (FFX) && (FFX) <= FFMAXUTOK \ -+ ? FF_CAST (ffsymbol_kind_t, fftranslate[FFX]) \ -+ : FFSYMBOL_FFUNDEF) - - /* FFTRANSLATE[TOKEN-NUM] -- Symbol number corresponding to TOKEN-NUM -- as returned by fflex, without out-of-bounds checking. */ --static const fftype_uint8 fftranslate[] = -+ as returned by fflex. */ -+static const fftype_int8 fftranslate[] = - { - 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, -- 51, 2, 2, 2, 2, 2, 2, 2, 2, 2, -+ 52, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, -- 2, 2, 2, 2, 2, 2, 2, 37, 41, 2, -- 53, 54, 38, 35, 20, 36, 2, 39, 2, 2, -- 2, 2, 2, 2, 2, 2, 2, 2, 22, 2, -- 2, 21, 2, 25, 2, 2, 2, 2, 2, 2, -+ 2, 2, 2, 2, 2, 2, 2, 38, 42, 2, -+ 54, 55, 39, 36, 21, 37, 2, 40, 2, 2, -+ 2, 2, 2, 2, 2, 2, 2, 2, 23, 2, -+ 2, 22, 2, 26, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, -- 2, 48, 2, 52, 2, 2, 2, 2, 2, 2, -+ 2, 49, 2, 53, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, -- 2, 2, 2, 23, 40, 24, 30, 2, 2, 2, -+ 2, 2, 2, 24, 41, 25, 31, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, -@@ -680,105 +843,121 @@ static const fftype_uint8 fftranslate[] = - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 1, 2, 3, 4, - 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, -- 15, 16, 17, 18, 19, 26, 27, 28, 29, 31, -- 32, 33, 34, 42, 43, 44, 45, 46, 47, 49, -- 50 -+ 15, 16, 17, 18, 19, 20, 27, 28, 29, 30, -+ 32, 33, 34, 35, 43, 44, 45, 46, 47, 48, -+ 50, 51 - }; - - #if FFDEBUG - /* FFRLINE[FFN] -- Source line where rule number FFN was defined. */ --static const fftype_uint16 ffrline[] = -+static const fftype_int16 ffrline[] = - { -- 0, 244, 244, 245, 248, 249, 255, 261, 267, 273, -- 276, 278, 291, 293, 306, 317, 331, 335, 339, 343, -- 345, 354, 357, 360, 369, 371, 373, 375, 377, 379, -- 382, 386, 388, 390, 392, 401, 403, 405, 408, 411, -- 414, 417, 420, 429, 438, 447, 450, 452, 454, 456, -- 460, 464, 483, 502, 521, 532, 546, 558, 589, 684, -- 692, 754, 778, 780, 782, 784, 786, 788, 790, 792, -- 794, 798, 800, 802, 811, 814, 817, 820, 823, 826, -- 829, 832, 835, 838, 841, 844, 847, 850, 853, 856, -- 859, 862, 865, 868, 870, 872, 874, 877, 884, 901, -- 914, 927, 938, 954, 978, 1006, 1043, 1047, 1051, 1054, -- 1058, 1062, 1065, 1069, 1071, 1073, 1075, 1077, 1079, 1081, -- 1085, 1088, 1090, 1099, 1101, 1103, 1112, 1131, 1150 -+ 0, 252, 252, 253, 256, 257, 263, 269, 275, 281, -+ 284, 286, 299, 301, 314, 325, 339, 343, 347, 351, -+ 353, 362, 365, 368, 377, 379, 381, 383, 385, 387, -+ 390, 394, 396, 398, 400, 409, 411, 413, 416, 419, -+ 422, 425, 428, 437, 446, 455, 458, 460, 462, 464, -+ 468, 472, 491, 510, 529, 540, 554, 566, 597, 692, -+ 700, 761, 785, 787, 789, 791, 793, 795, 797, 799, -+ 801, 805, 807, 809, 818, 821, 824, 827, 830, 833, -+ 836, 839, 842, 845, 848, 851, 854, 857, 860, 863, -+ 866, 869, 872, 875, 877, 879, 881, 884, 891, 908, -+ 921, 934, 945, 961, 985, 1013, 1050, 1054, 1058, 1061, -+ 1066, 1069, 1074, 1078, 1081, 1085, 1087, 1089, 1091, 1093, -+ 1095, 1097, 1101, 1104, 1106, 1115, 1117, 1119, 1128, 1147, -+ 1166 - }; - #endif - --#if FFDEBUG || FFERROR_VERBOSE || 0 -+/** Accessing symbol of state STATE. */ -+#define FF_ACCESSING_SYMBOL(State) FF_CAST (ffsymbol_kind_t, ffstos[State]) -+ -+#if FFDEBUG || 0 -+/* The user-facing name of the symbol whose (internal) number is -+ FFSYMBOL. No bounds checking. */ -+static const char *ffsymbol_name (ffsymbol_kind_t ffsymbol) FF_ATTRIBUTE_UNUSED; -+ - /* FFTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM. - First, the terminals, then, starting at FFNTOKENS, nonterminals. */ - static const char *const fftname[] = - { -- "$end", "error", "$undefined", "BOOLEAN", "LONG", "DOUBLE", "STRING", -- "BITSTR", "FUNCTION", "BFUNCTION", "IFUNCTION", "GTIFILTER", "REGFILTER", -- "COLUMN", "BCOLUMN", "SCOLUMN", "BITCOL", "ROWREF", "NULLREF", -- "SNULLREF", "','", "'='", "':'", "'{'", "'}'", "'?'", "OR", "AND", "EQ", -- "NE", "'~'", "GT", "LT", "LTE", "GTE", "'+'", "'-'", "'%'", "'*'", "'/'", -- "'|'", "'&'", "XOR", "POWER", "NOT", "INTCAST", "FLTCAST", "UMINUS", -- "'['", "ACCUM", "DIFF", "'\\n'", "']'", "'('", "')'", "$accept", "lines", -- "line", "bvector", "vector", "expr", "bexpr", "bits", "sexpr", FF_NULLPTR -+ "\"end of file\"", "error", "\"invalid token\"", "BOOLEAN", "LONG", -+ "DOUBLE", "STRING", "BITSTR", "FUNCTION", "BFUNCTION", "IFUNCTION", -+ "GTIFILTER", "GTIOVERLAP", "REGFILTER", "COLUMN", "BCOLUMN", "SCOLUMN", -+ "BITCOL", "ROWREF", "NULLREF", "SNULLREF", "','", "'='", "':'", "'{'", -+ "'}'", "'?'", "OR", "AND", "EQ", "NE", "'~'", "GT", "LT", "LTE", "GTE", -+ "'+'", "'-'", "'%'", "'*'", "'/'", "'|'", "'&'", "XOR", "POWER", "NOT", -+ "INTCAST", "FLTCAST", "UMINUS", "'['", "ACCUM", "DIFF", "'\\n'", "']'", -+ "'('", "')'", "$accept", "lines", "line", "bvector", "vector", "expr", -+ "bexpr", "bits", "sexpr", FF_NULLPTR - }; -+ -+static const char * -+ffsymbol_name (ffsymbol_kind_t ffsymbol) -+{ -+ return fftname[ffsymbol]; -+} - #endif - --# ifdef FFPRINT -+#ifdef FFPRINT - /* FFTOKNUM[NUM] -- (External) token number corresponding to the - (internal) symbol number NUM (which must be that of a token). */ --static const fftype_uint16 fftoknum[] = -+static const fftype_int16 fftoknum[] = - { - 0, 256, 257, 258, 259, 260, 261, 262, 263, 264, - 265, 266, 267, 268, 269, 270, 271, 272, 273, 274, -- 44, 61, 58, 123, 125, 63, 275, 276, 277, 278, -- 126, 279, 280, 281, 282, 43, 45, 37, 42, 47, -- 124, 38, 283, 284, 285, 286, 287, 288, 91, 289, -- 290, 10, 93, 40, 41 -+ 275, 44, 61, 58, 123, 125, 63, 276, 277, 278, -+ 279, 126, 280, 281, 282, 283, 43, 45, 37, 42, -+ 47, 124, 38, 284, 285, 286, 287, 288, 289, 91, -+ 290, 291, 10, 93, 40, 41 - }; --# endif -+#endif - --#define FFPACT_NINF -50 -+#define FFPACT_NINF (-40) - --#define ffpact_value_is_default(Yystate) \ -- (!!((Yystate) == (-50))) -+#define ffpact_value_is_default(Yyn) \ -+ ((Yyn) == FFPACT_NINF) - --#define FFTABLE_NINF -1 -+#define FFTABLE_NINF (-1) - --#define fftable_value_is_error(Yytable_value) \ -+#define fftable_value_is_error(Yyn) \ - 0 - - /* FFPACT[STATE-NUM] -- Index in FFTABLE of the portion describing - STATE-NUM. */ - static const fftype_int16 ffpact[] = - { -- -50, 306, -50, -49, -50, -50, -50, -50, -50, 357, -- 409, 409, -5, -2, -18, 5, 6, 34, -50, -50, -- -50, 409, 409, 409, 409, 409, 409, -50, 409, -50, -- 49, 87, 1126, 246, 1484, -17, -50, -50, 436, 10, -- 350, 164, 465, 17, 1550, 302, 1431, 1511, 1513, -14, -- -50, -13, 409, 409, 409, 409, 1431, 1511, 1522, -22, -- -22, 18, 44, -22, 18, -22, 18, 638, 117, 1449, -- 405, 409, -50, 409, -50, 409, 409, 409, 409, 409, -- 409, 409, 409, 409, 409, 409, 409, 409, 409, 409, -- 409, 409, 409, -50, 409, 409, 409, 409, 409, 409, -- 409, -50, 3, 3, 3, 3, 3, 3, 3, 3, -- 3, 409, -50, 409, 409, 409, 409, 409, 409, 409, -- -50, 409, -50, 409, -50, -50, 409, -50, 409, -50, -- -50, -50, 409, 409, -50, 409, -50, 1293, 1316, 1339, -- 1362, -50, -50, -50, -50, 1431, 1511, 1431, 1511, 1385, -- 1568, 1568, 1568, 1582, 1582, 1582, 1582, 305, 305, 305, -- 19, 18, 19, 20, 20, 20, 20, 751, 1408, 260, -- 205, 129, 67, -35, -35, 19, 776, 3, 3, 112, -- 112, 112, 112, 112, 112, 60, 44, 44, 801, 268, -- 268, 62, 62, 62, 62, -50, 494, 177, 1150, 1467, -- 1174, 1476, 523, 1198, -50, -50, -50, -50, 409, 409, -- -50, 409, 409, 409, 409, -50, 44, 128, 409, -50, -- 409, -50, -50, 409, -50, 409, -50, 98, -50, 409, -- 1532, 826, 1532, 1511, 1532, 1511, 1522, 851, 876, 1222, -- 666, 552, 86, 581, 409, -50, 409, -50, 409, -50, -- 409, -50, 409, -50, 103, 106, -50, 901, 926, 951, -- 694, 1246, 59, 68, 409, -50, 409, -50, 409, -50, -- -50, 409, -50, -50, 976, 1001, 1026, 610, 409, -50, -- 409, -50, 409, -50, 409, -50, 1051, 1076, 1101, 1270, -- -50, -50, -50, 409, 722, -50 -+ -40, 337, -40, -39, -40, -40, -40, -40, -40, 389, -+ 442, 442, -5, 21, 29, 17, 25, 44, 45, -40, -+ -40, -40, 442, 442, 442, 442, 442, 442, -40, 442, -+ -40, -15, 19, 1159, 443, 1584, 1605, -40, -40, 276, -+ -10, 330, 133, 469, 144, 1647, 248, 1526, 209, 1689, -+ -19, -40, 49, -18, 442, 442, 442, 442, 1526, 209, -+ 294, -6, -6, 24, 26, -6, 24, -6, 24, 671, -+ 1186, 382, 1544, 442, -40, 442, -40, 442, 442, 442, -+ 442, 442, 442, 442, 442, 442, 442, 442, 442, 442, -+ 442, 442, 442, 442, 442, -40, 442, 442, 442, 442, -+ 442, 442, 442, -40, -3, -3, -3, -3, -3, -3, -+ -3, -3, -3, 442, -40, 442, 442, 442, 442, 442, -+ 442, 442, -40, 442, -40, 442, -40, -40, 442, -40, -+ 442, -40, -40, -40, 442, 442, -40, 442, 442, -40, -+ 1388, 1411, 1434, 1457, -40, -40, -40, -40, 1526, 209, -+ 1526, 209, 1480, 1665, 1665, 1665, 22, 22, 22, 22, -+ 203, 203, 203, 148, 24, 148, -37, -37, -37, -37, -+ 784, 1503, 1558, 1619, 18, 69, -34, -34, 148, 809, -+ -3, -3, 111, 111, 111, 111, 111, 111, -11, 26, -+ 26, 834, 406, 406, 58, 58, 58, 58, -40, 498, -+ 1191, 1221, 1560, 1245, 1576, 527, 1269, 1293, -40, -40, -+ -40, -40, 442, 442, -40, 442, 442, 442, 442, -40, -+ 26, 68, 442, -40, 442, -40, -40, 442, -40, 442, -+ -40, 90, -40, 442, 442, 1629, 859, 1629, 209, 1629, -+ 209, 294, 884, 909, 1317, 699, 556, 76, 585, 614, -+ 442, -40, 442, -40, 442, -40, 442, -40, 442, -40, -+ 96, 97, -40, 99, -40, 934, 959, 984, 727, 1341, -+ 51, 92, 56, 442, -40, 442, -40, 442, -40, -40, -+ 442, -40, 108, -40, 1009, 1034, 1059, 643, 65, 442, -+ -40, 442, -40, 442, -40, 442, -40, -40, 1084, 1109, -+ 1134, 1365, -40, -40, -40, 442, 755, -40 - }; - - /* FFDEFACT[STATE-NUM] -- Default reduction number in state STATE-NUM. -@@ -786,445 +965,466 @@ static const fftype_int16 ffpact[] = - means the default is an error. */ - static const fftype_uint8 ffdefact[] = - { -- 2, 0, 1, 0, 71, 31, 32, 120, 18, 0, -- 0, 0, 0, 0, 33, 72, 121, 19, 35, 36, -- 123, 0, 0, 0, 0, 0, 0, 4, 0, 3, -- 0, 0, 0, 0, 0, 0, 9, 54, 0, 0, -+ 2, 0, 1, 0, 71, 31, 32, 122, 18, 0, -+ 0, 0, 0, 0, 0, 33, 72, 123, 19, 35, -+ 36, 125, 0, 0, 0, 0, 0, 0, 4, 0, -+ 3, 0, 0, 0, 0, 0, 0, 9, 54, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -- 106, 0, 0, 0, 0, 0, 12, 10, 0, 46, -- 47, 118, 29, 67, 68, 69, 70, 0, 0, 0, -- 0, 0, 17, 0, 16, 0, 0, 0, 0, 0, -+ 0, 106, 0, 0, 0, 0, 0, 0, 12, 10, -+ 0, 46, 47, 120, 29, 67, 68, 69, 70, 0, -+ 0, 0, 0, 0, 17, 0, 16, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -- 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, -- 0, 6, 0, 0, 0, 0, 0, 0, 0, 0, -- 0, 0, 8, 0, 0, 0, 0, 0, 0, 0, -- 7, 0, 58, 0, 55, 57, 0, 56, 0, 99, -- 100, 101, 0, 0, 107, 0, 110, 0, 0, 0, -- 0, 48, 119, 30, 124, 15, 11, 13, 14, 0, -- 85, 86, 84, 80, 81, 83, 82, 38, 39, 37, -- 40, 49, 41, 43, 42, 44, 45, 0, 0, 0, -- 0, 94, 93, 95, 96, 50, 0, 0, 0, 74, -- 75, 78, 76, 77, 79, 23, 22, 21, 0, 87, -- 88, 89, 91, 92, 90, 125, 0, 0, 0, 0, -- 0, 0, 0, 0, 34, 73, 122, 20, 0, 0, -- 62, 0, 0, 0, 0, 113, 29, 0, 0, 24, -- 0, 60, 102, 0, 127, 0, 59, 0, 108, 0, -- 97, 0, 51, 53, 52, 98, 126, 0, 0, 0, -- 0, 0, 0, 0, 0, 63, 0, 114, 0, 25, -- 0, 128, 0, 103, 0, 0, 111, 0, 0, 0, -- 0, 0, 0, 0, 0, 64, 0, 115, 0, 26, -- 61, 0, 109, 112, 0, 0, 0, 0, 0, 65, -- 0, 116, 0, 27, 0, 104, 0, 0, 0, 0, -- 66, 117, 28, 0, 0, 105 -+ 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, -+ 0, 0, 0, 6, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 8, 0, 0, 0, 0, 0, -+ 0, 0, 7, 0, 58, 0, 55, 57, 0, 56, -+ 0, 99, 100, 101, 0, 0, 107, 0, 0, 112, -+ 0, 0, 0, 0, 48, 121, 30, 126, 15, 11, -+ 13, 14, 0, 85, 86, 84, 80, 81, 83, 82, -+ 38, 39, 37, 40, 49, 41, 43, 42, 44, 45, -+ 0, 0, 0, 0, 94, 93, 95, 96, 50, 0, -+ 0, 0, 74, 75, 78, 76, 77, 79, 23, 22, -+ 21, 0, 87, 88, 89, 91, 92, 90, 127, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 34, 73, -+ 124, 20, 0, 0, 62, 0, 0, 0, 0, 115, -+ 29, 0, 0, 24, 0, 60, 102, 0, 129, 0, -+ 59, 0, 108, 0, 0, 97, 0, 51, 53, 52, -+ 98, 128, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 63, 0, 116, 0, 25, 0, 130, 0, 103, -+ 0, 0, 110, 0, 113, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 64, 0, 117, 0, 26, 61, -+ 0, 109, 0, 114, 0, 0, 0, 0, 0, 0, -+ 65, 0, 118, 0, 27, 0, 104, 111, 0, 0, -+ 0, 0, 66, 119, 28, 0, 0, 105 - }; - - /* FFPGOTO[NTERM-NUM]. */ - static const fftype_int16 ffpgoto[] = - { -- -50, -50, -50, -50, -50, -1, 93, 150, 22 -+ -40, -40, -40, -40, -40, -1, 106, 155, 23 - }; - - /* FFDEFGOTO[NTERM-NUM]. */ - static const fftype_int8 ffdefgoto[] = - { -- -1, 1, 29, 30, 31, 46, 47, 44, 58 -+ -1, 1, 30, 31, 32, 47, 48, 45, 60 - }; - - /* FFTABLE[FFPACT[STATE-NUM]] -- What to do in state STATE-NUM. If - positive, shift that token. If negative, reduce the rule whose - number is the opposite. If FFTABLE_NINF, syntax error. */ --static const fftype_uint16 fftable[] = -+static const fftype_int16 fftable[] = - { -- 32, 49, 36, 99, 51, 52, 133, 135, 38, 42, -- 8, 113, 114, 100, 115, 116, 117, 118, 119, 17, -- 56, 59, 60, 35, 63, 65, 92, 67, 53, 54, -- 123, 41, 45, 48, 120, 94, 95, 96, 97, 98, -- 134, 136, 94, 95, 96, 97, 98, 177, 99, 50, -- 70, 137, 138, 139, 140, 99, 178, 55, 100, 88, -- 89, 90, 91, 91, 124, 100, 100, 92, 92, 71, -- 145, 130, 147, 72, 149, 150, 151, 152, 153, 154, -- 155, 156, 157, 158, 159, 160, 162, 163, 164, 165, -- 166, 167, 111, 168, 33, 97, 98, 119, 175, 176, -- 109, 110, 39, 43, 242, 99, 254, 73, 111, 262, -- 188, 74, 263, 272, 57, 100, 170, 61, 64, 66, -- 196, 68, 273, 0, 0, 198, 0, 200, 0, 0, -- 0, 0, 202, 0, 203, 189, 190, 191, 192, 193, -- 194, 195, 94, 95, 96, 97, 98, 108, 199, 0, -- 0, 34, 109, 110, 201, 99, 96, 97, 98, 40, -- 111, 0, 0, 108, 146, 100, 148, 99, 109, 110, -- 0, 142, 0, 0, 62, 0, 111, 100, 69, 161, -- 0, 0, 143, 0, 126, 0, 0, 169, 171, 172, -- 173, 174, 113, 114, 0, 115, 116, 117, 118, 119, -- 0, 0, 94, 95, 96, 97, 98, 230, 231, 0, -- 232, 234, 0, 237, 0, 99, 197, 238, 127, 239, -- 0, 0, 240, 0, 241, 100, 0, 213, 243, 0, -- 0, 222, 0, 113, 114, 236, 115, 116, 117, 118, -- 119, 0, 0, 257, 0, 258, 0, 259, 0, 260, -- 0, 261, 179, 180, 181, 182, 183, 184, 185, 186, -- 187, 0, 0, 274, 0, 275, 0, 276, 0, 0, -- 277, 94, 95, 96, 97, 98, 0, 286, 0, 287, -- 0, 288, 212, 289, 99, 94, 95, 96, 97, 98, -- 0, 0, 294, 0, 100, 0, 0, 101, 99, 115, -- 116, 117, 118, 119, 233, 235, 2, 3, 100, 4, -- 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, -- 15, 16, 17, 18, 19, 20, 0, 216, 217, 21, -- 113, 114, 0, 115, 116, 117, 118, 119, 0, 0, -- 0, 22, 23, 86, 87, 88, 89, 90, 91, 0, -- 24, 25, 26, 92, 0, 0, 131, 27, 0, 28, -+ 33, 50, 135, 138, 8, 101, 73, 93, 39, 43, -+ 74, 125, 94, 37, 18, 102, 96, 97, 98, 99, -+ 100, 58, 61, 62, 36, 65, 67, 52, 69, 101, -+ 111, 112, 42, 46, 49, 53, 136, 139, 113, 102, -+ 75, 54, 180, 94, 76, 126, 98, 99, 100, 55, -+ 51, 181, 72, 140, 141, 142, 143, 101, 85, 86, -+ 87, 88, 89, 90, 91, 92, 93, 102, 56, 57, -+ 137, 94, 148, 102, 150, 113, 152, 153, 154, 155, -+ 156, 157, 158, 159, 160, 161, 162, 163, 165, 166, -+ 167, 168, 169, 170, 121, 171, 247, 260, 99, 100, -+ 178, 179, 270, 271, 110, 272, 281, 34, 101, 111, -+ 112, 283, 191, 282, 288, 40, 44, 113, 102, 173, -+ 297, 0, 199, 146, 0, 0, 0, 201, 59, 203, -+ 0, 63, 66, 68, 205, 70, 206, 207, 192, 193, -+ 194, 195, 196, 197, 198, 0, 0, 110, 0, 0, -+ 0, 202, 111, 112, 128, 0, 35, 204, 0, 0, -+ 113, 0, 115, 116, 41, 117, 118, 119, 120, 121, -+ 96, 97, 98, 99, 100, 0, 0, 0, 0, 149, -+ 64, 151, 0, 101, 71, 0, 0, 0, 129, 90, -+ 91, 92, 93, 102, 164, 0, 0, 94, 0, 132, -+ 0, 0, 172, 174, 175, 176, 177, 0, 0, 0, -+ 0, 235, 236, 0, 237, 239, 0, 242, 0, 0, -+ 0, 243, 0, 244, 0, 0, 245, 0, 246, 0, -+ 0, 200, 248, 249, 0, 96, 97, 98, 99, 100, -+ 241, 0, 88, 89, 90, 91, 92, 93, 101, 265, -+ 0, 266, 94, 267, 0, 268, 0, 269, 102, 182, -+ 183, 184, 185, 186, 187, 188, 189, 190, 0, 0, -+ 0, 0, 284, 0, 285, 0, 286, 115, 116, 287, -+ 117, 118, 119, 120, 121, 0, 0, 0, 298, 0, -+ 299, 0, 300, 0, 301, 0, 0, 123, 77, 0, -+ 0, 0, 0, 133, 306, 78, 79, 80, 81, 82, -+ 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, -+ 93, 238, 240, 115, 116, 94, 117, 118, 119, 120, -+ 121, 124, 0, 0, 0, 220, 221, 2, 3, 0, - 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, -- 14, 15, 16, 17, 18, 19, 20, 0, 102, 103, -- 21, 104, 105, 106, 107, 108, 0, 0, 0, 0, -- 109, 110, 22, 23, 0, 0, 0, 0, 111, 0, -- 0, 24, 25, 26, 125, 0, 0, 0, 0, 0, -- 28, 37, 4, 5, 6, 7, 8, 9, 10, 11, -- 12, 13, 14, 15, 16, 17, 18, 19, 20, 0, -- 0, 0, 21, 113, 114, 0, 115, 116, 117, 118, -- 119, 0, 0, 0, 22, 23, 0, 0, 0, 0, -- 0, 0, 0, 24, 25, 26, 121, 75, 0, 144, -- 0, 0, 28, 0, 76, 77, 78, 79, 80, 81, -+ 14, 15, 16, 17, 18, 19, 20, 21, 0, 104, -+ 105, 22, 106, 107, 108, 109, 110, 0, 0, 0, -+ 0, 111, 112, 23, 24, 0, 0, 0, 0, 113, -+ 0, 0, 25, 26, 27, 127, 0, 0, 0, 28, -+ 0, 29, 4, 5, 6, 7, 8, 9, 10, 11, -+ 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, -+ 0, 104, 105, 22, 106, 107, 108, 109, 110, 0, -+ 0, 0, 0, 111, 112, 23, 24, 0, 0, 0, -+ 0, 113, 0, 0, 25, 26, 27, 146, 117, 118, -+ 119, 120, 121, 29, 38, 4, 5, 6, 7, 8, -+ 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, -+ 19, 20, 21, 0, 0, 0, 22, 0, 0, 96, -+ 97, 98, 99, 100, 0, 0, 0, 0, 23, 24, -+ 0, 0, 101, 0, 0, 0, 0, 25, 26, 27, -+ 130, 77, 102, 0, 0, 103, 29, 0, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 0, 0, 0, 94, 224, -+ 77, 0, 0, 0, 131, 0, 0, 78, 79, 80, -+ 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, -+ 91, 92, 93, 0, 0, 0, 0, 94, 231, 77, -+ 0, 0, 0, 225, 0, 0, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 0, 0, 0, 92, 128, 75, 0, 0, 0, -- 122, 0, 0, 76, 77, 78, 79, 80, 81, 82, -- 83, 84, 85, 86, 87, 88, 89, 90, 91, 0, -- 0, 0, 0, 92, 220, 75, 0, 0, 0, 129, -- 0, 0, 76, 77, 78, 79, 80, 81, 82, 83, -- 84, 85, 86, 87, 88, 89, 90, 91, 0, 0, -- 0, 0, 92, 227, 75, 0, 0, 0, 221, 0, -- 0, 76, 77, 78, 79, 80, 81, 82, 83, 84, -- 85, 86, 87, 88, 89, 90, 91, 0, 0, 0, -- 0, 92, 252, 75, 0, 0, 0, 228, 0, 0, -- 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, -- 86, 87, 88, 89, 90, 91, 0, 0, 0, 0, -- 92, 255, 75, 0, 0, 0, 253, 0, 0, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 0, 0, 0, 92, -- 284, 75, 0, 0, 0, 256, 0, 0, 76, 77, -+ 92, 93, 0, 0, 0, 0, 94, 258, 77, 0, -+ 0, 0, 232, 0, 0, 78, 79, 80, 81, 82, -+ 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, -+ 93, 0, 0, 0, 0, 94, 261, 77, 0, 0, -+ 0, 259, 0, 0, 78, 79, 80, 81, 82, 83, -+ 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, -+ 0, 0, 0, 0, 94, 263, 77, 0, 0, 0, -+ 262, 0, 0, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 0, 0, 0, 94, 295, 77, 0, 0, 0, 264, -+ 0, 0, 78, 79, 80, 81, 82, 83, 84, 85, -+ 86, 87, 88, 89, 90, 91, 92, 93, 0, 0, -+ 0, 0, 94, 77, 0, 0, 0, 0, 296, 0, - 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, -- 88, 89, 90, 91, 0, 0, 0, 0, 92, 75, -- 0, 0, 0, 0, 285, 0, 76, 77, 78, 79, -+ 88, 89, 90, 91, 92, 93, 0, 0, 0, 0, -+ 94, 77, 0, 0, 0, 0, 144, 0, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -- 90, 91, 0, 0, 0, 0, 92, 75, 0, 0, -- 0, 0, 141, 0, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 0, 0, 0, 92, 75, 0, 0, 0, 0, -- 251, 0, 76, 77, 78, 79, 80, 81, 82, 83, -- 84, 85, 86, 87, 88, 89, 90, 91, 0, 0, -- 0, 0, 92, 75, 0, 0, 0, 0, 270, 0, -- 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, -- 86, 87, 88, 89, 90, 91, 0, 0, 0, 0, -- 92, 209, 75, 0, 0, 0, 295, 0, 0, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 214, 75, 0, 92, -- 0, 0, 0, 210, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 218, 75, 0, 92, 0, 0, 0, 215, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 244, 75, 0, 92, -- 0, 0, 0, 219, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 246, 75, 0, 92, 0, 0, 0, 245, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 248, 75, 0, 92, -- 0, 0, 0, 247, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 264, 75, 0, 92, 0, 0, 0, 249, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 266, 75, 0, 92, -- 0, 0, 0, 265, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 268, 75, 0, 92, 0, 0, 0, 267, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 278, 75, 0, 92, -- 0, 0, 0, 269, 76, 77, 78, 79, 80, 81, -+ 90, 91, 92, 93, 0, 0, 0, 0, 94, 77, -+ 0, 0, 0, 0, 257, 0, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 280, 75, 0, 92, 0, 0, 0, 279, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 282, 75, 0, 92, -- 0, 0, 0, 281, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 0, 75, 0, 92, 0, 0, 0, 283, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 0, 75, 0, 92, -- 0, 0, 0, 290, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 0, 0, 75, 0, 92, 0, 0, 0, 291, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 0, 75, 0, 92, -- 0, 0, 0, 292, 76, 77, 78, 79, 80, 81, -- 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 223, 75, 0, 0, 92, 0, 0, 93, 76, 77, -+ 92, 93, 0, 0, 0, 0, 94, 77, 0, 0, -+ 0, 0, 279, 0, 78, 79, 80, 81, 82, 83, -+ 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, -+ 0, 0, 0, 0, 94, 213, 77, 0, 0, 0, -+ 307, 0, 0, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 218, 77, 0, 94, 0, 0, 0, 214, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 222, 77, 0, 94, 0, -+ 0, 0, 219, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 250, 77, 0, 94, 0, 0, 0, 223, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 252, 77, 0, 94, 0, -+ 0, 0, 251, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 254, 77, 0, 94, 0, 0, 0, 253, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 273, 77, 0, 94, 0, -+ 0, 0, 255, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 275, 77, 0, 94, 0, 0, 0, 274, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 277, 77, 0, 94, 0, -+ 0, 0, 276, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 289, 77, 0, 94, 0, 0, 0, 278, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 291, 77, 0, 94, 0, -+ 0, 0, 290, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 293, 77, 0, 94, 0, 0, 0, 292, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 0, 77, 0, 94, 0, -+ 0, 0, 294, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 0, 77, 0, 94, 0, 0, 0, 302, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 0, 77, 0, 94, 0, -+ 0, 0, 303, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 0, -+ 0, 77, 0, 94, 0, 0, 0, 304, 78, 79, -+ 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -+ 90, 91, 92, 93, 0, 0, 0, 0, 94, 0, -+ 0, 95, 96, 97, 98, 99, 100, 96, 97, 98, -+ 99, 100, 0, 0, 0, 101, 0, 0, 0, 0, -+ 101, 0, 0, 0, 0, 102, 0, 0, 0, 0, -+ 102, 145, 227, 77, 0, 0, 226, 0, 0, 0, - 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, -- 88, 89, 90, 91, 225, 75, 0, 0, 92, 0, -- 0, 0, 76, 77, 78, 79, 80, 81, 82, 83, -- 84, 85, 86, 87, 88, 89, 90, 91, 229, 75, -- 0, 0, 92, 0, 0, 0, 76, 77, 78, 79, -+ 88, 89, 90, 91, 92, 93, 229, 77, 0, 0, -+ 94, 0, 0, 0, 78, 79, 80, 81, 82, 83, -+ 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, -+ 233, 77, 0, 0, 94, 0, 0, 0, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -- 90, 91, 250, 75, 0, 0, 92, 0, 0, 0, -- 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, -- 86, 87, 88, 89, 90, 91, 271, 75, 0, 0, -- 92, 0, 0, 0, 76, 77, 78, 79, 80, 81, -+ 90, 91, 92, 93, 234, 77, 0, 0, 94, 0, -+ 0, 0, 78, 79, 80, 81, 82, 83, 84, 85, -+ 86, 87, 88, 89, 90, 91, 92, 93, 256, 77, -+ 0, 0, 94, 0, 0, 0, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 293, 75, 0, 0, 92, 0, 0, 0, 76, 77, -+ 92, 93, 280, 77, 0, 0, 94, 0, 0, 0, - 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, -- 88, 89, 90, 91, 75, 0, 0, 204, 92, 0, -- 0, 76, 77, 78, 79, 80, 81, 82, 83, 84, -- 85, 86, 87, 88, 89, 90, 91, 75, 0, 0, -- 205, 92, 0, 0, 76, 77, 78, 79, 80, 81, -+ 88, 89, 90, 91, 92, 93, 305, 77, 0, 0, -+ 94, 0, 0, 0, 78, 79, 80, 81, 82, 83, -+ 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, -+ 77, 0, 0, 208, 94, 0, 0, 78, 79, 80, -+ 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, -+ 91, 92, 93, 77, 0, 0, 209, 94, 0, 0, -+ 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, -+ 88, 89, 90, 91, 92, 93, 77, 0, 0, 210, -+ 94, 0, 0, 78, 79, 80, 81, 82, 83, 84, -+ 85, 86, 87, 88, 89, 90, 91, 92, 93, 77, -+ 0, 0, 211, 94, 0, 0, 78, 79, 80, 81, - 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, -- 75, 0, 0, 206, 92, 0, 0, 76, 77, 78, -+ 92, 93, 77, 212, 0, 0, 94, 0, 0, 78, - 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, -- 89, 90, 91, 75, 0, 0, 207, 92, 0, 0, -- 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, -- 86, 87, 88, 89, 90, 91, 75, 208, 0, 0, -- 92, 0, 0, 76, 77, 78, 79, 80, 81, 82, -- 83, 84, 85, 86, 87, 88, 89, 90, 91, 75, -- 211, 0, 0, 92, 0, 0, 76, 77, 78, 79, -- 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -- 90, 91, 75, 0, 0, 0, 92, 0, 0, 76, -- 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, -- 87, 88, 89, 90, 91, 0, 0, 102, 103, 92, -- 104, 105, 106, 107, 108, 0, 0, 0, 0, 109, -- 110, 0, 0, 0, 0, 113, 114, 111, 115, 116, -- 117, 118, 119, 143, 113, 114, 0, 115, 116, 117, -- 118, 119, 102, 103, 0, 104, 105, 106, 107, 108, -- 0, 224, 0, 0, 109, 110, 0, 0, 0, 0, -- 226, 0, 111, 132, 0, 112, 94, 95, 96, 97, -- 98, 113, 114, 0, 115, 116, 117, 118, 119, 99, -- 113, 114, 0, 115, 116, 117, 118, 119, 0, 100, -- 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, -- 86, 87, 88, 89, 90, 91, 0, 0, 102, 103, -- 92, 104, 105, 106, 107, 108, 0, 0, 0, 0, -- 109, 110, 0, 0, 0, 0, 0, 0, 111, 79, -+ 89, 90, 91, 92, 93, 77, 215, 0, 0, 94, -+ 0, 0, 78, 79, 80, 81, 82, 83, 84, 85, -+ 86, 87, 88, 89, 90, 91, 92, 93, 77, 0, -+ 0, 0, 94, 0, 0, 78, 79, 80, 81, 82, -+ 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, -+ 93, 0, 0, 115, 116, 94, 117, 118, 119, 120, -+ 121, 216, 0, 0, 96, 97, 98, 99, 100, 115, -+ 116, 0, 117, 118, 119, 120, 121, 101, 0, 147, -+ 0, 0, 0, 0, 0, 115, 116, 102, 117, 118, -+ 119, 120, 121, 104, 105, 228, 106, 107, 108, 109, -+ 110, 0, 0, 0, 0, 111, 112, 0, 0, 0, -+ 0, 230, 0, 113, 115, 116, 114, 117, 118, 119, -+ 120, 121, 217, 0, 0, 0, 0, 0, 115, 116, -+ 0, 117, 118, 119, 120, 121, 0, 122, 78, 79, - 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, -- 90, 91, 0, 0, 0, 0, 92, 83, 84, 85, -- 86, 87, 88, 89, 90, 91, 0, 0, 0, 0, -- 92 -+ 90, 91, 92, 93, 0, 0, 104, 105, 94, 106, -+ 107, 108, 109, 110, 0, 0, 0, 0, 111, 112, -+ 0, 0, 0, 0, 0, 0, 113, 81, 82, 83, -+ 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, -+ 134, 0, 0, 0, 94, 0, 0, 0, 115, 116, -+ 0, 117, 118, 119, 120, 121 - }; - - static const fftype_int16 ffcheck[] = - { -- 1, 6, 51, 38, 6, 23, 20, 20, 9, 10, -- 7, 28, 29, 48, 31, 32, 33, 34, 35, 16, -- 21, 22, 23, 1, 25, 26, 48, 28, 23, 23, -- 20, 9, 10, 11, 51, 25, 26, 27, 28, 29, -- 54, 54, 25, 26, 27, 28, 29, 44, 38, 54, -- 28, 52, 53, 54, 55, 38, 53, 23, 48, 40, -- 41, 42, 43, 43, 54, 48, 48, 48, 48, 20, -- 71, 54, 73, 24, 75, 76, 77, 78, 79, 80, -+ 1, 6, 21, 21, 7, 39, 21, 44, 9, 10, -+ 25, 21, 49, 52, 17, 49, 26, 27, 28, 29, -+ 30, 22, 23, 24, 1, 26, 27, 6, 29, 39, -+ 41, 42, 9, 10, 11, 6, 55, 55, 49, 49, -+ 21, 24, 45, 49, 25, 55, 28, 29, 30, 24, -+ 55, 54, 29, 54, 55, 56, 57, 39, 36, 37, -+ 38, 39, 40, 41, 42, 43, 44, 49, 24, 24, -+ 21, 49, 73, 49, 75, 49, 77, 78, 79, 80, - 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, -- 91, 92, 48, 94, 1, 28, 29, 35, 99, 100, -- 40, 41, 9, 10, 6, 38, 20, 20, 48, 6, -- 111, 24, 6, 54, 21, 48, 94, 24, 25, 26, -- 121, 28, 54, -1, -1, 126, -1, 128, -1, -1, -- -1, -1, 133, -1, 135, 113, 114, 115, 116, 117, -- 118, 119, 25, 26, 27, 28, 29, 35, 126, -1, -- -1, 1, 40, 41, 132, 38, 27, 28, 29, 9, -- 48, -1, -1, 35, 71, 48, 73, 38, 40, 41, -- -1, 54, -1, -1, 24, -1, 48, 48, 28, 86, -- -1, -1, 54, -1, 20, -1, -1, 94, 95, 96, -- 97, 98, 28, 29, -1, 31, 32, 33, 34, 35, -- -1, -1, 25, 26, 27, 28, 29, 208, 209, -1, -- 211, 212, -1, 214, -1, 38, 123, 218, 54, 220, -- -1, -1, 223, -1, 225, 48, -1, 22, 229, -1, -- -1, 54, -1, 28, 29, 213, 31, 32, 33, 34, -- 35, -1, -1, 244, -1, 246, -1, 248, -1, 250, -- -1, 252, 102, 103, 104, 105, 106, 107, 108, 109, -- 110, -1, -1, 264, -1, 266, -1, 268, -1, -1, -- 271, 25, 26, 27, 28, 29, -1, 278, -1, 280, -- -1, 282, 22, 284, 38, 25, 26, 27, 28, 29, -- -1, -1, 293, -1, 48, -1, -1, 51, 38, 31, -- 32, 33, 34, 35, 211, 212, 0, 1, 48, 3, -- 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, -- 14, 15, 16, 17, 18, 19, -1, 177, 178, 23, -- 28, 29, -1, 31, 32, 33, 34, 35, -1, -1, -- -1, 35, 36, 38, 39, 40, 41, 42, 43, -1, -- 44, 45, 46, 48, -1, -1, 54, 51, -1, 53, -- 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, -- 13, 14, 15, 16, 17, 18, 19, -1, 28, 29, -- 23, 31, 32, 33, 34, 35, -1, -1, -1, -1, -- 40, 41, 35, 36, -1, -1, -1, -1, 48, -1, -- -1, 44, 45, 46, 54, -1, -1, -1, -1, -1, -- 53, 54, 3, 4, 5, 6, 7, 8, 9, 10, -- 11, 12, 13, 14, 15, 16, 17, 18, 19, -1, -- -1, -1, 23, 28, 29, -1, 31, 32, 33, 34, -- 35, -1, -1, -1, 35, 36, -1, -1, -1, -1, -- -1, -1, -1, 44, 45, 46, 20, 21, -1, 54, -- -1, -1, 53, -1, 28, 29, 30, 31, 32, 33, -+ 91, 92, 93, 94, 36, 96, 6, 21, 29, 30, -+ 101, 102, 6, 6, 36, 6, 55, 1, 39, 41, -+ 42, 55, 113, 21, 6, 9, 10, 49, 49, 96, -+ 55, -1, 123, 55, -1, -1, -1, 128, 22, 130, -+ -1, 25, 26, 27, 135, 29, 137, 138, 115, 116, -+ 117, 118, 119, 120, 121, -1, -1, 36, -1, -1, -+ -1, 128, 41, 42, 21, -1, 1, 134, -1, -1, -+ 49, -1, 29, 30, 9, 32, 33, 34, 35, 36, -+ 26, 27, 28, 29, 30, -1, -1, -1, -1, 73, -+ 25, 75, -1, 39, 29, -1, -1, -1, 55, 41, -+ 42, 43, 44, 49, 88, -1, -1, 49, -1, 55, -+ -1, -1, 96, 97, 98, 99, 100, -1, -1, -1, -+ -1, 212, 213, -1, 215, 216, -1, 218, -1, -1, -+ -1, 222, -1, 224, -1, -1, 227, -1, 229, -1, -+ -1, 125, 233, 234, -1, 26, 27, 28, 29, 30, -+ 217, -1, 39, 40, 41, 42, 43, 44, 39, 250, -+ -1, 252, 49, 254, -1, 256, -1, 258, 49, 104, -+ 105, 106, 107, 108, 109, 110, 111, 112, -1, -1, -+ -1, -1, 273, -1, 275, -1, 277, 29, 30, 280, -+ 32, 33, 34, 35, 36, -1, -1, -1, 289, -1, -+ 291, -1, 293, -1, 295, -1, -1, 21, 22, -1, -+ -1, -1, -1, 55, 305, 29, 30, 31, 32, 33, - 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, -1, -1, -1, 48, 20, 21, -1, -1, -1, -- 54, -1, -1, 28, 29, 30, 31, 32, 33, 34, -- 35, 36, 37, 38, 39, 40, 41, 42, 43, -1, -- -1, -1, -1, 48, 20, 21, -1, -1, -1, 54, -- -1, -1, 28, 29, 30, 31, 32, 33, 34, 35, -- 36, 37, 38, 39, 40, 41, 42, 43, -1, -1, -- -1, -1, 48, 20, 21, -1, -1, -1, 54, -1, -- -1, 28, 29, 30, 31, 32, 33, 34, 35, 36, -- 37, 38, 39, 40, 41, 42, 43, -1, -1, -1, -- -1, 48, 20, 21, -1, -1, -1, 54, -1, -1, -- 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, -- 38, 39, 40, 41, 42, 43, -1, -1, -1, -1, -- 48, 20, 21, -1, -1, -1, 54, -1, -1, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, -1, -1, -1, 48, -- 20, 21, -1, -1, -1, 54, -1, -1, 28, 29, -- 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, -- 40, 41, 42, 43, -1, -1, -1, -1, 48, 21, -- -1, -1, -1, -1, 54, -1, 28, 29, 30, 31, -+ 44, 215, 216, 29, 30, 49, 32, 33, 34, 35, -+ 36, 55, -1, -1, -1, 180, 181, 0, 1, -1, -+ 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, -+ 13, 14, 15, 16, 17, 18, 19, 20, -1, 29, -+ 30, 24, 32, 33, 34, 35, 36, -1, -1, -1, -+ -1, 41, 42, 36, 37, -1, -1, -1, -1, 49, -+ -1, -1, 45, 46, 47, 55, -1, -1, -1, 52, -+ -1, 54, 3, 4, 5, 6, 7, 8, 9, 10, -+ 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, -+ -1, 29, 30, 24, 32, 33, 34, 35, 36, -1, -+ -1, -1, -1, 41, 42, 36, 37, -1, -1, -1, -+ -1, 49, -1, -1, 45, 46, 47, 55, 32, 33, -+ 34, 35, 36, 54, 55, 3, 4, 5, 6, 7, -+ 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, -+ 18, 19, 20, -1, -1, -1, 24, -1, -1, 26, -+ 27, 28, 29, 30, -1, -1, -1, -1, 36, 37, -+ -1, -1, 39, -1, -1, -1, -1, 45, 46, 47, -+ 21, 22, 49, -1, -1, 52, 54, -1, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, -1, -1, -1, 49, 21, -+ 22, -1, -1, -1, 55, -1, -1, 29, 30, 31, - 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, -- 42, 43, -1, -1, -1, -1, 48, 21, -1, -1, -- -1, -1, 54, -1, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, -1, -1, -1, 48, 21, -1, -1, -1, -1, -- 54, -1, 28, 29, 30, 31, 32, 33, 34, 35, -- 36, 37, 38, 39, 40, 41, 42, 43, -1, -1, -- -1, -1, 48, 21, -1, -1, -1, -1, 54, -1, -- 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, -- 38, 39, 40, 41, 42, 43, -1, -1, -1, -1, -- 48, 20, 21, -1, -1, -1, 54, -1, -1, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, 20, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, 20, 21, -1, 48, -1, -1, -1, 52, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, 20, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, 20, 21, -1, 48, -1, -1, -1, 52, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, 20, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, 20, 21, -1, 48, -1, -1, -1, 52, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, 20, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, 20, 21, -1, 48, -1, -1, -1, 52, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, 20, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -+ 42, 43, 44, -1, -1, -1, -1, 49, 21, 22, -+ -1, -1, -1, 55, -1, -1, 29, 30, 31, 32, -+ 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, -+ 43, 44, -1, -1, -1, -1, 49, 21, 22, -1, -+ -1, -1, 55, -1, -1, 29, 30, 31, 32, 33, - 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, 20, 21, -1, 48, -1, -1, -1, 52, 28, -+ 44, -1, -1, -1, -1, 49, 21, 22, -1, -1, -+ -1, 55, -1, -1, 29, 30, 31, 32, 33, 34, -+ 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, -+ -1, -1, -1, -1, 49, 21, 22, -1, -1, -1, -+ 55, -1, -1, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ -1, -1, -1, 49, 21, 22, -1, -1, -1, 55, -+ -1, -1, 29, 30, 31, 32, 33, 34, 35, 36, -+ 37, 38, 39, 40, 41, 42, 43, 44, -1, -1, -+ -1, -1, 49, 22, -1, -1, -1, -1, 55, -1, - 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, 20, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, -1, 21, -1, 48, -1, -1, -1, 52, 28, -+ 39, 40, 41, 42, 43, 44, -1, -1, -1, -1, -+ 49, 22, -1, -1, -1, -1, 55, -1, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, -1, -1, -1, 49, 22, -+ -1, -1, -1, -1, 55, -1, 29, 30, 31, 32, -+ 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, -+ 43, 44, -1, -1, -1, -1, 49, 22, -1, -1, -+ -1, -1, 55, -1, 29, 30, 31, 32, 33, 34, -+ 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, -+ -1, -1, -1, -1, 49, 21, 22, -1, -1, -1, -+ 55, -1, -1, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ 21, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, 21, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ 21, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, 21, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ 21, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, 21, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ 21, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, 21, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ 21, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, 21, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ 21, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, -1, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ -1, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, -1, 22, -1, 49, -1, -+ -1, -1, 53, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, -1, -+ -1, 22, -1, 49, -1, -1, -1, 53, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, -1, -1, -1, -1, 49, -1, -+ -1, 52, 26, 27, 28, 29, 30, 26, 27, 28, -+ 29, 30, -1, -1, -1, 39, -1, -1, -1, -1, -+ 39, -1, -1, -1, -1, 49, -1, -1, -1, -1, -+ 49, 55, 21, 22, -1, -1, 55, -1, -1, -1, - 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, -1, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- -1, -1, 21, -1, 48, -1, -1, -1, 52, 28, -+ 39, 40, 41, 42, 43, 44, 21, 22, -1, -1, -+ 49, -1, -1, -1, 29, 30, 31, 32, 33, 34, -+ 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, -+ 21, 22, -1, -1, 49, -1, -1, -1, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, 21, 22, -1, -1, 49, -1, -+ -1, -1, 29, 30, 31, 32, 33, 34, 35, 36, -+ 37, 38, 39, 40, 41, 42, 43, 44, 21, 22, -+ -1, -1, 49, -1, -1, -1, 29, 30, 31, 32, -+ 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, -+ 43, 44, 21, 22, -1, -1, 49, -1, -1, -1, - 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, -1, 21, -1, 48, -- -1, -1, -1, 52, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- 20, 21, -1, -1, 48, -1, -1, 51, 28, 29, -- 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, -- 40, 41, 42, 43, 20, 21, -1, -1, 48, -1, -- -1, -1, 28, 29, 30, 31, 32, 33, 34, 35, -- 36, 37, 38, 39, 40, 41, 42, 43, 20, 21, -- -1, -1, 48, -1, -1, -1, 28, 29, 30, 31, -+ 39, 40, 41, 42, 43, 44, 21, 22, -1, -1, -+ 49, -1, -1, -1, 29, 30, 31, 32, 33, 34, -+ 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, -+ 22, -1, -1, 25, 49, -1, -1, 29, 30, 31, - 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, -- 42, 43, 20, 21, -1, -1, 48, -1, -1, -1, -- 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, -- 38, 39, 40, 41, 42, 43, 20, 21, -1, -1, -- 48, -1, -1, -1, 28, 29, 30, 31, 32, 33, -- 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- 20, 21, -1, -1, 48, -1, -1, -1, 28, 29, -+ 42, 43, 44, 22, -1, -1, 25, 49, -1, -1, -+ 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -+ 39, 40, 41, 42, 43, 44, 22, -1, -1, 25, -+ 49, -1, -1, 29, 30, 31, 32, 33, 34, 35, -+ 36, 37, 38, 39, 40, 41, 42, 43, 44, 22, -+ -1, -1, 25, 49, -1, -1, 29, 30, 31, 32, -+ 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, -+ 43, 44, 22, 23, -1, -1, 49, -1, -1, 29, - 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, -- 40, 41, 42, 43, 21, -1, -1, 24, 48, -1, -- -1, 28, 29, 30, 31, 32, 33, 34, 35, 36, -- 37, 38, 39, 40, 41, 42, 43, 21, -1, -1, -- 24, 48, -1, -1, 28, 29, 30, 31, 32, 33, -+ 40, 41, 42, 43, 44, 22, 23, -1, -1, 49, -+ -1, -1, 29, 30, 31, 32, 33, 34, 35, 36, -+ 37, 38, 39, 40, 41, 42, 43, 44, 22, -1, -+ -1, -1, 49, -1, -1, 29, 30, 31, 32, 33, - 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, -- 21, -1, -1, 24, 48, -1, -1, 28, 29, 30, -+ 44, -1, -1, 29, 30, 49, 32, 33, 34, 35, -+ 36, 23, -1, -1, 26, 27, 28, 29, 30, 29, -+ 30, -1, 32, 33, 34, 35, 36, 39, -1, 55, -+ -1, -1, -1, -1, -1, 29, 30, 49, 32, 33, -+ 34, 35, 36, 29, 30, 55, 32, 33, 34, 35, -+ 36, -1, -1, -1, -1, 41, 42, -1, -1, -1, -+ -1, 55, -1, 49, 29, 30, 52, 32, 33, 34, -+ 35, 36, 23, -1, -1, -1, -1, -1, 29, 30, -+ -1, 32, 33, 34, 35, 36, -1, 52, 29, 30, - 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -- 41, 42, 43, 21, -1, -1, 24, 48, -1, -1, -- 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, -- 38, 39, 40, 41, 42, 43, 21, 22, -1, -1, -- 48, -1, -1, 28, 29, 30, 31, 32, 33, 34, -- 35, 36, 37, 38, 39, 40, 41, 42, 43, 21, -- 22, -1, -1, 48, -1, -1, 28, 29, 30, 31, -- 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, -- 42, 43, 21, -1, -1, -1, 48, -1, -1, 28, -- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, -- 39, 40, 41, 42, 43, -1, -1, 28, 29, 48, -- 31, 32, 33, 34, 35, -1, -1, -1, -1, 40, -- 41, -1, -1, -1, -1, 28, 29, 48, 31, 32, -- 33, 34, 35, 54, 28, 29, -1, 31, 32, 33, -- 34, 35, 28, 29, -1, 31, 32, 33, 34, 35, -- -1, 54, -1, -1, 40, 41, -1, -1, -1, -1, -- 54, -1, 48, 20, -1, 51, 25, 26, 27, 28, -- 29, 28, 29, -1, 31, 32, 33, 34, 35, 38, -- 28, 29, -1, 31, 32, 33, 34, 35, -1, 48, -- 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, -- 38, 39, 40, 41, 42, 43, -1, -1, 28, 29, -- 48, 31, 32, 33, 34, 35, -1, -1, -1, -1, -- 40, 41, -1, -1, -1, -1, -1, -1, 48, 31, -- 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, -- 42, 43, -1, -1, -1, -1, 48, 35, 36, 37, -- 38, 39, 40, 41, 42, 43, -1, -1, -1, -1, -- 48 -+ 41, 42, 43, 44, -1, -1, 29, 30, 49, 32, -+ 33, 34, 35, 36, -1, -1, -1, -1, 41, 42, -+ -1, -1, -1, -1, -1, -1, 49, 32, 33, 34, -+ 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, -+ 21, -1, -1, -1, 49, -1, -1, -1, 29, 30, -+ -1, 32, 33, 34, 35, 36 - }; - - /* FFSTOS[STATE-NUM] -- The (internal number of the) accessing - symbol of state STATE-NUM. */ --static const fftype_uint8 ffstos[] = -+static const fftype_int8 ffstos[] = - { -- 0, 56, 0, 1, 3, 4, 5, 6, 7, 8, -+ 0, 57, 0, 1, 3, 4, 5, 6, 7, 8, - 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, -- 19, 23, 35, 36, 44, 45, 46, 51, 53, 57, -- 58, 59, 60, 61, 62, 63, 51, 54, 60, 61, -- 62, 63, 60, 61, 62, 63, 60, 61, 63, 6, -- 54, 6, 23, 23, 23, 23, 60, 61, 63, 60, -- 60, 61, 62, 60, 61, 60, 61, 60, 61, 62, -- 63, 20, 24, 20, 24, 21, 28, 29, 30, 31, -- 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, -- 42, 43, 48, 51, 25, 26, 27, 28, 29, 38, -- 48, 51, 28, 29, 31, 32, 33, 34, 35, 40, -- 41, 48, 51, 28, 29, 31, 32, 33, 34, 35, -- 51, 20, 54, 20, 54, 54, 20, 54, 20, 54, -- 54, 54, 20, 20, 54, 20, 54, 60, 60, 60, -- 60, 54, 54, 54, 54, 60, 61, 60, 61, 60, -- 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, -- 60, 61, 60, 60, 60, 60, 60, 60, 60, 61, -- 63, 61, 61, 61, 61, 60, 60, 44, 53, 62, -- 62, 62, 62, 62, 62, 62, 62, 62, 60, 63, -- 63, 63, 63, 63, 63, 63, 60, 61, 60, 63, -- 60, 63, 60, 60, 24, 24, 24, 24, 22, 20, -- 52, 22, 22, 22, 20, 52, 62, 62, 20, 52, -- 20, 54, 54, 20, 54, 20, 54, 20, 54, 20, -- 60, 60, 60, 61, 60, 61, 63, 60, 60, 60, -- 60, 60, 6, 60, 20, 52, 20, 52, 20, 52, -- 20, 54, 20, 54, 20, 20, 54, 60, 60, 60, -- 60, 60, 6, 6, 20, 52, 20, 52, 20, 52, -- 54, 20, 54, 54, 60, 60, 60, 60, 20, 52, -- 20, 52, 20, 52, 20, 54, 60, 60, 60, 60, -- 52, 52, 52, 20, 60, 54 -+ 19, 20, 24, 36, 37, 45, 46, 47, 52, 54, -+ 58, 59, 60, 61, 62, 63, 64, 52, 55, 61, -+ 62, 63, 64, 61, 62, 63, 64, 61, 62, 64, -+ 6, 55, 6, 6, 24, 24, 24, 24, 61, 62, -+ 64, 61, 61, 62, 63, 61, 62, 61, 62, 61, -+ 62, 63, 64, 21, 25, 21, 25, 22, 29, 30, -+ 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, -+ 41, 42, 43, 44, 49, 52, 26, 27, 28, 29, -+ 30, 39, 49, 52, 29, 30, 32, 33, 34, 35, -+ 36, 41, 42, 49, 52, 29, 30, 32, 33, 34, -+ 35, 36, 52, 21, 55, 21, 55, 55, 21, 55, -+ 21, 55, 55, 55, 21, 21, 55, 21, 21, 55, -+ 61, 61, 61, 61, 55, 55, 55, 55, 61, 62, -+ 61, 62, 61, 61, 61, 61, 61, 61, 61, 61, -+ 61, 61, 61, 61, 62, 61, 61, 61, 61, 61, -+ 61, 61, 62, 64, 62, 62, 62, 62, 61, 61, -+ 45, 54, 63, 63, 63, 63, 63, 63, 63, 63, -+ 63, 61, 64, 64, 64, 64, 64, 64, 64, 61, -+ 62, 61, 64, 61, 64, 61, 61, 61, 25, 25, -+ 25, 25, 23, 21, 53, 23, 23, 23, 21, 53, -+ 63, 63, 21, 53, 21, 55, 55, 21, 55, 21, -+ 55, 21, 55, 21, 21, 61, 61, 61, 62, 61, -+ 62, 64, 61, 61, 61, 61, 61, 6, 61, 61, -+ 21, 53, 21, 53, 21, 53, 21, 55, 21, 55, -+ 21, 21, 55, 21, 55, 61, 61, 61, 61, 61, -+ 6, 6, 6, 21, 53, 21, 53, 21, 53, 55, -+ 21, 55, 21, 55, 61, 61, 61, 61, 6, 21, -+ 53, 21, 53, 21, 53, 21, 55, 55, 61, 61, -+ 61, 61, 53, 53, 53, 21, 61, 55 - }; - - /* FFR1[FFN] -- Symbol number of symbol that rule FFN derives. */ --static const fftype_uint8 ffr1[] = -+static const fftype_int8 ffr1[] = - { -- 0, 55, 56, 56, 57, 57, 57, 57, 57, 57, -- 58, 58, 59, 59, 59, 59, 60, 61, 62, 62, -- 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, -- 62, 60, 60, 60, 60, 60, 60, 60, 60, 60, -- 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, -- 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, -- 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, -- 60, 61, 61, 61, 61, 61, 61, 61, 61, 61, -- 61, 61, 61, 61, 61, 61, 61, 61, 61, 61, -+ 0, 56, 57, 57, 58, 58, 58, 58, 58, 58, -+ 59, 59, 60, 60, 60, 60, 61, 62, 63, 63, -+ 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, -+ 63, 61, 61, 61, 61, 61, 61, 61, 61, 61, - 61, 61, 61, 61, 61, 61, 61, 61, 61, 61, - 61, 61, 61, 61, 61, 61, 61, 61, 61, 61, - 61, 61, 61, 61, 61, 61, 61, 61, 61, 61, -- 63, 63, 63, 63, 63, 63, 63, 63, 63 -+ 61, 62, 62, 62, 62, 62, 62, 62, 62, 62, -+ 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, -+ 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, -+ 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, -+ 62, 62, 62, 62, 62, 62, 62, 62, 62, 62, -+ 62, 62, 64, 64, 64, 64, 64, 64, 64, 64, -+ 64 - }; - - /* FFR2[FFN] -- Number of symbols on the right hand side of rule FFN. */ --static const fftype_uint8 ffr2[] = -+static const fftype_int8 ffr2[] = - { - 0, 2, 0, 2, 1, 2, 2, 2, 2, 2, - 2, 3, 2, 3, 3, 3, 2, 2, 1, 1, -@@ -1237,15 +1437,16 @@ static const fftype_uint8 ffr2[] = - 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, - 3, 3, 3, 3, 3, 3, 3, 5, 5, 3, - 3, 3, 5, 7, 11, 15, 2, 3, 5, 9, -- 3, 7, 9, 4, 6, 8, 10, 12, 2, 3, -- 1, 1, 4, 1, 3, 3, 5, 5, 7 -+ 7, 11, 3, 7, 9, 4, 6, 8, 10, 12, -+ 2, 3, 1, 1, 4, 1, 3, 3, 5, 5, -+ 7 - }; - - -+enum { FFENOMEM = -2 }; -+ - #define fferrok (fferrstatus = 0) - #define ffclearin (ffchar = FFEMPTY) --#define FFEMPTY (-2) --#define FFEOF 0 - - #define FFACCEPT goto ffacceptlab - #define FFABORT goto ffabortlab -@@ -1254,27 +1455,26 @@ static const fftype_uint8 ffr2[] = - - #define FFRECOVERING() (!!fferrstatus) - --#define FFBACKUP(Token, Value) \ --do \ -- if (ffchar == FFEMPTY) \ -- { \ -- ffchar = (Token); \ -- fflval = (Value); \ -- FFPOPSTACK (fflen); \ -- ffstate = *ffssp; \ -- goto ffbackup; \ -- } \ -- else \ -- { \ -- fferror (FF_("syntax error: cannot back up")); \ -- FFERROR; \ -- } \ --while (0) -- --/* Error token number */ --#define FFTERROR 1 --#define FFERRCODE 256 -- -+#define FFBACKUP(Token, Value) \ -+ do \ -+ if (ffchar == FFEMPTY) \ -+ { \ -+ ffchar = (Token); \ -+ fflval = (Value); \ -+ FFPOPSTACK (fflen); \ -+ ffstate = *ffssp; \ -+ goto ffbackup; \ -+ } \ -+ else \ -+ { \ -+ fferror (FF_("syntax error: cannot back up")); \ -+ FFERROR; \ -+ } \ -+ while (0) -+ -+/* Backward compatibility with an undocumented macro. -+ Use FFerror or FFUNDEF. */ -+#define FFERRCODE FFUNDEF - - - /* Enable debugging if requested. */ -@@ -1292,54 +1492,58 @@ do { \ - } while (0) - - /* This macro is provided for backward compatibility. */ --#ifndef FF_LOCATION_PRINT --# define FF_LOCATION_PRINT(File, Loc) ((void) 0) --#endif -+# ifndef FF_LOCATION_PRINT -+# define FF_LOCATION_PRINT(File, Loc) ((void) 0) -+# endif - - --# define FF_SYMBOL_PRINT(Title, Type, Value, Location) \ -+# define FF_SYMBOL_PRINT(Title, Kind, Value, Location) \ - do { \ - if (ffdebug) \ - { \ - FFFPRINTF (stderr, "%s ", Title); \ - ff_symbol_print (stderr, \ -- Type, Value); \ -+ Kind, Value); \ - FFFPRINTF (stderr, "\n"); \ - } \ - } while (0) - - --/*----------------------------------------. --| Print this symbol's value on FFOUTPUT. | --`----------------------------------------*/ -+/*-----------------------------------. -+| Print this symbol's value on FFO. | -+`-----------------------------------*/ - - static void --ff_symbol_value_print (FILE *ffoutput, int fftype, FFSTYPE const * const ffvaluep) -+ff_symbol_value_print (FILE *ffo, -+ ffsymbol_kind_t ffkind, FFSTYPE const * const ffvaluep) - { -- FILE *ffo = ffoutput; -- FFUSE (ffo); -+ FILE *ffoutput = ffo; -+ FFUSE (ffoutput); - if (!ffvaluep) - return; - # ifdef FFPRINT -- if (fftype < FFNTOKENS) -- FFPRINT (ffoutput, fftoknum[fftype], *ffvaluep); -+ if (ffkind < FFNTOKENS) -+ FFPRINT (ffo, fftoknum[ffkind], *ffvaluep); - # endif -- FFUSE (fftype); -+ FF_IGNORE_MAYBE_UNINITIALIZED_BEGIN -+ FFUSE (ffkind); -+ FF_IGNORE_MAYBE_UNINITIALIZED_END - } - - --/*--------------------------------. --| Print this symbol on FFOUTPUT. | --`--------------------------------*/ -+/*---------------------------. -+| Print this symbol on FFO. | -+`---------------------------*/ - - static void --ff_symbol_print (FILE *ffoutput, int fftype, FFSTYPE const * const ffvaluep) -+ff_symbol_print (FILE *ffo, -+ ffsymbol_kind_t ffkind, FFSTYPE const * const ffvaluep) - { -- FFFPRINTF (ffoutput, "%s %s (", -- fftype < FFNTOKENS ? "token" : "nterm", fftname[fftype]); -+ FFFPRINTF (ffo, "%s %s (", -+ ffkind < FFNTOKENS ? "token" : "nterm", ffsymbol_name (ffkind)); - -- ff_symbol_value_print (ffoutput, fftype, ffvaluep); -- FFFPRINTF (ffoutput, ")"); -+ ff_symbol_value_print (ffo, ffkind, ffvaluep); -+ FFFPRINTF (ffo, ")"); - } - - /*------------------------------------------------------------------. -@@ -1348,7 +1552,7 @@ ff_symbol_print (FILE *ffoutput, int fftype, FFSTYPE const * const ffvaluep) - `------------------------------------------------------------------*/ - - static void --ff_stack_print (fftype_int16 *ffbottom, fftype_int16 *fftop) -+ff_stack_print (ff_state_t *ffbottom, ff_state_t *fftop) - { - FFFPRINTF (stderr, "Stack now"); - for (; ffbottom <= fftop; ffbottom++) -@@ -1371,21 +1575,21 @@ do { \ - `------------------------------------------------*/ - - static void --ff_reduce_print (fftype_int16 *ffssp, FFSTYPE *ffvsp, int ffrule) -+ff_reduce_print (ff_state_t *ffssp, FFSTYPE *ffvsp, -+ int ffrule) - { -- unsigned long int fflno = ffrline[ffrule]; -+ int fflno = ffrline[ffrule]; - int ffnrhs = ffr2[ffrule]; - int ffi; -- FFFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n", -+ FFFPRINTF (stderr, "Reducing stack by rule %d (line %d):\n", - ffrule - 1, fflno); - /* The symbols being reduced. */ - for (ffi = 0; ffi < ffnrhs; ffi++) - { - FFFPRINTF (stderr, " $%d = ", ffi + 1); - ff_symbol_print (stderr, -- ffstos[ffssp[ffi + 1 - ffnrhs]], -- &(ffvsp[(ffi + 1) - (ffnrhs)]) -- ); -+ FF_ACCESSING_SYMBOL (+ffssp[ffi + 1 - ffnrhs]), -+ &ffvsp[(ffi + 1) - (ffnrhs)]); - FFFPRINTF (stderr, "\n"); - } - } -@@ -1400,8 +1604,8 @@ do { \ - multiple parsers can coexist. */ - int ffdebug; - #else /* !FFDEBUG */ --# define FFDPRINTF(Args) --# define FF_SYMBOL_PRINT(Title, Type, Value, Location) -+# define FFDPRINTF(Args) ((void) 0) -+# define FF_SYMBOL_PRINT(Title, Kind, Value, Location) - # define FF_STACK_PRINT(Bottom, Top) - # define FF_REDUCE_PRINT(Rule) - #endif /* !FFDEBUG */ -@@ -1424,250 +1628,30 @@ int ffdebug; - #endif - - --#if FFERROR_VERBOSE - --# ifndef ffstrlen --# if defined __GLIBC__ && defined _STRING_H --# define ffstrlen strlen --# else --/* Return the length of FFSTR. */ --static FFSIZE_T --ffstrlen (const char *ffstr) --{ -- FFSIZE_T fflen; -- for (fflen = 0; ffstr[fflen]; fflen++) -- continue; -- return fflen; --} --# endif --# endif - --# ifndef ffstpcpy --# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE --# define ffstpcpy stpcpy --# else --/* Copy FFSRC to FFDEST, returning the address of the terminating '\0' in -- FFDEST. */ --static char * --ffstpcpy (char *ffdest, const char *ffsrc) --{ -- char *ffd = ffdest; -- const char *ffs = ffsrc; - -- while ((*ffd++ = *ffs++) != '\0') -- continue; -- -- return ffd - 1; --} --# endif --# endif -- --# ifndef fftnamerr --/* Copy to FFRES the contents of FFSTR after stripping away unnecessary -- quotes and backslashes, so that it's suitable for fferror. The -- heuristic is that double-quoting is unnecessary unless the string -- contains an apostrophe, a comma, or backslash (other than -- backslash-backslash). FFSTR is taken from fftname. If FFRES is -- null, do not copy; instead, return the length of what the result -- would have been. */ --static FFSIZE_T --fftnamerr (char *ffres, const char *ffstr) --{ -- if (*ffstr == '"') -- { -- FFSIZE_T ffn = 0; -- char const *ffp = ffstr; -- -- for (;;) -- switch (*++ffp) -- { -- case '\'': -- case ',': -- goto do_not_strip_quotes; -- -- case '\\': -- if (*++ffp != '\\') -- goto do_not_strip_quotes; -- /* Fall through. */ -- default: -- if (ffres) -- ffres[ffn] = *ffp; -- ffn++; -- break; -- -- case '"': -- if (ffres) -- ffres[ffn] = '\0'; -- return ffn; -- } -- do_not_strip_quotes: ; -- } -- -- if (! ffres) -- return ffstrlen (ffstr); -- -- return ffstpcpy (ffres, ffstr) - ffres; --} --# endif -- --/* Copy into *FFMSG, which is of size *FFMSG_ALLOC, an error message -- about the unexpected token FFTOKEN for the state stack whose top is -- FFSSP. -- -- Return 0 if *FFMSG was successfully written. Return 1 if *FFMSG is -- not large enough to hold the message. In that case, also set -- *FFMSG_ALLOC to the required number of bytes. Return 2 if the -- required number of bytes is too large to store. */ --static int --ffsyntax_error (FFSIZE_T *ffmsg_alloc, char **ffmsg, -- fftype_int16 *ffssp, int fftoken) --{ -- FFSIZE_T ffsize0 = fftnamerr (FF_NULLPTR, fftname[fftoken]); -- FFSIZE_T ffsize = ffsize0; -- enum { FFERROR_VERBOSE_ARGS_MAXIMUM = 5 }; -- /* Internationalized format string. */ -- const char *ffformat = FF_NULLPTR; -- /* Arguments of ffformat. */ -- char const *ffarg[FFERROR_VERBOSE_ARGS_MAXIMUM]; -- /* Number of reported tokens (one for the "unexpected", one per -- "expected"). */ -- int ffcount = 0; -- -- /* There are many possibilities here to consider: -- - If this state is a consistent state with a default action, then -- the only way this function was invoked is if the default action -- is an error action. In that case, don't check for expected -- tokens because there are none. -- - The only way there can be no lookahead present (in ffchar) is if -- this state is a consistent state with a default action. Thus, -- detecting the absence of a lookahead is sufficient to determine -- that there is no unexpected or expected token to report. In that -- case, just report a simple "syntax error". -- - Don't assume there isn't a lookahead just because this state is a -- consistent state with a default action. There might have been a -- previous inconsistent state, consistent state with a non-default -- action, or user semantic action that manipulated ffchar. -- - Of course, the expected token list depends on states to have -- correct lookahead information, and it depends on the parser not -- to perform extra reductions after fetching a lookahead from the -- scanner and before detecting a syntax error. Thus, state merging -- (from LALR or IELR) and default reductions corrupt the expected -- token list. However, the list is correct for canonical LR with -- one exception: it will still contain any token that will not be -- accepted due to an error action in a later state. -- */ -- if (fftoken != FFEMPTY) -- { -- int ffn = ffpact[*ffssp]; -- ffarg[ffcount++] = fftname[fftoken]; -- if (!ffpact_value_is_default (ffn)) -- { -- /* Start FFX at -FFN if negative to avoid negative indexes in -- FFCHECK. In other words, skip the first -FFN actions for -- this state because they are default actions. */ -- int ffxbegin = ffn < 0 ? -ffn : 0; -- /* Stay within bounds of both ffcheck and fftname. */ -- int ffchecklim = FFLAST - ffn + 1; -- int ffxend = ffchecklim < FFNTOKENS ? ffchecklim : FFNTOKENS; -- int ffx; -- -- for (ffx = ffxbegin; ffx < ffxend; ++ffx) -- if (ffcheck[ffx + ffn] == ffx && ffx != FFTERROR -- && !fftable_value_is_error (fftable[ffx + ffn])) -- { -- if (ffcount == FFERROR_VERBOSE_ARGS_MAXIMUM) -- { -- ffcount = 1; -- ffsize = ffsize0; -- break; -- } -- ffarg[ffcount++] = fftname[ffx]; -- { -- FFSIZE_T ffsize1 = ffsize + fftnamerr (FF_NULLPTR, fftname[ffx]); -- if (! (ffsize <= ffsize1 -- && ffsize1 <= FFSTACK_ALLOC_MAXIMUM)) -- return 2; -- ffsize = ffsize1; -- } -- } -- } -- } -- -- switch (ffcount) -- { --# define FFCASE_(N, S) \ -- case N: \ -- ffformat = S; \ -- break -- default: /* Avoid compiler warnings. */ -- FFCASE_(0, FF_("syntax error")); -- FFCASE_(1, FF_("syntax error, unexpected %s")); -- FFCASE_(2, FF_("syntax error, unexpected %s, expecting %s")); -- FFCASE_(3, FF_("syntax error, unexpected %s, expecting %s or %s")); -- FFCASE_(4, FF_("syntax error, unexpected %s, expecting %s or %s or %s")); -- FFCASE_(5, FF_("syntax error, unexpected %s, expecting %s or %s or %s or %s")); --# undef FFCASE_ -- } -- -- { -- FFSIZE_T ffsize1 = ffsize + ffstrlen (ffformat); -- if (! (ffsize <= ffsize1 && ffsize1 <= FFSTACK_ALLOC_MAXIMUM)) -- return 2; -- ffsize = ffsize1; -- } -- -- if (*ffmsg_alloc < ffsize) -- { -- *ffmsg_alloc = 2 * ffsize; -- if (! (ffsize <= *ffmsg_alloc -- && *ffmsg_alloc <= FFSTACK_ALLOC_MAXIMUM)) -- *ffmsg_alloc = FFSTACK_ALLOC_MAXIMUM; -- return 1; -- } -- -- /* Avoid sprintf, as that infringes on the user's name space. -- Don't have undefined behavior even if the translation -- produced a string with the wrong number of "%s"s. */ -- { -- char *ffp = *ffmsg; -- int ffi = 0; -- while ((*ffp = *ffformat) != '\0') -- if (*ffp == '%' && ffformat[1] == 's' && ffi < ffcount) -- { -- ffp += fftnamerr (ffp, ffarg[ffi++]); -- ffformat += 2; -- } -- else -- { -- ffp++; -- ffformat++; -- } -- } -- return 0; --} --#endif /* FFERROR_VERBOSE */ - - /*-----------------------------------------------. - | Release the memory associated to this symbol. | - `-----------------------------------------------*/ - - static void --ffdestruct (const char *ffmsg, int fftype, FFSTYPE *ffvaluep) -+ffdestruct (const char *ffmsg, -+ ffsymbol_kind_t ffkind, FFSTYPE *ffvaluep) - { - FFUSE (ffvaluep); - if (!ffmsg) - ffmsg = "Deleting"; -- FF_SYMBOL_PRINT (ffmsg, fftype, ffvaluep, fflocationp); -+ FF_SYMBOL_PRINT (ffmsg, ffkind, ffvaluep, fflocationp); - - FF_IGNORE_MAYBE_UNINITIALIZED_BEGIN -- FFUSE (fftype); -+ FFUSE (ffkind); - FF_IGNORE_MAYBE_UNINITIALIZED_END - } - - -- -- --/* The lookahead symbol. */ -+/* Lookahead token kind. */ - int ffchar; - - /* The semantic value of the lookahead symbol. */ -@@ -1676,6 +1660,8 @@ FFSTYPE fflval; - int ffnerrs; - - -+ -+ - /*----------. - | ffparse. | - `----------*/ -@@ -1683,43 +1669,36 @@ int ffnerrs; - int - ffparse (void) - { -- int ffstate; -+ ff_state_fast_t ffstate = 0; - /* Number of tokens to shift before error messages enabled. */ -- int fferrstatus; -- -- /* The stacks and their tools: -- 'ffss': related to states. -- 'ffvs': related to semantic values. -+ int fferrstatus = 0; - -- Refer to the stacks through separate pointers, to allow ffoverflow -+ /* Refer to the stacks through separate pointers, to allow ffoverflow - to reallocate them elsewhere. */ - -- /* The state stack. */ -- fftype_int16 ffssa[FFINITDEPTH]; -- fftype_int16 *ffss; -- fftype_int16 *ffssp; -+ /* Their size. */ -+ FFPTRDIFF_T ffstacksize = FFINITDEPTH; - -- /* The semantic value stack. */ -- FFSTYPE ffvsa[FFINITDEPTH]; -- FFSTYPE *ffvs; -- FFSTYPE *ffvsp; -+ /* The state stack: array, bottom, top. */ -+ ff_state_t ffssa[FFINITDEPTH]; -+ ff_state_t *ffss = ffssa; -+ ff_state_t *ffssp = ffss; - -- FFSIZE_T ffstacksize; -+ /* The semantic value stack: array, bottom, top. */ -+ FFSTYPE ffvsa[FFINITDEPTH]; -+ FFSTYPE *ffvs = ffvsa; -+ FFSTYPE *ffvsp = ffvs; - - int ffn; -+ /* The return value of ffparse. */ - int ffresult; -- /* Lookahead token as an internal (translated) token number. */ -- int fftoken = 0; -+ /* Lookahead symbol kind. */ -+ ffsymbol_kind_t fftoken = FFSYMBOL_FFEMPTY; - /* The variables used to return semantic value and location from the - action routines. */ - FFSTYPE ffval; - --#if FFERROR_VERBOSE -- /* Buffer for error messages, and its allocated size. */ -- char ffmsgbuf[128]; -- char *ffmsg = ffmsgbuf; -- FFSIZE_T ffmsg_alloc = sizeof ffmsgbuf; --#endif -+ - - #define FFPOPSTACK(N) (ffvsp -= (N), ffssp -= (N)) - -@@ -1727,58 +1706,60 @@ ffparse (void) - Keep to zero when no symbol should be popped. */ - int fflen = 0; - -- ffssp = ffss = ffssa; -- ffvsp = ffvs = ffvsa; -- ffstacksize = FFINITDEPTH; -- - FFDPRINTF ((stderr, "Starting parse\n")); - -- ffstate = 0; -- fferrstatus = 0; -- ffnerrs = 0; - ffchar = FFEMPTY; /* Cause a token to be read. */ - goto ffsetstate; - -+ - /*------------------------------------------------------------. --| ffnewstate -- Push a new state, which is found in ffstate. | -+| ffnewstate -- push a new state, which is found in ffstate. | - `------------------------------------------------------------*/ -- ffnewstate: -+ffnewstate: - /* In all cases, when you get here, the value and location stacks - have just been pushed. So pushing a state here evens the stacks. */ - ffssp++; - -- ffsetstate: -- *ffssp = ffstate; -+ -+/*--------------------------------------------------------------------. -+| ffsetstate -- set current state (the top of the stack) to ffstate. | -+`--------------------------------------------------------------------*/ -+ffsetstate: -+ FFDPRINTF ((stderr, "Entering state %d\n", ffstate)); -+ FF_ASSERT (0 <= ffstate && ffstate < FFNSTATES); -+ FF_IGNORE_USELESS_CAST_BEGIN -+ *ffssp = FF_CAST (ff_state_t, ffstate); -+ FF_IGNORE_USELESS_CAST_END -+ FF_STACK_PRINT (ffss, ffssp); - - if (ffss + ffstacksize - 1 <= ffssp) -+#if !defined ffoverflow && !defined FFSTACK_RELOCATE -+ goto ffexhaustedlab; -+#else - { - /* Get the current used size of the three stacks, in elements. */ -- FFSIZE_T ffsize = ffssp - ffss + 1; -+ FFPTRDIFF_T ffsize = ffssp - ffss + 1; - --#ifdef ffoverflow -+# if defined ffoverflow - { - /* Give user a chance to reallocate the stack. Use copies of - these so that the &'s don't force the real ones into - memory. */ -+ ff_state_t *ffss1 = ffss; - FFSTYPE *ffvs1 = ffvs; -- fftype_int16 *ffss1 = ffss; - - /* Each stack pointer address is followed by the size of the - data in use in that stack, in bytes. This used to be a - conditional around just the two extra args, but that might - be undefined if ffoverflow is a macro. */ - ffoverflow (FF_("memory exhausted"), -- &ffss1, ffsize * sizeof (*ffssp), -- &ffvs1, ffsize * sizeof (*ffvsp), -+ &ffss1, ffsize * FFSIZEOF (*ffssp), -+ &ffvs1, ffsize * FFSIZEOF (*ffvsp), - &ffstacksize); -- - ffss = ffss1; - ffvs = ffvs1; - } --#else /* no ffoverflow */ --# ifndef FFSTACK_RELOCATE -- goto ffexhaustedlab; --# else -+# else /* defined FFSTACK_RELOCATE */ - /* Extend the stack our own way. */ - if (FFMAXDEPTH <= ffstacksize) - goto ffexhaustedlab; -@@ -1787,9 +1768,10 @@ ffparse (void) - ffstacksize = FFMAXDEPTH; - - { -- fftype_int16 *ffss1 = ffss; -+ ff_state_t *ffss1 = ffss; - union ffalloc *ffptr = -- (union ffalloc *) FFSTACK_ALLOC (FFSTACK_BYTES (ffstacksize)); -+ FF_CAST (union ffalloc *, -+ FFSTACK_ALLOC (FF_CAST (FFSIZE_T, FFSTACK_BYTES (ffstacksize)))); - if (! ffptr) - goto ffexhaustedlab; - FFSTACK_RELOCATE (ffss_alloc, ffss); -@@ -1799,30 +1781,30 @@ ffparse (void) - FFSTACK_FREE (ffss1); - } - # endif --#endif /* no ffoverflow */ - - ffssp = ffss + ffsize - 1; - ffvsp = ffvs + ffsize - 1; - -- FFDPRINTF ((stderr, "Stack size increased to %lu\n", -- (unsigned long int) ffstacksize)); -+ FF_IGNORE_USELESS_CAST_BEGIN -+ FFDPRINTF ((stderr, "Stack size increased to %ld\n", -+ FF_CAST (long, ffstacksize))); -+ FF_IGNORE_USELESS_CAST_END - - if (ffss + ffstacksize - 1 <= ffssp) - FFABORT; - } -- -- FFDPRINTF ((stderr, "Entering state %d\n", ffstate)); -+#endif /* !defined ffoverflow && !defined FFSTACK_RELOCATE */ - - if (ffstate == FFFINAL) - FFACCEPT; - - goto ffbackup; - -+ - /*-----------. - | ffbackup. | - `-----------*/ - ffbackup: -- - /* Do appropriate processing given the current state. Read a - lookahead token if we need one and don't already have one. */ - -@@ -1833,18 +1815,29 @@ ffparse (void) - - /* Not known => get a lookahead token if don't already have one. */ - -- /* FFCHAR is either FFEMPTY or FFEOF or a valid lookahead symbol. */ -+ /* FFCHAR is either empty, or end-of-input, or a valid lookahead. */ - if (ffchar == FFEMPTY) - { -- FFDPRINTF ((stderr, "Reading a token: ")); -+ FFDPRINTF ((stderr, "Reading a token\n")); - ffchar = fflex (); - } - - if (ffchar <= FFEOF) - { -- ffchar = fftoken = FFEOF; -+ ffchar = FFEOF; -+ fftoken = FFSYMBOL_FFEOF; - FFDPRINTF ((stderr, "Now at end of input.\n")); - } -+ else if (ffchar == FFerror) -+ { -+ /* The scanner already issued an error message, process directly -+ to error recovery. But do not keep the error token as -+ lookahead, it is too special and may lead us to an endless -+ loop in error recovery. */ -+ ffchar = FFUNDEF; -+ fftoken = FFSYMBOL_FFerror; -+ goto fferrlab1; -+ } - else - { - fftoken = FFTRANSLATE (ffchar); -@@ -1872,15 +1865,13 @@ ffparse (void) - - /* Shift the lookahead token. */ - FF_SYMBOL_PRINT ("Shifting", fftoken, &fflval, &fflloc); -- -- /* Discard the shifted token. */ -- ffchar = FFEMPTY; -- - ffstate = ffn; - FF_IGNORE_MAYBE_UNINITIALIZED_BEGIN - *++ffvsp = fflval; - FF_IGNORE_MAYBE_UNINITIALIZED_END - -+ /* Discard the shifted token. */ -+ ffchar = FFEMPTY; - goto ffnewstate; - - -@@ -1895,7 +1886,7 @@ ffparse (void) - - - /*-----------------------------. --| ffreduce -- Do a reduction. | -+| ffreduce -- do a reduction. | - `-----------------------------*/ - ffreduce: - /* ffn is the number of a rule to reduce with. */ -@@ -1915,67 +1906,67 @@ ffparse (void) - FF_REDUCE_PRINT (ffn); - switch (ffn) - { -- case 4: --#line 248 "eval.y" /* yacc.c:1648 */ -- {} --#line 1922 "y.tab.c" /* yacc.c:1648 */ -+ case 4: /* line: '\n' */ -+#line 256 "eval.y" -+ {} -+#line 1913 "y.tab.c" - break; - -- case 5: --#line 250 "eval.y" /* yacc.c:1648 */ -- { if( (ffvsp[-1].Node)<0 ) { -+ case 5: /* line: expr '\n' */ -+#line 258 "eval.y" -+ { if( (ffvsp[-1].Node)<0 ) { - fferror("Couldn't build node structure: out of memory?"); - FFERROR; } - gParse.resultNode = (ffvsp[-1].Node); - } --#line 1932 "y.tab.c" /* yacc.c:1648 */ -+#line 1923 "y.tab.c" - break; - -- case 6: --#line 256 "eval.y" /* yacc.c:1648 */ -- { if( (ffvsp[-1].Node)<0 ) { -+ case 6: /* line: bexpr '\n' */ -+#line 264 "eval.y" -+ { if( (ffvsp[-1].Node)<0 ) { - fferror("Couldn't build node structure: out of memory?"); - FFERROR; } - gParse.resultNode = (ffvsp[-1].Node); - } --#line 1942 "y.tab.c" /* yacc.c:1648 */ -+#line 1933 "y.tab.c" - break; - -- case 7: --#line 262 "eval.y" /* yacc.c:1648 */ -- { if( (ffvsp[-1].Node)<0 ) { -+ case 7: /* line: sexpr '\n' */ -+#line 270 "eval.y" -+ { if( (ffvsp[-1].Node)<0 ) { - fferror("Couldn't build node structure: out of memory?"); - FFERROR; } - gParse.resultNode = (ffvsp[-1].Node); - } --#line 1952 "y.tab.c" /* yacc.c:1648 */ -+#line 1943 "y.tab.c" - break; - -- case 8: --#line 268 "eval.y" /* yacc.c:1648 */ -- { if( (ffvsp[-1].Node)<0 ) { -+ case 8: /* line: bits '\n' */ -+#line 276 "eval.y" -+ { if( (ffvsp[-1].Node)<0 ) { - fferror("Couldn't build node structure: out of memory?"); - FFERROR; } - gParse.resultNode = (ffvsp[-1].Node); - } --#line 1962 "y.tab.c" /* yacc.c:1648 */ -+#line 1953 "y.tab.c" - break; - -- case 9: --#line 273 "eval.y" /* yacc.c:1648 */ -- { fferrok; } --#line 1968 "y.tab.c" /* yacc.c:1648 */ -+ case 9: /* line: error '\n' */ -+#line 281 "eval.y" -+ { fferrok; } -+#line 1959 "y.tab.c" - break; - -- case 10: --#line 277 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Vector( (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 1974 "y.tab.c" /* yacc.c:1648 */ -+ case 10: /* bvector: '{' bexpr */ -+#line 285 "eval.y" -+ { (ffval.Node) = New_Vector( (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 1965 "y.tab.c" - break; - -- case 11: --#line 279 "eval.y" /* yacc.c:1648 */ -- { -+ case 11: /* bvector: bvector ',' bexpr */ -+#line 287 "eval.y" -+ { - if( gParse.Nodes[(ffvsp[-2].Node)].nSubNodes >= MAXSUBS ) { - (ffvsp[-2].Node) = Close_Vec( (ffvsp[-2].Node) ); TEST((ffvsp[-2].Node)); - (ffval.Node) = New_Vector( (ffvsp[-2].Node) ); TEST((ffval.Node)); -@@ -1985,18 +1976,18 @@ ffparse (void) - gParse.Nodes[(ffval.Node)].SubNodes[ gParse.Nodes[(ffval.Node)].nSubNodes++ ] - = (ffvsp[0].Node); - } --#line 1989 "y.tab.c" /* yacc.c:1648 */ -+#line 1980 "y.tab.c" - break; - -- case 12: --#line 292 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Vector( (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 1995 "y.tab.c" /* yacc.c:1648 */ -+ case 12: /* vector: '{' expr */ -+#line 300 "eval.y" -+ { (ffval.Node) = New_Vector( (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 1986 "y.tab.c" - break; - -- case 13: --#line 294 "eval.y" /* yacc.c:1648 */ -- { -+ case 13: /* vector: vector ',' expr */ -+#line 302 "eval.y" -+ { - if( TYPE((ffvsp[-2].Node)) < TYPE((ffvsp[0].Node)) ) - TYPE((ffvsp[-2].Node)) = TYPE((ffvsp[0].Node)); - if( gParse.Nodes[(ffvsp[-2].Node)].nSubNodes >= MAXSUBS ) { -@@ -2008,12 +1999,12 @@ ffparse (void) - gParse.Nodes[(ffval.Node)].SubNodes[ gParse.Nodes[(ffval.Node)].nSubNodes++ ] - = (ffvsp[0].Node); - } --#line 2012 "y.tab.c" /* yacc.c:1648 */ -+#line 2003 "y.tab.c" - break; - -- case 14: --#line 307 "eval.y" /* yacc.c:1648 */ -- { -+ case 14: /* vector: vector ',' bexpr */ -+#line 315 "eval.y" -+ { - if( gParse.Nodes[(ffvsp[-2].Node)].nSubNodes >= MAXSUBS ) { - (ffvsp[-2].Node) = Close_Vec( (ffvsp[-2].Node) ); TEST((ffvsp[-2].Node)); - (ffval.Node) = New_Vector( (ffvsp[-2].Node) ); TEST((ffval.Node)); -@@ -2023,12 +2014,12 @@ ffparse (void) - gParse.Nodes[(ffval.Node)].SubNodes[ gParse.Nodes[(ffval.Node)].nSubNodes++ ] - = (ffvsp[0].Node); - } --#line 2027 "y.tab.c" /* yacc.c:1648 */ -+#line 2018 "y.tab.c" - break; - -- case 15: --#line 318 "eval.y" /* yacc.c:1648 */ -- { -+ case 15: /* vector: bvector ',' expr */ -+#line 326 "eval.y" -+ { - TYPE((ffvsp[-2].Node)) = TYPE((ffvsp[0].Node)); - if( gParse.Nodes[(ffvsp[-2].Node)].nSubNodes >= MAXSUBS ) { - (ffvsp[-2].Node) = Close_Vec( (ffvsp[-2].Node) ); TEST((ffvsp[-2].Node)); -@@ -2039,38 +2030,38 @@ ffparse (void) - gParse.Nodes[(ffval.Node)].SubNodes[ gParse.Nodes[(ffval.Node)].nSubNodes++ ] - = (ffvsp[0].Node); - } --#line 2043 "y.tab.c" /* yacc.c:1648 */ -+#line 2034 "y.tab.c" - break; - -- case 16: --#line 332 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = Close_Vec( (ffvsp[-1].Node) ); TEST((ffval.Node)); } --#line 2049 "y.tab.c" /* yacc.c:1648 */ -+ case 16: /* expr: vector '}' */ -+#line 340 "eval.y" -+ { (ffval.Node) = Close_Vec( (ffvsp[-1].Node) ); TEST((ffval.Node)); } -+#line 2040 "y.tab.c" - break; - -- case 17: --#line 336 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = Close_Vec( (ffvsp[-1].Node) ); TEST((ffval.Node)); } --#line 2055 "y.tab.c" /* yacc.c:1648 */ -+ case 17: /* bexpr: bvector '}' */ -+#line 344 "eval.y" -+ { (ffval.Node) = Close_Vec( (ffvsp[-1].Node) ); TEST((ffval.Node)); } -+#line 2046 "y.tab.c" - break; - -- case 18: --#line 340 "eval.y" /* yacc.c:1648 */ -- { -+ case 18: /* bits: BITSTR */ -+#line 348 "eval.y" -+ { - (ffval.Node) = New_Const( BITSTR, (ffvsp[0].str), strlen((ffvsp[0].str))+1 ); TEST((ffval.Node)); - SIZE((ffval.Node)) = strlen((ffvsp[0].str)); } --#line 2063 "y.tab.c" /* yacc.c:1648 */ -+#line 2054 "y.tab.c" - break; - -- case 19: --#line 344 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Column( (ffvsp[0].lng) ); TEST((ffval.Node)); } --#line 2069 "y.tab.c" /* yacc.c:1648 */ -+ case 19: /* bits: BITCOL */ -+#line 352 "eval.y" -+ { (ffval.Node) = New_Column( (ffvsp[0].lng) ); TEST((ffval.Node)); } -+#line 2060 "y.tab.c" - break; - -- case 20: --#line 346 "eval.y" /* yacc.c:1648 */ -- { -+ case 20: /* bits: BITCOL '{' expr '}' */ -+#line 354 "eval.y" -+ { - if( TYPE((ffvsp[-1].Node)) != LONG - || OPER((ffvsp[-1].Node)) != CONST_OP ) { - fferror("Offset argument must be a constant integer"); -@@ -2078,26 +2069,26 @@ ffparse (void) - } - (ffval.Node) = New_Offset( (ffvsp[-3].lng), (ffvsp[-1].Node) ); TEST((ffval.Node)); - } --#line 2082 "y.tab.c" /* yacc.c:1648 */ -+#line 2073 "y.tab.c" - break; - -- case 21: --#line 355 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BITSTR, (ffvsp[-2].Node), '&', (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 21: /* bits: bits '&' bits */ -+#line 363 "eval.y" -+ { (ffval.Node) = New_BinOp( BITSTR, (ffvsp[-2].Node), '&', (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = ( SIZE((ffvsp[-2].Node))>SIZE((ffvsp[0].Node)) ? SIZE((ffvsp[-2].Node)) : SIZE((ffvsp[0].Node)) ); } --#line 2089 "y.tab.c" /* yacc.c:1648 */ -+#line 2080 "y.tab.c" - break; - -- case 22: --#line 358 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BITSTR, (ffvsp[-2].Node), '|', (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 22: /* bits: bits '|' bits */ -+#line 366 "eval.y" -+ { (ffval.Node) = New_BinOp( BITSTR, (ffvsp[-2].Node), '|', (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = ( SIZE((ffvsp[-2].Node))>SIZE((ffvsp[0].Node)) ? SIZE((ffvsp[-2].Node)) : SIZE((ffvsp[0].Node)) ); } --#line 2096 "y.tab.c" /* yacc.c:1648 */ -+#line 2087 "y.tab.c" - break; - -- case 23: --#line 361 "eval.y" /* yacc.c:1648 */ -- { -+ case 23: /* bits: bits '+' bits */ -+#line 369 "eval.y" -+ { - if (SIZE((ffvsp[-2].Node))+SIZE((ffvsp[0].Node)) >= MAX_STRLEN) { - fferror("Combined bit string size exceeds " MAX_STRLEN_S " bits"); - FFERROR; -@@ -2105,72 +2096,72 @@ ffparse (void) - (ffval.Node) = New_BinOp( BITSTR, (ffvsp[-2].Node), '+', (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = SIZE((ffvsp[-2].Node)) + SIZE((ffvsp[0].Node)); - } --#line 2109 "y.tab.c" /* yacc.c:1648 */ -+#line 2100 "y.tab.c" - break; - -- case 24: --#line 370 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-3].Node), 1, (ffvsp[-1].Node), 0, 0, 0, 0 ); TEST((ffval.Node)); } --#line 2115 "y.tab.c" /* yacc.c:1648 */ -+ case 24: /* bits: bits '[' expr ']' */ -+#line 378 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-3].Node), 1, (ffvsp[-1].Node), 0, 0, 0, 0 ); TEST((ffval.Node)); } -+#line 2106 "y.tab.c" - break; - -- case 25: --#line 372 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-5].Node), 2, (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0, 0 ); TEST((ffval.Node)); } --#line 2121 "y.tab.c" /* yacc.c:1648 */ -+ case 25: /* bits: bits '[' expr ',' expr ']' */ -+#line 380 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-5].Node), 2, (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0, 0 ); TEST((ffval.Node)); } -+#line 2112 "y.tab.c" - break; - -- case 26: --#line 374 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-7].Node), 3, (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0 ); TEST((ffval.Node)); } --#line 2127 "y.tab.c" /* yacc.c:1648 */ -+ case 26: /* bits: bits '[' expr ',' expr ',' expr ']' */ -+#line 382 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-7].Node), 3, (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0 ); TEST((ffval.Node)); } -+#line 2118 "y.tab.c" - break; - -- case 27: --#line 376 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-9].Node), 4, (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0 ); TEST((ffval.Node)); } --#line 2133 "y.tab.c" /* yacc.c:1648 */ -+ case 27: /* bits: bits '[' expr ',' expr ',' expr ',' expr ']' */ -+#line 384 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-9].Node), 4, (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0 ); TEST((ffval.Node)); } -+#line 2124 "y.tab.c" - break; - -- case 28: --#line 378 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-11].Node), 5, (ffvsp[-9].Node), (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node) ); TEST((ffval.Node)); } --#line 2139 "y.tab.c" /* yacc.c:1648 */ -+ case 28: /* bits: bits '[' expr ',' expr ',' expr ',' expr ',' expr ']' */ -+#line 386 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-11].Node), 5, (ffvsp[-9].Node), (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node) ); TEST((ffval.Node)); } -+#line 2130 "y.tab.c" - break; - -- case 29: --#line 380 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Unary( BITSTR, NOT, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2145 "y.tab.c" /* yacc.c:1648 */ -+ case 29: /* bits: NOT bits */ -+#line 388 "eval.y" -+ { (ffval.Node) = New_Unary( BITSTR, NOT, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2136 "y.tab.c" - break; - -- case 30: --#line 383 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = (ffvsp[-1].Node); } --#line 2151 "y.tab.c" /* yacc.c:1648 */ -+ case 30: /* bits: '(' bits ')' */ -+#line 391 "eval.y" -+ { (ffval.Node) = (ffvsp[-1].Node); } -+#line 2142 "y.tab.c" - break; - -- case 31: --#line 387 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Const( LONG, &((ffvsp[0].lng)), sizeof(long) ); TEST((ffval.Node)); } --#line 2157 "y.tab.c" /* yacc.c:1648 */ -+ case 31: /* expr: LONG */ -+#line 395 "eval.y" -+ { (ffval.Node) = New_Const( LONG, &((ffvsp[0].lng)), sizeof(long) ); TEST((ffval.Node)); } -+#line 2148 "y.tab.c" - break; - -- case 32: --#line 389 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Const( DOUBLE, &((ffvsp[0].dbl)), sizeof(double) ); TEST((ffval.Node)); } --#line 2163 "y.tab.c" /* yacc.c:1648 */ -+ case 32: /* expr: DOUBLE */ -+#line 397 "eval.y" -+ { (ffval.Node) = New_Const( DOUBLE, &((ffvsp[0].dbl)), sizeof(double) ); TEST((ffval.Node)); } -+#line 2154 "y.tab.c" - break; - -- case 33: --#line 391 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Column( (ffvsp[0].lng) ); TEST((ffval.Node)); } --#line 2169 "y.tab.c" /* yacc.c:1648 */ -+ case 33: /* expr: COLUMN */ -+#line 399 "eval.y" -+ { (ffval.Node) = New_Column( (ffvsp[0].lng) ); TEST((ffval.Node)); } -+#line 2160 "y.tab.c" - break; - -- case 34: --#line 393 "eval.y" /* yacc.c:1648 */ -- { -+ case 34: /* expr: COLUMN '{' expr '}' */ -+#line 401 "eval.y" -+ { - if( TYPE((ffvsp[-1].Node)) != LONG - || OPER((ffvsp[-1].Node)) != CONST_OP ) { - fferror("Offset argument must be a constant integer"); -@@ -2178,59 +2169,59 @@ ffparse (void) - } - (ffval.Node) = New_Offset( (ffvsp[-3].lng), (ffvsp[-1].Node) ); TEST((ffval.Node)); - } --#line 2182 "y.tab.c" /* yacc.c:1648 */ -+#line 2173 "y.tab.c" - break; - -- case 35: --#line 402 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Func( LONG, row_fct, 0, 0, 0, 0, 0, 0, 0, 0 ); } --#line 2188 "y.tab.c" /* yacc.c:1648 */ -+ case 35: /* expr: ROWREF */ -+#line 410 "eval.y" -+ { (ffval.Node) = New_Func( LONG, row_fct, 0, 0, 0, 0, 0, 0, 0, 0 ); } -+#line 2179 "y.tab.c" - break; - -- case 36: --#line 404 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Func( LONG, null_fct, 0, 0, 0, 0, 0, 0, 0, 0 ); } --#line 2194 "y.tab.c" /* yacc.c:1648 */ -+ case 36: /* expr: NULLREF */ -+#line 412 "eval.y" -+ { (ffval.Node) = New_Func( LONG, null_fct, 0, 0, 0, 0, 0, 0, 0, 0 ); } -+#line 2185 "y.tab.c" - break; - -- case 37: --#line 406 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '%', (ffvsp[0].Node) ); -+ case 37: /* expr: expr '%' expr */ -+#line 414 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '%', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2201 "y.tab.c" /* yacc.c:1648 */ -+#line 2192 "y.tab.c" - break; - -- case 38: --#line 409 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '+', (ffvsp[0].Node) ); -+ case 38: /* expr: expr '+' expr */ -+#line 417 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '+', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2208 "y.tab.c" /* yacc.c:1648 */ -+#line 2199 "y.tab.c" - break; - -- case 39: --#line 412 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '-', (ffvsp[0].Node) ); -+ case 39: /* expr: expr '-' expr */ -+#line 420 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '-', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2215 "y.tab.c" /* yacc.c:1648 */ -+#line 2206 "y.tab.c" - break; - -- case 40: --#line 415 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '*', (ffvsp[0].Node) ); -+ case 40: /* expr: expr '*' expr */ -+#line 423 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '*', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2222 "y.tab.c" /* yacc.c:1648 */ -+#line 2213 "y.tab.c" - break; - -- case 41: --#line 418 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '/', (ffvsp[0].Node) ); -+ case 41: /* expr: expr '/' expr */ -+#line 426 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '/', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2229 "y.tab.c" /* yacc.c:1648 */ -+#line 2220 "y.tab.c" - break; - -- case 42: --#line 421 "eval.y" /* yacc.c:1648 */ -- { -+ case 42: /* expr: expr '&' expr */ -+#line 429 "eval.y" -+ { - if (TYPE((ffvsp[-2].Node)) != LONG || - TYPE((ffvsp[0].Node)) != LONG) { - fferror("Bitwise operations with incompatible types; only (bit OP bit) and (int OP int) are allowed"); -@@ -2238,12 +2229,12 @@ ffparse (void) - } - (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '&', (ffvsp[0].Node) ); - } --#line 2242 "y.tab.c" /* yacc.c:1648 */ -+#line 2233 "y.tab.c" - break; - -- case 43: --#line 430 "eval.y" /* yacc.c:1648 */ -- { -+ case 43: /* expr: expr '|' expr */ -+#line 438 "eval.y" -+ { - if (TYPE((ffvsp[-2].Node)) != LONG || - TYPE((ffvsp[0].Node)) != LONG) { - fferror("Bitwise operations with incompatible types; only (bit OP bit) and (int OP int) are allowed"); -@@ -2251,12 +2242,12 @@ ffparse (void) - } - (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '|', (ffvsp[0].Node) ); - } --#line 2255 "y.tab.c" /* yacc.c:1648 */ -+#line 2246 "y.tab.c" - break; - -- case 44: --#line 439 "eval.y" /* yacc.c:1648 */ -- { -+ case 44: /* expr: expr XOR expr */ -+#line 447 "eval.y" -+ { - if (TYPE((ffvsp[-2].Node)) != LONG || - TYPE((ffvsp[0].Node)) != LONG) { - fferror("Bitwise operations with incompatible types; only (bit OP bit) and (int OP int) are allowed"); -@@ -2264,53 +2255,53 @@ ffparse (void) - } - (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '^', (ffvsp[0].Node) ); - } --#line 2268 "y.tab.c" /* yacc.c:1648 */ -+#line 2259 "y.tab.c" - break; - -- case 45: --#line 448 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), POWER, (ffvsp[0].Node) ); -+ case 45: /* expr: expr POWER expr */ -+#line 456 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), POWER, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2275 "y.tab.c" /* yacc.c:1648 */ -+#line 2266 "y.tab.c" - break; - -- case 46: --#line 451 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = (ffvsp[0].Node); } --#line 2281 "y.tab.c" /* yacc.c:1648 */ -+ case 46: /* expr: '+' expr */ -+#line 459 "eval.y" -+ { (ffval.Node) = (ffvsp[0].Node); } -+#line 2272 "y.tab.c" - break; - -- case 47: --#line 453 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Unary( TYPE((ffvsp[0].Node)), UMINUS, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2287 "y.tab.c" /* yacc.c:1648 */ -+ case 47: /* expr: '-' expr */ -+#line 461 "eval.y" -+ { (ffval.Node) = New_Unary( TYPE((ffvsp[0].Node)), UMINUS, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2278 "y.tab.c" - break; - -- case 48: --#line 455 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = (ffvsp[-1].Node); } --#line 2293 "y.tab.c" /* yacc.c:1648 */ -+ case 48: /* expr: '(' expr ')' */ -+#line 463 "eval.y" -+ { (ffval.Node) = (ffvsp[-1].Node); } -+#line 2284 "y.tab.c" - break; - -- case 49: --#line 457 "eval.y" /* yacc.c:1648 */ -- { (ffvsp[0].Node) = New_Unary( TYPE((ffvsp[-2].Node)), 0, (ffvsp[0].Node) ); -+ case 49: /* expr: expr '*' bexpr */ -+#line 465 "eval.y" -+ { (ffvsp[0].Node) = New_Unary( TYPE((ffvsp[-2].Node)), 0, (ffvsp[0].Node) ); - (ffval.Node) = New_BinOp( TYPE((ffvsp[-2].Node)), (ffvsp[-2].Node), '*', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2301 "y.tab.c" /* yacc.c:1648 */ -+#line 2292 "y.tab.c" - break; - -- case 50: --#line 461 "eval.y" /* yacc.c:1648 */ -- { (ffvsp[-2].Node) = New_Unary( TYPE((ffvsp[0].Node)), 0, (ffvsp[-2].Node) ); -+ case 50: /* expr: bexpr '*' expr */ -+#line 469 "eval.y" -+ { (ffvsp[-2].Node) = New_Unary( TYPE((ffvsp[0].Node)), 0, (ffvsp[-2].Node) ); - (ffval.Node) = New_BinOp( TYPE((ffvsp[0].Node)), (ffvsp[-2].Node), '*', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2309 "y.tab.c" /* yacc.c:1648 */ -+#line 2300 "y.tab.c" - break; - -- case 51: --#line 465 "eval.y" /* yacc.c:1648 */ -- { -+ case 51: /* expr: bexpr '?' expr ':' expr */ -+#line 473 "eval.y" -+ { - PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); - if( ! Test_Dims((ffvsp[-2].Node),(ffvsp[0].Node)) ) { - fferror("Incompatible dimensions in '?:' arguments"); -@@ -2328,12 +2319,12 @@ ffparse (void) - TYPE((ffvsp[-4].Node)) = BOOLEAN; - if( SIZE((ffval.Node))=SIZE((ffvsp[-1].Node)) && Test_Dims( (ffvsp[-3].Node), (ffvsp[-1].Node) ) ) { - PROMOTE((ffvsp[-3].Node),(ffvsp[-1].Node)); -@@ -2620,27 +2611,26 @@ ffparse (void) - "are not compatible"); - FFERROR; - } --#if 0 -- } else if (FSTRCMP((ffvsp[-4].str),"STRSTR(") == 0) { -- if( TYPE((ffvsp[-3].Node)) != STRING || TYPE((ffvsp[-1].Node)) != STRING) { -- fferror("Arguments to strstr(s,r) must be strings"); -+ } else if (FSTRCMP((ffvsp[-4].str),"SETNULL(") == 0) { -+ if (OPER((ffvsp[-3].Node)) != CONST_OP -+ || SIZE((ffvsp[-3].Node)) != 1) { -+ fferror("SETNULL first argument must be a scalar constant"); - FFERROR; - } -- (ffval.Node) = New_Func( LONG, strpos_fct, 2, (ffvsp[-3].Node), (ffvsp[-1].Node), 0, -- 0, 0, 0, 0 ); -- TEST((ffval.Node)); --#endif -+ /* Make sure first arg is same type as second arg */ -+ if ( TYPE((ffvsp[-3].Node)) != TYPE((ffvsp[-1].Node)) ) (ffvsp[-3].Node) = New_Unary( TYPE((ffvsp[-1].Node)), 0, (ffvsp[-3].Node) ); -+ (ffval.Node) = New_Func( 0, setnull_fct, 2, (ffvsp[-1].Node), (ffvsp[-3].Node), 0, 0, 0, 0, 0 ); - } else { - fferror("Function(expr,expr) not supported"); - FFERROR; - } - } --#line 2639 "y.tab.c" /* yacc.c:1648 */ -+#line 2629 "y.tab.c" - break; - -- case 61: --#line 755 "eval.y" /* yacc.c:1648 */ -- { -+ case 61: /* expr: FUNCTION expr ',' expr ',' expr ',' expr ')' */ -+#line 762 "eval.y" -+ { - if (FSTRCMP((ffvsp[-8].str),"ANGSEP(") == 0) { - if( TYPE((ffvsp[-7].Node)) != DOUBLE ) (ffvsp[-7].Node) = New_Unary( DOUBLE, 0, (ffvsp[-7].Node) ); - if( TYPE((ffvsp[-5].Node)) != DOUBLE ) (ffvsp[-5].Node) = New_Unary( DOUBLE, 0, (ffvsp[-5].Node) ); -@@ -2663,78 +2653,78 @@ ffparse (void) - FFERROR; - } - } --#line 2667 "y.tab.c" /* yacc.c:1648 */ -+#line 2657 "y.tab.c" - break; - -- case 62: --#line 779 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-3].Node), 1, (ffvsp[-1].Node), 0, 0, 0, 0 ); TEST((ffval.Node)); } --#line 2673 "y.tab.c" /* yacc.c:1648 */ -+ case 62: /* expr: expr '[' expr ']' */ -+#line 786 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-3].Node), 1, (ffvsp[-1].Node), 0, 0, 0, 0 ); TEST((ffval.Node)); } -+#line 2663 "y.tab.c" - break; - -- case 63: --#line 781 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-5].Node), 2, (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0, 0 ); TEST((ffval.Node)); } --#line 2679 "y.tab.c" /* yacc.c:1648 */ -+ case 63: /* expr: expr '[' expr ',' expr ']' */ -+#line 788 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-5].Node), 2, (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0, 0 ); TEST((ffval.Node)); } -+#line 2669 "y.tab.c" - break; - -- case 64: --#line 783 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-7].Node), 3, (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0 ); TEST((ffval.Node)); } --#line 2685 "y.tab.c" /* yacc.c:1648 */ -+ case 64: /* expr: expr '[' expr ',' expr ',' expr ']' */ -+#line 790 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-7].Node), 3, (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0, 0 ); TEST((ffval.Node)); } -+#line 2675 "y.tab.c" - break; - -- case 65: --#line 785 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-9].Node), 4, (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0 ); TEST((ffval.Node)); } --#line 2691 "y.tab.c" /* yacc.c:1648 */ -+ case 65: /* expr: expr '[' expr ',' expr ',' expr ',' expr ']' */ -+#line 792 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-9].Node), 4, (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node), 0 ); TEST((ffval.Node)); } -+#line 2681 "y.tab.c" - break; - -- case 66: --#line 787 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Deref( (ffvsp[-11].Node), 5, (ffvsp[-9].Node), (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node) ); TEST((ffval.Node)); } --#line 2697 "y.tab.c" /* yacc.c:1648 */ -+ case 66: /* expr: expr '[' expr ',' expr ',' expr ',' expr ',' expr ']' */ -+#line 794 "eval.y" -+ { (ffval.Node) = New_Deref( (ffvsp[-11].Node), 5, (ffvsp[-9].Node), (ffvsp[-7].Node), (ffvsp[-5].Node), (ffvsp[-3].Node), (ffvsp[-1].Node) ); TEST((ffval.Node)); } -+#line 2687 "y.tab.c" - break; - -- case 67: --#line 789 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Unary( LONG, INTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2703 "y.tab.c" /* yacc.c:1648 */ -+ case 67: /* expr: INTCAST expr */ -+#line 796 "eval.y" -+ { (ffval.Node) = New_Unary( LONG, INTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2693 "y.tab.c" - break; - -- case 68: --#line 791 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Unary( LONG, INTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2709 "y.tab.c" /* yacc.c:1648 */ -+ case 68: /* expr: INTCAST bexpr */ -+#line 798 "eval.y" -+ { (ffval.Node) = New_Unary( LONG, INTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2699 "y.tab.c" - break; - -- case 69: --#line 793 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Unary( DOUBLE, FLTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2715 "y.tab.c" /* yacc.c:1648 */ -+ case 69: /* expr: FLTCAST expr */ -+#line 800 "eval.y" -+ { (ffval.Node) = New_Unary( DOUBLE, FLTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2705 "y.tab.c" - break; - -- case 70: --#line 795 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Unary( DOUBLE, FLTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2721 "y.tab.c" /* yacc.c:1648 */ -+ case 70: /* expr: FLTCAST bexpr */ -+#line 802 "eval.y" -+ { (ffval.Node) = New_Unary( DOUBLE, FLTCAST, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2711 "y.tab.c" - break; - -- case 71: --#line 799 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Const( BOOLEAN, &((ffvsp[0].log)), sizeof(char) ); TEST((ffval.Node)); } --#line 2727 "y.tab.c" /* yacc.c:1648 */ -+ case 71: /* bexpr: BOOLEAN */ -+#line 806 "eval.y" -+ { (ffval.Node) = New_Const( BOOLEAN, &((ffvsp[0].log)), sizeof(char) ); TEST((ffval.Node)); } -+#line 2717 "y.tab.c" - break; - -- case 72: --#line 801 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_Column( (ffvsp[0].lng) ); TEST((ffval.Node)); } --#line 2733 "y.tab.c" /* yacc.c:1648 */ -+ case 72: /* bexpr: BCOLUMN */ -+#line 808 "eval.y" -+ { (ffval.Node) = New_Column( (ffvsp[0].lng) ); TEST((ffval.Node)); } -+#line 2723 "y.tab.c" - break; - -- case 73: --#line 803 "eval.y" /* yacc.c:1648 */ -- { -+ case 73: /* bexpr: BCOLUMN '{' expr '}' */ -+#line 810 "eval.y" -+ { - if( TYPE((ffvsp[-1].Node)) != LONG - || OPER((ffvsp[-1].Node)) != CONST_OP ) { - fferror("Offset argument must be a constant integer"); -@@ -2742,179 +2732,179 @@ ffparse (void) - } - (ffval.Node) = New_Offset( (ffvsp[-3].lng), (ffvsp[-1].Node) ); TEST((ffval.Node)); - } --#line 2746 "y.tab.c" /* yacc.c:1648 */ -+#line 2736 "y.tab.c" - break; - -- case 74: --#line 812 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 74: /* bexpr: bits EQ bits */ -+#line 819 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2753 "y.tab.c" /* yacc.c:1648 */ -+#line 2743 "y.tab.c" - break; - -- case 75: --#line 815 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 75: /* bexpr: bits NE bits */ -+#line 822 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2760 "y.tab.c" /* yacc.c:1648 */ -+#line 2750 "y.tab.c" - break; - -- case 76: --#line 818 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LT, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 76: /* bexpr: bits LT bits */ -+#line 825 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LT, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2767 "y.tab.c" /* yacc.c:1648 */ -+#line 2757 "y.tab.c" - break; - -- case 77: --#line 821 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 77: /* bexpr: bits LTE bits */ -+#line 828 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2774 "y.tab.c" /* yacc.c:1648 */ -+#line 2764 "y.tab.c" - break; - -- case 78: --#line 824 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GT, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 78: /* bexpr: bits GT bits */ -+#line 831 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GT, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2781 "y.tab.c" /* yacc.c:1648 */ -+#line 2771 "y.tab.c" - break; - -- case 79: --#line 827 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GTE, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 79: /* bexpr: bits GTE bits */ -+#line 834 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GTE, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2788 "y.tab.c" /* yacc.c:1648 */ -+#line 2778 "y.tab.c" - break; - -- case 80: --#line 830 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GT, (ffvsp[0].Node) ); -+ case 80: /* bexpr: expr GT expr */ -+#line 837 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GT, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2795 "y.tab.c" /* yacc.c:1648 */ -+#line 2785 "y.tab.c" - break; - -- case 81: --#line 833 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LT, (ffvsp[0].Node) ); -+ case 81: /* bexpr: expr LT expr */ -+#line 840 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LT, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2802 "y.tab.c" /* yacc.c:1648 */ -+#line 2792 "y.tab.c" - break; - -- case 82: --#line 836 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GTE, (ffvsp[0].Node) ); -+ case 82: /* bexpr: expr GTE expr */ -+#line 843 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GTE, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2809 "y.tab.c" /* yacc.c:1648 */ -+#line 2799 "y.tab.c" - break; - -- case 83: --#line 839 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[0].Node) ); -+ case 83: /* bexpr: expr LTE expr */ -+#line 846 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2816 "y.tab.c" /* yacc.c:1648 */ -+#line 2806 "y.tab.c" - break; - -- case 84: --#line 842 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), '~', (ffvsp[0].Node) ); -+ case 84: /* bexpr: expr '~' expr */ -+#line 849 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), '~', (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2823 "y.tab.c" /* yacc.c:1648 */ -+#line 2813 "y.tab.c" - break; - -- case 85: --#line 845 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); -+ case 85: /* bexpr: expr EQ expr */ -+#line 852 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2830 "y.tab.c" /* yacc.c:1648 */ -+#line 2820 "y.tab.c" - break; - -- case 86: --#line 848 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); -+ case 86: /* bexpr: expr NE expr */ -+#line 855 "eval.y" -+ { PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2837 "y.tab.c" /* yacc.c:1648 */ -+#line 2827 "y.tab.c" - break; - -- case 87: --#line 851 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 87: /* bexpr: sexpr EQ sexpr */ -+#line 858 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2844 "y.tab.c" /* yacc.c:1648 */ -+#line 2834 "y.tab.c" - break; - -- case 88: --#line 854 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 88: /* bexpr: sexpr NE sexpr */ -+#line 861 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2851 "y.tab.c" /* yacc.c:1648 */ -+#line 2841 "y.tab.c" - break; - -- case 89: --#line 857 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GT, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 89: /* bexpr: sexpr GT sexpr */ -+#line 864 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GT, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2858 "y.tab.c" /* yacc.c:1648 */ -+#line 2848 "y.tab.c" - break; - -- case 90: --#line 860 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GTE, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 90: /* bexpr: sexpr GTE sexpr */ -+#line 867 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), GTE, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2865 "y.tab.c" /* yacc.c:1648 */ -+#line 2855 "y.tab.c" - break; - -- case 91: --#line 863 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LT, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 91: /* bexpr: sexpr LT sexpr */ -+#line 870 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LT, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2872 "y.tab.c" /* yacc.c:1648 */ -+#line 2862 "y.tab.c" - break; - -- case 92: --#line 866 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[0].Node) ); TEST((ffval.Node)); -+ case 92: /* bexpr: sexpr LTE sexpr */ -+#line 873 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = 1; } --#line 2879 "y.tab.c" /* yacc.c:1648 */ -+#line 2869 "y.tab.c" - break; - -- case 93: --#line 869 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), AND, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2885 "y.tab.c" /* yacc.c:1648 */ -+ case 93: /* bexpr: bexpr AND bexpr */ -+#line 876 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), AND, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2875 "y.tab.c" - break; - -- case 94: --#line 871 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), OR, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2891 "y.tab.c" /* yacc.c:1648 */ -+ case 94: /* bexpr: bexpr OR bexpr */ -+#line 878 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), OR, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2881 "y.tab.c" - break; - -- case 95: --#line 873 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2897 "y.tab.c" /* yacc.c:1648 */ -+ case 95: /* bexpr: bexpr EQ bexpr */ -+#line 880 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), EQ, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2887 "y.tab.c" - break; - -- case 96: --#line 875 "eval.y" /* yacc.c:1648 */ -- { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); TEST((ffval.Node)); } --#line 2903 "y.tab.c" /* yacc.c:1648 */ -+ case 96: /* bexpr: bexpr NE bexpr */ -+#line 882 "eval.y" -+ { (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), NE, (ffvsp[0].Node) ); TEST((ffval.Node)); } -+#line 2893 "y.tab.c" - break; - -- case 97: --#line 878 "eval.y" /* yacc.c:1648 */ -- { PROMOTE((ffvsp[-4].Node),(ffvsp[-2].Node)); PROMOTE((ffvsp[-4].Node),(ffvsp[0].Node)); PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); -+ case 97: /* bexpr: expr '=' expr ':' expr */ -+#line 885 "eval.y" -+ { PROMOTE((ffvsp[-4].Node),(ffvsp[-2].Node)); PROMOTE((ffvsp[-4].Node),(ffvsp[0].Node)); PROMOTE((ffvsp[-2].Node),(ffvsp[0].Node)); - (ffvsp[-2].Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), LTE, (ffvsp[-4].Node) ); - (ffvsp[0].Node) = New_BinOp( BOOLEAN, (ffvsp[-4].Node), LTE, (ffvsp[0].Node) ); - (ffval.Node) = New_BinOp( BOOLEAN, (ffvsp[-2].Node), AND, (ffvsp[0].Node) ); - TEST((ffval.Node)); } --#line 2913 "y.tab.c" /* yacc.c:1648 */ -+#line 2903 "y.tab.c" - break; - -- case 98: --#line 885 "eval.y" /* yacc.c:1648 */ -- { -+ case 98: /* bexpr: bexpr '?' bexpr ':' bexpr */ -+#line 892 "eval.y" -+ { - if( ! Test_Dims((ffvsp[-2].Node),(ffvsp[0].Node)) ) { - fferror("Incompatible dimensions in '?:' arguments"); - FFERROR; -@@ -2929,12 +2919,12 @@ ffparse (void) - } - if( SIZE((ffval.Node))=SIZE((ffvsp[-1].Node)) && Test_Dims( (ffvsp[-3].Node), (ffvsp[-1].Node) ) ) { - (ffval.Node) = New_Func( 0, defnull_fct, 2, (ffvsp[-3].Node), (ffvsp[-1].Node), 0, -@@ -2998,12 +2988,12 @@ ffparse (void) - FFERROR; - } - } --#line 3002 "y.tab.c" /* yacc.c:1648 */ -+#line 2992 "y.tab.c" - break; - -- case 103: --#line 955 "eval.y" /* yacc.c:1648 */ -- { -+ case 103: /* bexpr: BFUNCTION expr ',' expr ',' expr ')' */ -+#line 962 "eval.y" -+ { - if( TYPE((ffvsp[-5].Node)) != DOUBLE ) (ffvsp[-5].Node) = New_Unary( DOUBLE, 0, (ffvsp[-5].Node) ); - if( TYPE((ffvsp[-3].Node)) != DOUBLE ) (ffvsp[-3].Node) = New_Unary( DOUBLE, 0, (ffvsp[-3].Node) ); - if( TYPE((ffvsp[-1].Node)) != DOUBLE ) (ffvsp[-1].Node) = New_Unary( DOUBLE, 0, (ffvsp[-1].Node) ); -@@ -3026,12 +3016,12 @@ ffparse (void) - if( SIZE((ffvsp[-3].Node))= MAX_STRLEN) { - fferror("Combined string size exceeds " MAX_STRLEN_S " characters"); - FFERROR; -@@ -3243,12 +3247,12 @@ ffparse (void) - (ffval.Node) = New_BinOp( STRING, (ffvsp[-2].Node), '+', (ffvsp[0].Node) ); TEST((ffval.Node)); - SIZE((ffval.Node)) = SIZE((ffvsp[-2].Node)) + SIZE((ffvsp[0].Node)); - } --#line 3247 "y.tab.c" /* yacc.c:1648 */ -+#line 3251 "y.tab.c" - break; - -- case 126: --#line 1113 "eval.y" /* yacc.c:1648 */ -- { -+ case 128: /* sexpr: bexpr '?' sexpr ':' sexpr */ -+#line 1129 "eval.y" -+ { - int outSize; - if( SIZE((ffvsp[-4].Node))!=1 ) { - fferror("Cannot have a vector string column"); -@@ -3265,12 +3269,12 @@ ffparse (void) - TEST((ffval.Node)); - if( SIZE((ffvsp[-2].Node)) $$ =", ffr1[ffn], &ffval, &ffloc); -+ FF_SYMBOL_PRINT ("-> $$ =", FF_CAST (ffsymbol_kind_t, ffr1[ffn]), &ffval, &ffloc); - - FFPOPSTACK (fflen); - fflen = 0; -- FF_STACK_PRINT (ffss, ffssp); - - *++ffvsp = ffval; - - /* Now 'shift' the result of the reduction. Determine what state - that goes to, based on the state we popped back to and the rule - number reduced by. */ -- -- ffn = ffr1[ffn]; -- -- ffstate = ffpgoto[ffn - FFNTOKENS] + *ffssp; -- if (0 <= ffstate && ffstate <= FFLAST && ffcheck[ffstate] == *ffssp) -- ffstate = fftable[ffstate]; -- else -- ffstate = ffdefgoto[ffn - FFNTOKENS]; -+ { -+ const int fflhs = ffr1[ffn] - FFNTOKENS; -+ const int ffi = ffpgoto[fflhs] + *ffssp; -+ ffstate = (0 <= ffi && ffi <= FFLAST && ffcheck[ffi] == *ffssp -+ ? fftable[ffi] -+ : ffdefgoto[fflhs]); -+ } - - goto ffnewstate; - -@@ -3366,50 +3369,14 @@ ffparse (void) - fferrlab: - /* Make sure we have latest lookahead translation. See comments at - user semantic actions for why this is necessary. */ -- fftoken = ffchar == FFEMPTY ? FFEMPTY : FFTRANSLATE (ffchar); -- -+ fftoken = ffchar == FFEMPTY ? FFSYMBOL_FFEMPTY : FFTRANSLATE (ffchar); - /* If not already recovering from an error, report this error. */ - if (!fferrstatus) - { - ++ffnerrs; --#if ! FFERROR_VERBOSE - fferror (FF_("syntax error")); --#else --# define FFSYNTAX_ERROR ffsyntax_error (&ffmsg_alloc, &ffmsg, \ -- ffssp, fftoken) -- { -- char const *ffmsgp = FF_("syntax error"); -- int ffsyntax_error_status; -- ffsyntax_error_status = FFSYNTAX_ERROR; -- if (ffsyntax_error_status == 0) -- ffmsgp = ffmsg; -- else if (ffsyntax_error_status == 1) -- { -- if (ffmsg != ffmsgbuf) -- FFSTACK_FREE (ffmsg); -- ffmsg = (char *) FFSTACK_ALLOC (ffmsg_alloc); -- if (!ffmsg) -- { -- ffmsg = ffmsgbuf; -- ffmsg_alloc = sizeof ffmsgbuf; -- ffsyntax_error_status = 2; -- } -- else -- { -- ffsyntax_error_status = FFSYNTAX_ERROR; -- ffmsgp = ffmsg; -- } -- } -- fferror (ffmsgp); -- if (ffsyntax_error_status == 2) -- goto ffexhaustedlab; -- } --# undef FFSYNTAX_ERROR --#endif - } - -- -- - if (fferrstatus == 3) - { - /* If just tried and failed to reuse lookahead token after an -@@ -3438,12 +3405,10 @@ ffparse (void) - | fferrorlab -- error raised explicitly by FFERROR. | - `---------------------------------------------------*/ - fferrorlab: -- -- /* Pacify compilers like GCC when the user code never invokes -- FFERROR and the label fferrorlab therefore never appears in user -- code. */ -- if (/*CONSTCOND*/ 0) -- goto fferrorlab; -+ /* Pacify compilers when the user code never invokes FFERROR and the -+ label fferrorlab therefore never appears in user code. */ -+ if (0) -+ FFERROR; - - /* Do not reclaim the symbols of the rule whose action triggered - this FFERROR. */ -@@ -3460,13 +3425,14 @@ ffparse (void) - fferrlab1: - fferrstatus = 3; /* Each real token shifted decrements this. */ - -+ /* Pop stack until we find a state that shifts the error token. */ - for (;;) - { - ffn = ffpact[ffstate]; - if (!ffpact_value_is_default (ffn)) - { -- ffn += FFTERROR; -- if (0 <= ffn && ffn <= FFLAST && ffcheck[ffn] == FFTERROR) -+ ffn += FFSYMBOL_FFerror; -+ if (0 <= ffn && ffn <= FFLAST && ffcheck[ffn] == FFSYMBOL_FFerror) - { - ffn = fftable[ffn]; - if (0 < ffn) -@@ -3480,7 +3446,7 @@ ffparse (void) - - - ffdestruct ("Error: popping", -- ffstos[ffstate], ffvsp); -+ FF_ACCESSING_SYMBOL (ffstate), ffvsp); - FFPOPSTACK (1); - ffstate = *ffssp; - FF_STACK_PRINT (ffss, ffssp); -@@ -3492,7 +3458,7 @@ ffparse (void) - - - /* Shift the error token. */ -- FF_SYMBOL_PRINT ("Shifting", ffstos[ffn], ffvsp, fflsp); -+ FF_SYMBOL_PRINT ("Shifting", FF_ACCESSING_SYMBOL (ffn), ffvsp, fflsp); - - ffstate = ffn; - goto ffnewstate; -@@ -3505,6 +3471,7 @@ ffparse (void) - ffresult = 0; - goto ffreturn; - -+ - /*-----------------------------------. - | ffabortlab -- FFABORT comes here. | - `-----------------------------------*/ -@@ -3512,16 +3479,21 @@ ffparse (void) - ffresult = 1; - goto ffreturn; - --#if !defined ffoverflow || FFERROR_VERBOSE -+ -+#if !defined ffoverflow - /*-------------------------------------------------. - | ffexhaustedlab -- memory exhaustion comes here. | - `-------------------------------------------------*/ - ffexhaustedlab: - fferror (FF_("memory exhausted")); - ffresult = 2; -- /* Fall through. */ -+ goto ffreturn; - #endif - -+ -+/*-------------------------------------------------------. -+| ffreturn -- parsing is finished, clean up and return. | -+`-------------------------------------------------------*/ - ffreturn: - if (ffchar != FFEMPTY) - { -@@ -3538,20 +3510,18 @@ ffparse (void) - while (ffssp != ffss) - { - ffdestruct ("Cleanup: popping", -- ffstos[*ffssp], ffvsp); -+ FF_ACCESSING_SYMBOL (+*ffssp), ffvsp); - FFPOPSTACK (1); - } - #ifndef ffoverflow - if (ffss != ffssa) - FFSTACK_FREE (ffss); - #endif --#if FFERROR_VERBOSE -- if (ffmsg != ffmsgbuf) -- FFSTACK_FREE (ffmsg); --#endif -+ - return ffresult; - } --#line 1180 "eval.y" /* yacc.c:1907 */ -+ -+#line 1196 "eval.y" - - - /*************************************************************************/ -@@ -3871,10 +3841,10 @@ static int New_Deref( int Var, int nDim, - - extern int ffGetVariable( char *varName, FFSTYPE *varVal ); - --static int New_GTI( char *fname, int Node1, char *start, char *stop ) -+static int New_GTI( funcOp Op, char *fname, int Node1, int Node2, char *start, char *stop ) - { - fitsfile *fptr; -- Node *this, *that0, *that1; -+ Node *this, *that0, *that1, *that2; - int type,i,n, startCol, stopCol, Node0; - int hdutype, hdunum, evthdu, samefile, extvers, movetotype, tstat; - char extname[100]; -@@ -3883,7 +3853,7 @@ static int New_GTI( char *fname, int Node1, char *start, char *stop ) - char xcol[20], xexpr[20]; - FFSTYPE colVal; - -- if( Node1==-99 ) { -+ if( Op == gtifilt_fct && Node1==-99 ) { - type = ffGetVariable( "TIME", &colVal ); - if( type==COLUMN ) { - Node1 = New_Column( (int)colVal.lng ); -@@ -3892,6 +3862,19 @@ static int New_GTI( char *fname, int Node1, char *start, char *stop ) - return(-1); - } - } -+ -+ if (Op == gtiover_fct) { -+ if (Node1 == -99 || Node2 == -99) { -+ fferror("startExpr and stopExpr values must be defined for GTIOVERLAP"); -+ return(-1); -+ } -+ /* Also case TIME_STOP to double precision */ -+ Node2 = New_Unary( DOUBLE, 0, Node2 ); -+ if (Node2 < 0) return(-1); -+ -+ } -+ -+ /* Type cast TIME to double precision */ - Node1 = New_Unary( DOUBLE, 0, Node1 ); - Node0 = Alloc_Node(); /* This will hold the START/STOP times */ - if( Node1<0 || Node0<0 ) return(-1); -@@ -4005,16 +3988,30 @@ static int New_GTI( char *fname, int Node1, char *start, char *stop ) - n = Alloc_Node(); - if( n >= 0 ) { - this = gParse.Nodes + n; -- this->nSubNodes = 2; - this->SubNodes[1] = Node1; -- this->operation = (int)gtifilt_fct; -- this->DoOp = Do_GTI; -- this->type = BOOLEAN; -+ this->operation = (int) Op; -+ if (Op == gtifilt_fct) { -+ this->nSubNodes = 2; -+ this->DoOp = Do_GTI; -+ this->type = BOOLEAN; -+ } else { -+ this->nSubNodes = 3; -+ this->DoOp = Do_GTI_Over; -+ this->type = DOUBLE; -+ } - that1 = gParse.Nodes + Node1; - this->value.nelem = that1->value.nelem; - this->value.naxis = that1->value.naxis; - for( i=0; i < that1->value.naxis; i++ ) - this->value.naxes[i] = that1->value.naxes[i]; -+ if (Op == gtiover_fct) { -+ this->SubNodes[2] = Node2; -+ that2 = gParse.Nodes + Node2; -+ if (that1->value.nelem != that2->value.nelem) { -+ fferror("Dimensions of TIME and TIME_STOP must match for GTIOVERLAP"); -+ return(-1); -+ } -+ } - - /* Init START/STOP node to be treated as a "constant" */ - -@@ -4058,6 +4055,12 @@ static int New_GTI( char *fname, int Node1, char *start, char *stop ) - that0->type = 0; - break; - } -+ -+ /* GTIOVERLAP() requires ordered GTI */ -+ if (that0->type != 1 && Op == gtiover_fct) { -+ fferror("Input GTI must be time-ordered for GTIOVERLAP"); -+ return(-1); -+ } - - /* Handle TIMEZERO offset, if any */ - -@@ -4070,8 +4073,11 @@ static int New_GTI( char *fname, int Node1, char *start, char *stop ) - that0->value.data.dblptr[i] += dt; - } - } -- if( OPER(Node1)==CONST_OP ) -- this->DoOp( this ); -+ /* If Node1 is constant (gtifilt_fct) or -+ Node1 and Node2 are constant (gtiover_fct), then evaluate now */ -+ if( OPER(Node1)==CONST_OP && (Op == gtifilt_fct || OPER(Node2)==CONST_OP)) { -+ this->DoOp( this ); -+ } - } - - if( samefile ) -@@ -5877,6 +5883,12 @@ static void Do_Func( Node *this ) - else if( this->type==STRING ) - strcpy(this->value.data.str,pVals[0].data.str); - break; -+ case setnull_fct: /* Only defined for numeric expressions */ -+ if( this->type==LONG ) -+ this->value.data.lng = pVals[0].data.lng; -+ else if( this->type==DOUBLE ) -+ this->value.data.dbl = pVals[0].data.dbl; -+ break; - - /* Math functions with 1 double argument */ - -@@ -6560,6 +6572,34 @@ static void Do_Func( Node *this ) - } - } - break; -+ case setnull_fct: -+ switch( this->type ) { -+ case LONG: -+ while( elem-- ) { -+ if ( theParams[1]->value.data.lng == -+ theParams[0]->value.data.lngptr[elem] ) { -+ this->value.data.lngptr[elem] = 0; -+ this->value.undef[elem] = 1; -+ } else { -+ this->value.data.lngptr[elem] = theParams[0]->value.data.lngptr[elem]; -+ this->value.undef[elem] = theParams[0]->value.undef[elem]; -+ } -+ } -+ break; -+ case DOUBLE: -+ while( elem-- ) { -+ if ( theParams[1]->value.data.dbl == -+ theParams[0]->value.data.dblptr[elem] ) { -+ this->value.data.dblptr[elem] = 0; -+ this->value.undef[elem] = 1; -+ } else { -+ this->value.data.dblptr[elem] = theParams[0]->value.data.dblptr[elem]; -+ this->value.undef[elem] = theParams[0]->value.undef[elem]; -+ } -+ } -+ break; -+ } -+ break; - - /* Math functions with 1 double argument */ - -@@ -7591,7 +7631,7 @@ static void Do_GTI( Node *this ) - if( theExpr->operation==CONST_OP ) { - - this->value.data.log = -- (Search_GTI( theExpr->value.data.dbl, nGTI, start, stop, ordered )>=0); -+ (Search_GTI( theExpr->value.data.dbl, nGTI, start, stop, ordered, 0 )>=0); - this->operation = CONST_OP; - - } else { -@@ -7610,7 +7650,7 @@ static void Do_GTI( Node *this ) - - /* Before searching entire GTI, check the GTI found last time */ - if( gti<0 || times[elem]stop[gti] ) { -- gti = Search_GTI( times[elem], nGTI, start, stop, ordered ); -+ gti = Search_GTI( times[elem], nGTI, start, stop, ordered, 0 ); - } - this->value.data.logptr[elem] = ( gti>=0 ); - } -@@ -7626,10 +7666,158 @@ static void Do_GTI( Node *this ) - free( theExpr->value.data.ptr ); - } - -+static void Do_GTI_Over( Node *this ) -+{ -+ Node *theTimes, *theStart, *theStop; -+ double *gtiStart, *gtiStop; -+ double *evtStart, *evtStop; -+ long elem, nGTI, gti, nextGTI; -+ int ordered; -+ -+ theTimes = gParse.Nodes + this->SubNodes[0]; /* GTI times */ -+ theStop = gParse.Nodes + this->SubNodes[2]; /* User start time */ -+ theStart = gParse.Nodes + this->SubNodes[1]; /* User stop time */ -+ -+ nGTI = theTimes->value.nelem; -+ gtiStart = theTimes->value.data.dblptr; /* GTI start */ -+ gtiStop = theTimes->value.data.dblptr + nGTI; /* GTI stop */ -+ -+ if( theStart->operation==CONST_OP && theStop->operation==CONST_OP) { -+ -+ this->value.data.dbl = -+ (GTI_Over( theStart->value.data.dbl, theStop->value.data.dbl, -+ nGTI, gtiStart, gtiStop, >i)); -+ this->operation = CONST_OP; -+ -+ } else { -+ char undefStart = 0, undefStop = 0; /* Input values are undef? */ -+ double uStart, uStop; /* User start/stop values */ -+ if (theStart->operation==CONST_OP) uStart = theStart->value.data.dbl; -+ if (theStop ->operation==CONST_OP) uStop = theStop ->value.data.dbl; -+ -+ Allocate_Ptrs( this ); -+ -+ evtStart = theStart->value.data.dblptr; -+ evtStop = theStop ->value.data.dblptr; -+ if( !gParse.status ) { -+ -+ elem = gParse.nRows * this->value.nelem; -+ if( nGTI ) { -+ double toverlap = 0.0; -+ gti = -1; -+ while( elem-- ) { -+ if (theStart->operation!=CONST_OP) { -+ undefStart = theStart->value.undef[elem]; -+ uStart = evtStart[elem]; -+ } -+ if (theStop->operation!=CONST_OP) { -+ undefStop = theStop ->value.undef[elem]; -+ uStop = evtStop[elem]; -+ } -+ /* This works because at least one of the values is not const */ -+ if( (this->value.undef[elem] = (undefStart||undefStop)) ) -+ continue; -+ -+ /* Before searching entire GTI, check the GTI found last time */ -+ if( gti<0 || -+ uStartgtiStop[gti] || -+ uStop gtiStop[gti]) { -+ /* Nope, need to recalculate */ -+ toverlap = GTI_Over(uStart, uStop, -+ nGTI, gtiStart, gtiStop, -+ >i); -+ } else { -+ /* We are in same GTI, the overlap is just stop-start of user range */ -+ toverlap = (uStop-uStart); -+ } -+ -+ /* This works because at least one of the values is not const */ -+ this->value.data.dblptr[elem] = toverlap; -+ } -+ } else -+ /* nGTI == 0; there is no overlap so set all values to 0.0 */ -+ while( elem-- ) { -+ this->value.data.dblptr[elem] = 0.0; -+ this->value.undef[elem] = 0; -+ } -+ } -+ } -+ -+ if( theStart->operation>0 ) { -+ free( theStart->value.data.ptr ); -+ } -+ if( theStop->operation>0 ) { -+ free( theStop->value.data.ptr ); -+ } -+} -+ -+static double GTI_Over(double evtStart, double evtStop, -+ long nGTI, double *start, double *stop, -+ long *gtiout) -+{ -+ long gti1, gti2, nextGTI1, nextGTI2; -+ long gti, nMax; -+ double overlap = 0.0; -+ -+ *gtiout = -1L; -+ /* Zero or negative bin size */ -+ if (evtStop <= evtStart) return 0.0; -+ -+ /* Locate adjacent GTIs for evtStart and evtStop */ -+ gti1 = Search_GTI(evtStart, nGTI, start, stop, 1, &nextGTI1); -+ gti2 = Search_GTI(evtStop, nGTI, start, stop, 1, &nextGTI2); -+ -+ /* evtStart is in gti1, we return that for future processing */ -+ if (gti1 >= 0) *gtiout = gti1; -+ -+ /* Both evtStart/evtStop are beyond the last GTI */ -+ if (nextGTI1 < 0 && nextGTI2 < 0) return 0.0; -+ -+ /* Both evtStart/evtStop are in the same gap between GTIs */ -+ if (gti1 < 0 && gti2 < 0 && nextGTI1 == nextGTI2) return 0.0; -+ -+ /* Both evtStart/evtStop are in the same GTI */ -+ if (gti1 >= 0 && gti1 == gti2) return (evtStop-evtStart); -+ -+ /* Count through the remaining GTIs; there will be at least one */ -+ /* The largest GTI to consider is either nextGTI2-1, if it exists, -+ or nGTI-1 */ -+ if (nextGTI2 < 0) nMax = nGTI-1; -+ else if (gti2 >= 0) nMax = nextGTI2; -+ else nMax = nextGTI2-1; -+ for (gti = nextGTI1; gti <= nMax; gti++) { -+ double starti = start[gti], stopi = stop[gti]; -+ /* Trim the GTI by actual evtStart/Stop times */ -+ if (evtStart > starti) starti = evtStart; -+ if (evtStop < stopi ) stopi = evtStop; -+ overlap += (stopi - starti); -+ } -+ -+ return overlap; -+} -+ -+/* -+ * Search_GTI - search GTI for requested evtTime -+ * -+ * double evtTime - requested event time -+ * long nGTI - number of entries in start[] and stop[] -+ * double start[], stop[] - start and stop of each GTI -+ * int ordered - set to 1 if time-ordered -+ * long *nextGTI0 - upon return, *nextGTI0 is either -+ * the GTI evtTime is inside -+ * the next GTI if evtTime is not inside -+ * -1L if there is no next GTI -+ * not set if nextGTI0 is a null pointer -+ * -+ * NOTE: for *nextGTI to be well-defined, the GTI must -+ * be ordered. This is true when called by Do_GTI. -+ * -+ * RETURNS: gti index that evtTime is located inside, or -1L -+ */ - static long Search_GTI( double evtTime, long nGTI, double *start, -- double *stop, int ordered ) -+ double *stop, int ordered, long *nextGTI0 ) - { -- long gti, step; -+ long gti, nextGTI = -1L, step; - - if( ordered && nGTI>15 ) { /* If time-ordered and lots of GTIs, */ - /* use "FAST" Binary search algorithm */ -@@ -7642,6 +7830,7 @@ static long Search_GTI( double evtTime, long nGTI, double *start, - if( evtTime>=start[gti+1] ) - gti += step; - else { -+ nextGTI = gti+1; - gti = -1L; - break; - } -@@ -7649,22 +7838,35 @@ static long Search_GTI( double evtTime, long nGTI, double *start, - if( evtTime<=stop[gti-1] ) - gti -= step; - else { -+ nextGTI = gti; - gti = -1L; - break; - } - } else { -+ nextGTI = gti; - break; - } - } -- } else -+ } else { -+ if (start[0] > evtTime) nextGTI = 0; - gti = -1L; -+ } - -- } else { /* Use "SLOW" linear search */ -+ } else { /* Use "SLOW" linear search. Not required to be -+ ordered, so we have to search the whole table -+ no matter what. -+ */ - gti = nGTI; -- while( gti-- ) -- if( evtTime>=start[gti] && evtTime<=stop[gti] ) -+ while( gti-- ) { -+ if( stop[gti] >= evtTime ) nextGTI = gti; -+ if( evtTime>=start[gti] && evtTime<=stop[gti] ) - break; -+ } - } -+ -+ if (nextGTI >= nGTI) nextGTI = -1; -+ if (nextGTI0) *nextGTI0 = nextGTI; -+ - return( gti ); - } - -diff --git a/cextern/cfitsio/lib/fitscore.c b/cextern/cfitsio/lib/fitscore.c -index f7a4fd52f69..56b155ca619 100644 ---- a/cextern/cfitsio/lib/fitscore.c -+++ b/cextern/cfitsio/lib/fitscore.c -@@ -73,11 +73,12 @@ float ffvers(float *version) /* IO - version number */ - return the current version number of the FITSIO software - */ - { -- *version = (float) 3.49; -+ *version = (float) 4.0; - --/* Aug 2020 -+/* May 2021 - - Previous releases: -+ *version = 3.49 Aug 2020 - *version = 3.48 Apr 2020 - *version = 3.47 May 2019 - *version = 3.46 Oct 2018 -@@ -5501,11 +5502,13 @@ int ffgcprll( fitsfile *fptr, /* I - FITS file pointer */ - /* the returned values of repeat and incre. */ - /* If = -1, then reading data in reverse */ - /* direction. */ -+ /* If writemode has 16 added, then treat */ -+ /* TSTRING column as TBYTE vector */ - double *scale, /* O - FITS scaling factor (TSCALn keyword value) */ - double *zero, /* O - FITS scaling zero pt (TZEROn keyword value) */ - char *tform, /* O - ASCII column format: value of TFORMn keyword */ - long *twidth, /* O - width of ASCII column (characters) */ -- int *tcode, /* O - column datatype code: I*4=41, R*4=42, etc */ -+ int *tcode, /* O - abs(column datatype code): I*4=41, R*4=42, etc */ - int *maxelem, /* O - max number of elements that fit in buffer */ - LONGLONG *startpos,/* O - offset in file to starting row & column */ - LONGLONG *elemnum, /* O - starting element number ( 0 = 1st element) */ -@@ -5538,7 +5541,7 @@ int ffgcprll( fitsfile *fptr, /* I - FITS file pointer */ - if ( ffrdef(fptr, status) > 0) - return(*status); - -- } else if (writemode > 0) { -+ } else if (writemode > 0 && writemode != 15) { - - /* Only terminate the header with the END card if */ - /* writing to the stdout stream (don't have random access). */ -@@ -5633,6 +5636,35 @@ int ffgcprll( fitsfile *fptr, /* I - FITS file pointer */ - snull[nulpos] = '\0'; - } - -+ /* Special case: use writemode = 15,16,17,18 to interpret TSTRING columns -+ as TBYTE vectors instead (but not for ASCII tables). -+ writemode = 15 equivalent to writemode =-1 -+ writemode = 16 equivalent to writemode = 0 -+ writemode = 17 equivalent to writemode = 1 -+ writemode = 18 equivalent to writemode = 2 -+ */ -+ if (writemode >= 15 && writemode <= 18) { -+ -+ if (abs(*tcode) == TSTRING && *hdutype != ASCII_TBL ) { -+ *incre = 1; /* each element is 1 byte wide */ -+ if (*tcode < 0) *repeat = *twidth; /* variable columns appear to put width in *twidth */ -+ *twidth = 1; /* width of each element */ -+ *scale = 1.0; /* no scaling */ -+ *zero = 0.0; -+ *tnull = NULL_UNDEFINED; /* don't test for nulls */ -+ *maxelem = DBUFFSIZE; -+ -+ if (*tcode < 0) { -+ *tcode = -TBYTE; /* variable-length */ -+ } else { -+ *tcode = TBYTE; -+ } -+ } -+ -+ /* translate to the equivalent as listed above */ -+ writemode -= 16; -+ } -+ - /* Special case: interpret writemode = -1 as reading data, but */ - /* don't do error check for exceeding the range of pixels */ - if (writemode == -1) -@@ -5650,7 +5682,10 @@ int ffgcprll( fitsfile *fptr, /* I - FITS file pointer */ - - /* Special case: support the 'rAw' format in BINTABLEs */ - if (*hdutype == BINARY_TBL && *tcode == TSTRING) { -- *repeat = *repeat / *twidth; /* repeat = # of unit strings in field */ -+ if (*twidth) -+ *repeat = *repeat / *twidth; /* repeat = # of unit strings in field */ -+ else -+ *repeat = 0; - } - else if (*hdutype == BINARY_TBL && *tcode == -TSTRING) { - /* variable length string */ -@@ -5684,7 +5719,11 @@ int ffgcprll( fitsfile *fptr, /* I - FITS file pointer */ - *maxelem = DBUFFSIZE / sizeof(double); - else if (abs(*tcode) == TSTRING) - { -- *maxelem = (DBUFFSIZE - 1)/ *twidth; /* leave room for final \0 */ -+ if (*twidth) -+ *maxelem = (DBUFFSIZE - 1)/ *twidth; /* leave room for final \0 */ -+ else -+ *maxelem = DBUFFSIZE - 1; -+ - if (*maxelem == 0) { - snprintf(message,FLEN_ERRMSG, - "ASCII string column is too wide: %ld; max supported width is %d", -diff --git a/cextern/cfitsio/lib/fitsio.h b/cextern/cfitsio/lib/fitsio.h -index 719b187d46a..efe02fd2db5 100644 ---- a/cextern/cfitsio/lib/fitsio.h -+++ b/cextern/cfitsio/lib/fitsio.h -@@ -34,9 +34,10 @@ SERVICES PROVIDED HEREUNDER." - #ifndef _FITSIO_H - #define _FITSIO_H - --#define CFITSIO_VERSION 3.49 --#define CFITSIO_MINOR 49 --#define CFITSIO_MAJOR 3 -+#define CFITSIO_VERSION 4.0.0 -+#define CFITSIO_MICRO 0 -+#define CFITSIO_MINOR 0 -+#define CFITSIO_MAJOR 4 - #define CFITSIO_SONAME 9 - - /* the SONAME is incremented in a new release if the binary shared */ -diff --git a/cextern/cfitsio/lib/getcolb.c b/cextern/cfitsio/lib/getcolb.c -index 9dd38e8639a..a9c56e9a443 100644 ---- a/cextern/cfitsio/lib/getcolb.c -+++ b/cextern/cfitsio/lib/getcolb.c -@@ -662,7 +662,7 @@ int ffgclb( fitsfile *fptr, /* I - FITS file pointer */ - int tcode, maxelem2, hdutype, xcode, decimals; - long twidth, incre, ntodo; - long ii, xwidth; -- int convert, nulcheck, readcheck = 0; -+ int convert, nulcheck, readcheck = 16; /* see note below on readcheck */ - LONGLONG repeat, startpos, elemnum, readptr, tnull; - LONGLONG rowlen, rownum, remain, next, rowincre, maxelem; - char tform[20]; -@@ -692,7 +692,17 @@ int ffgclb( fitsfile *fptr, /* I - FITS file pointer */ - /* Check input and get parameters about the column: */ - /*---------------------------------------------------*/ - if (elemincre < 0) -- readcheck = -1; /* don't do range checking in this case */ -+ readcheck -= 1; /* don't do range checking in this case */ -+ -+ /* IMPORTANT NOTE: that the special case of using this subroutine -+ to read bytes from a character column are handled internally -+ by the call to ffgcprll() below. It will adjust the effective -+ *tcode, repeats, etc, to appear as a TBYTE column. */ -+ -+ /* Note that readcheck = 16 is equivalent to readcheck = 0 -+ and readcheck = 15 is equivalent to readcheck = -1, -+ but either of those settings allow TSTRINGS to be -+ treated as TBYTE vectors, but with full error checking */ - - ffgcprll( fptr, colnum, firstrow, firstelem, nelem, readcheck, &scale, &zero, - tform, &twidth, &tcode, &maxelem2, &startpos, &elemnum, &incre, -@@ -709,30 +719,6 @@ int ffgclb( fitsfile *fptr, /* I - FITS file pointer */ - return(*status); - } - -- if (strchr(tform,'A') != NULL) -- { -- if (*status == BAD_ELEM_NUM) -- { -- /* ignore this error message */ -- *status = 0; -- ffcmsg(); /* clear error stack */ -- } -- -- /* interpret a 'A' ASCII column as a 'B' byte column ('8A' == '8B') */ -- /* This is an undocumented 'feature' in CFITSIO */ -- -- /* we have to reset some of the values returned by ffgcpr */ -- -- tcode = TBYTE; -- incre = 1; /* each element is 1 byte wide */ -- repeat = twidth; /* total no. of chars in the col */ -- twidth = 1; /* width of each element */ -- scale = 1.0; /* no scaling */ -- zero = 0.0; -- tnull = NULL_UNDEFINED; /* don't test for nulls */ -- maxelem = DBUFFSIZE; -- } -- - if (*status > 0) - return(*status); - -diff --git a/cextern/cfitsio/lib/getkey.c b/cextern/cfitsio/lib/getkey.c -index e867db29732..122bccc3f68 100644 ---- a/cextern/cfitsio/lib/getkey.c -+++ b/cextern/cfitsio/lib/getkey.c -@@ -286,6 +286,7 @@ int ffgky( fitsfile *fptr, /* I - FITS file pointer */ - */ - { - LONGLONG longval; -+ ULONGLONG ulongval; - double doubleval; - - if (*status > 0) /* inherit input status value if > 0 */ -@@ -361,12 +362,12 @@ int ffgky( fitsfile *fptr, /* I - FITS file pointer */ - } - else if (datatype == TULONG) - { -- if (ffgkyjj(fptr, keyname, &longval, comm, status) <= 0) -+ if (ffgkyujj(fptr, keyname, &ulongval, comm, status) <= 0) - { -- if (longval > ULONG_MAX || longval < 0) -+ if (ulongval > ULONG_MAX) - *status = NUM_OVERFLOW; - else -- *(unsigned long *) value = longval; -+ *(unsigned long *) value = ulongval; - } - } - else if (datatype == TLONG) -diff --git a/cextern/cfitsio/lib/putcol.c b/cextern/cfitsio/lib/putcol.c -index 526339737af..7808233421a 100644 ---- a/cextern/cfitsio/lib/putcol.c -+++ b/cextern/cfitsio/lib/putcol.c -@@ -1106,7 +1106,7 @@ int ffiter(int n_cols, - void *dataptr, *defaultnull; - colNulls *col; - int ii, jj, tstatus, naxis, bitpix; -- int typecode, hdutype, jtype, type, anynul, nfiles, nbytes; -+ int typecode, hdutype, jtype, type, anynul=0, nfiles, nbytes; - long totaln, nleft, frow, felement, n_optimum, i_optimum, ntodo; - long rept, rowrept, width, tnull, naxes[9] = {1,1,1,1,1,1,1,1,1}, groups; - double zeros = 0.; -@@ -1423,8 +1423,11 @@ int ffiter(int n_cols, - /* calc total number of elements to do on each iteration */ - if (hdutype == IMAGE_HDU || cols[jj].datatype == TSTRING) - { -- ntodo = n_optimum; -+ ntodo = n_optimum; - cols[jj].repeat = 1; -+ /* handle special case of a 0-width string column */ -+ if (hdutype == BINARY_TBL && rept == 0) -+ cols[jj].repeat = 0; - - /* get the BLANK keyword value, if it exists */ - if (abs(typecode) == TBYTE || abs(typecode) == TSHORT || abs(typecode) == TLONG -@@ -1701,7 +1704,8 @@ int ffiter(int n_cols, - { - /* allocate string to store the null string value */ - col[jj].null.stringnull = calloc(rept + 1, sizeof(char) ); -- col[jj].null.stringnull[1] = 1; /* to make sure string != 0 */ -+ if (rept > 0) -+ col[jj].null.stringnull[1] = 1; /* to make sure string != 0 */ - - /* allocate big block for the array of table column strings */ - stringptr[0] = calloc((ntodo + 1) * (rept + 1), sizeof(char) ); -diff --git a/cextern/cfitsio/lib/putcolb.c b/cextern/cfitsio/lib/putcolb.c -index 6660ad7ed0f..363a875ab1e 100644 ---- a/cextern/cfitsio/lib/putcolb.c -+++ b/cextern/cfitsio/lib/putcolb.c -@@ -356,6 +356,7 @@ int ffpclb( fitsfile *fptr, /* I - FITS file pointer */ - and will be inverse-scaled by the FITS TSCALn and TZEROn values if necessary. - */ - { -+ int writemode; - int tcode, maxelem2, hdutype, writeraw; - long twidth, incre; - long ntodo; -@@ -377,7 +378,15 @@ int ffpclb( fitsfile *fptr, /* I - FITS file pointer */ - /*---------------------------------------------------*/ - /* Check input and get parameters about the column: */ - /*---------------------------------------------------*/ -- if (ffgcprll( fptr, colnum, firstrow, firstelem, nelem, 1, &scale, &zero, -+ -+ /* IMPORTANT NOTE: that the special case of using this subroutine -+ to write bytes to a character column are handled internally -+ by the call to ffgcprll() below. It will adjust the effective -+ *tcode, repeats, etc, to appear as a TBYTE column. */ -+ -+ writemode = 17; /* Equivalent to writemode = 1 but allow TSTRING -> TBYTE */ -+ -+ if (ffgcprll( fptr, colnum, firstrow, firstelem, nelem, writemode, &scale, &zero, - tform, &twidth, &tcode, &maxelem2, &startpos, &elemnum, &incre, - &repeat, &rowlen, &hdutype, &tnull, snull, status) > 0) - return(*status); -@@ -481,18 +490,19 @@ int ffpclb( fitsfile *fptr, /* I - FITS file pointer */ - - case (TSTRING): /* numerical column in an ASCII table */ - -- if (strchr(tform,'A')) -+ if (strchr(tform,'A')) - { - /* write raw input bytes without conversion */ - /* This case is a hack to let users write a stream */ - /* of bytes directly to the 'A' format column */ - -- if (incre == twidth) -+ if (incre == twidth) { - ffpbyt(fptr, ntodo, &array[next], status); -- else -+ } else { - ffpbytoff(fptr, twidth, ntodo/twidth, incre - twidth, - &array[next], status); -- break; -+ } -+ break; - } - else if (cform[1] != 's') /* "%s" format is a string */ - { -diff --git a/cextern/cfitsio/lib/putkey.c b/cextern/cfitsio/lib/putkey.c -index 0fa88a34d96..f94bc6d1bd8 100644 ---- a/cextern/cfitsio/lib/putkey.c -+++ b/cextern/cfitsio/lib/putkey.c -@@ -1401,12 +1401,13 @@ int ffs2tm(char *datestr, /* I - date string: "YYYY-MM-DD" */ - return(*status = BAD_DATE); - } - -- else if (datestr[10] == 'T' && datestr[13] == ':' && datestr[16] == ':') -+ else if (datestr[10] == 'T') - { -- if (isdigit((int) datestr[11]) && isdigit((int) datestr[12]) -- && isdigit((int) datestr[14]) && isdigit((int) datestr[15]) -- && isdigit((int) datestr[17]) && isdigit((int) datestr[18]) ) -- { -+ if (datestr[13] == ':' && datestr[16] == ':') { -+ if (isdigit((int) datestr[11]) && isdigit((int) datestr[12]) -+ && isdigit((int) datestr[14]) && isdigit((int) datestr[15]) -+ && isdigit((int) datestr[17]) && isdigit((int) datestr[18]) ) -+ { - if (slen > 19 && datestr[19] != '.') - { - ffpmsg("input date string has illegal format:"); -@@ -1423,14 +1424,21 @@ int ffs2tm(char *datestr, /* I - date string: "YYYY-MM-DD" */ - - if (second) - *second = atof(&datestr[17]); -- } -- else -- { -+ } -+ else -+ { - ffpmsg("input date string has illegal format:"); - ffpmsg(datestr); - return(*status = BAD_DATE); -- } -- -+ } -+ -+ } -+ else -+ { -+ ffpmsg("input date string has illegal format:"); -+ ffpmsg(datestr); -+ return(*status = BAD_DATE); -+ } - } - } - else /* no date fields */ -@@ -1564,7 +1572,7 @@ int ffpkns( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1623,7 +1631,7 @@ int ffpknl( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1683,7 +1691,7 @@ int ffpknj( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1741,7 +1749,7 @@ int ffpknjj( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1800,7 +1808,7 @@ int ffpknf( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1859,7 +1867,7 @@ int ffpkne( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1918,7 +1926,7 @@ int ffpkng( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -@@ -1977,7 +1985,7 @@ int ffpknd( fitsfile *fptr, /* I - FITS file pointer */ - while (len > 0 && comm[0][len - 1] == ' ') - len--; /* ignore trailing blanks */ - -- if (comm[0][len - 1] == '&') -+ if (len > 0 && comm[0][len - 1] == '&') - { - len = minvalue(len, FLEN_COMMENT); - tcomment[0] = '\0'; -diff --git a/cextern/cfitsio/lib/region.c b/cextern/cfitsio/lib/region.c -index a9ca9def762..a5bec8d695a 100644 ---- a/cextern/cfitsio/lib/region.c -+++ b/cextern/cfitsio/lib/region.c -@@ -980,17 +980,58 @@ int fits_in_region( double X, - - /*---------------------------------------------------------------------------*/ - void fits_free_region( SAORegion *Rgn ) --/* Free up memory allocated to hold the region data. */ -+/* Free up memory allocated to hold the region data. -+ This is more complicated for the case of polygons, which may be sharing -+ points arrays due to shallow copying (in fits_set_region_components) of -+ 'exluded' regions. We must ensure that these arrays are only freed once. -+ - /*---------------------------------------------------------------------------*/ - { -- int i; -+ int i,j; -+ -+ int nFreedPoly=0; -+ int nPolyArraySize=10; -+ double **freedPolyPtrs=0; -+ double *ptsToFree=0; -+ int isAlreadyFreed=0; -+ -+ freedPolyPtrs = (double**)malloc(nPolyArraySize*sizeof(double*)); - - for( i=0; inShapes; i++ ) - if( Rgn->Shapes[i].shape == poly_rgn ) -- free( Rgn->Shapes[i].param.poly.Pts ); -+ { -+ /* No shared arrays for 'include' polygons */ -+ if (Rgn->Shapes[i].sign) -+ free(Rgn->Shapes[i].param.poly.Pts); -+ else -+ { -+ ptsToFree = Rgn->Shapes[i].param.poly.Pts; -+ isAlreadyFreed = 0; -+ for (j=0; jShapes ) - free( Rgn->Shapes ); - free( Rgn ); -+ -+ free(freedPolyPtrs); - } - - /*---------------------------------------------------------------------------*/ -@@ -1105,6 +1146,10 @@ void fits_set_region_components ( SAORegion *aRgn ) - - /* if this is an include region then insert a copy of the exclude - region immediately after it */ -+ -+ /* Note that this makes shallow copies of a polygon's dynamically -+ allocated Pts array -- the memory is shared. This must be checked -+ when freeing in fits_free_region. */ - - if ( aRgn->Shapes[j].sign ) { - -diff --git a/cextern/cfitsio/zlib/zcompress.c b/cextern/cfitsio/lib/zcompress.c -similarity index 100% -rename from cextern/cfitsio/zlib/zcompress.c -rename to cextern/cfitsio/lib/zcompress.c -diff --git a/cextern/cfitsio/zlib/zuncompress.c b/cextern/cfitsio/lib/zuncompress.c -similarity index 100% -rename from cextern/cfitsio/zlib/zuncompress.c -rename to cextern/cfitsio/lib/zuncompress.c - -From 35fd98587fefeca65cc6f0b58cd6d055e7bb11d3 Mon Sep 17 00:00:00 2001 -From: Simon Conseil -Date: Thu, 29 Jul 2021 22:41:36 +0200 -Subject: [PATCH 2/3] Require cfitsio 3.35+ - ---- - astropy/io/fits/hdu/compressed.py | 46 ++++--------------------- - astropy/io/fits/src/compressionmodule.c | 33 +----------------- - astropy/io/fits/src/compressionmodule.h | 23 +++---------- - 3 files changed, 11 insertions(+), 91 deletions(-) - -diff --git a/astropy/io/fits/hdu/compressed.py b/astropy/io/fits/hdu/compressed.py -index f571afd6d7a..5e1160f7cd0 100644 ---- a/astropy/io/fits/hdu/compressed.py -+++ b/astropy/io/fits/hdu/compressed.py -@@ -57,21 +57,7 @@ - DEFAULT_BLOCK_SIZE = 32 - DEFAULT_BYTE_PIX = 4 - --CMTYPE_ALIASES = {} -- --# CFITSIO version-specific features --if COMPRESSION_SUPPORTED: -- try: -- CFITSIO_SUPPORTS_GZIPDATA = compression.CFITSIO_VERSION >= 3.28 -- CFITSIO_SUPPORTS_Q_FORMAT = compression.CFITSIO_VERSION >= 3.35 -- if compression.CFITSIO_VERSION >= 3.35: -- CMTYPE_ALIASES['RICE_ONE'] = 'RICE_1' -- except AttributeError: -- # This generally shouldn't happen unless running pip in an -- # environment where an old build of pyfits exists -- CFITSIO_SUPPORTS_GZIPDATA = True -- CFITSIO_SUPPORTS_Q_FORMAT = True -- -+CMTYPE_ALIASES = {'RICE_ONE': 'RICE_1'} - - COMPRESSION_KEYWORDS = {'ZIMAGE', 'ZCMPTYPE', 'ZBITPIX', 'ZNAXIS', 'ZMASKCMP', - 'ZSIMPLE', 'ZTENSION', 'ZEXTEND'} -@@ -828,12 +814,6 @@ def _update_header_data(self, image_header, - # almost entirely contrived corner cases, so it will do for now - if self._has_data: - huge_hdu = self.data.nbytes > 2 ** 32 -- -- if huge_hdu and not CFITSIO_SUPPORTS_Q_FORMAT: -- raise OSError( -- "Astropy cannot compress images greater than 4 GB in size " -- "({} is {} bytes) without CFITSIO >= 3.35".format( -- (self.name, self.ver), self.data.nbytes)) - else: - huge_hdu = False - -@@ -926,25 +906,11 @@ def _update_header_data(self, image_header, - # this behavior so the only way to determine which behavior will - # be employed is via the CFITSIO version - -- if CFITSIO_SUPPORTS_GZIPDATA: -- ttype2 = 'GZIP_COMPRESSED_DATA' -- # The required format for the GZIP_COMPRESSED_DATA is actually -- # missing from the standard docs, but CFITSIO suggests it -- # should be 1PB, which is logical. -- tform2 = '1QB' if huge_hdu else '1PB' -- else: -- # Q format is not supported for UNCOMPRESSED_DATA columns. -- ttype2 = 'UNCOMPRESSED_DATA' -- if zbitpix == 8: -- tform2 = '1QB' if huge_hdu else '1PB' -- elif zbitpix == 16: -- tform2 = '1QI' if huge_hdu else '1PI' -- elif zbitpix == 32: -- tform2 = '1QJ' if huge_hdu else '1PJ' -- elif zbitpix == -32: -- tform2 = '1QE' if huge_hdu else '1PE' -- else: -- tform2 = '1QD' if huge_hdu else '1PD' -+ ttype2 = 'GZIP_COMPRESSED_DATA' -+ # The required format for the GZIP_COMPRESSED_DATA is actually -+ # missing from the standard docs, but CFITSIO suggests it -+ # should be 1PB, which is logical. -+ tform2 = '1QB' if huge_hdu else '1PB' - - # Set up the second column for the table that will hold any - # uncompressable data. -diff --git a/astropy/io/fits/src/compressionmodule.c b/astropy/io/fits/src/compressionmodule.c -index 67abdb0b068..5f07149cdd4 100644 ---- a/astropy/io/fits/src/compressionmodule.c -+++ b/astropy/io/fits/src/compressionmodule.c -@@ -223,13 +223,11 @@ int compress_type_from_string(char* zcmptype) { - } else if (0 == strcmp(zcmptype, "HCOMPRESS_1")) { - return HCOMPRESS_1; - } --#ifdef CFITSIO_SUPPORTS_SUBTRACTIVE_DITHER_2 - /* CFITSIO adds a compression type alias for RICE_1 compression - as a flag for using subtractive_dither_2 */ - else if (0 == strcmp(zcmptype, "RICE_ONE")) { - return RICE_1; - } --#endif - else { - PyErr_Format(PyExc_ValueError, "Unrecognized compression type: %s", - zcmptype); -@@ -531,9 +529,7 @@ void configure_compression(fitsfile* fileptr, PyObject* header) { - // BLANK in the header - Fptr->cn_zblank = Fptr->cn_zzero = Fptr->cn_zscale = -1; - Fptr->cn_uncompressed = 0; --#ifdef CFITSIO_SUPPORTS_GZIPDATA - Fptr->cn_gzip_data = 0; --#endif - - // Check for a ZBLANK, ZZERO, ZSCALE, and - // UNCOMPRESSED_DATA/GZIP_COMPRESSED_DATA columns in the compressed data -@@ -541,11 +537,9 @@ void configure_compression(fitsfile* fileptr, PyObject* header) { - for (idx = 0; idx < tfields; idx++) { - if (0 == strncmp(columns[idx].ttype, "UNCOMPRESSED_DATA", 18)) { - Fptr->cn_uncompressed = idx + 1; --#ifdef CFITSIO_SUPPORTS_GZIPDATA - } else if (0 == strncmp(columns[idx].ttype, - "GZIP_COMPRESSED_DATA", 21)) { - Fptr->cn_gzip_data = idx + 1; --#endif - } else if (0 == strncmp(columns[idx].ttype, "ZSCALE", 7)) { - Fptr->cn_zscale = idx + 1; - } else if (0 == strncmp(columns[idx].ttype, "ZZERO", 6)) { -@@ -706,11 +700,9 @@ void configure_compression(fitsfile* fileptr, PyObject* header) { - /* Ugh; the fact that cfitsio defines its version as a float makes - preprocessor comparison impossible */ - fits_get_version(&version); -- if ((version >= CFITSIO_LOSSLESS_COMP_SUPPORTED_VERS) && -- (0 == strcmp(tmp, "NONE"))) { -+ if (0 == strcmp(tmp, "NONE")) { - Fptr->quantize_level = NO_QUANTIZE; - } else if (0 == strcmp(tmp, "SUBTRACTIVE_DITHER_1")) { --#ifdef CFITSIO_SUPPORTS_SUBTRACTIVE_DITHER_2 - // Added in CFITSIO 3.35, this also changed the name of the - // quantize_dither struct member to quantize_method - Fptr->quantize_method = SUBTRACTIVE_DITHER_1; -@@ -735,29 +727,6 @@ void configure_compression(fitsfile* fileptr, PyObject* header) { - break; - } - } --#else -- Fptr->quantize_dither = SUBTRACTIVE_DITHER_1; -- } else { -- Fptr->quantize_dither = NO_DITHER; -- } -- } else { -- Fptr->quantize_dither = NO_DITHER; -- } -- -- if (Fptr->quantize_dither != NO_DITHER) { -- switch (get_header_int(header, "ZDITHER0", &(Fptr->dither_offset), 0, HDR_NOFLAG)) { -- case GET_HEADER_FAILED: -- return; -- case GET_HEADER_DEFAULT_USED: // ZDITHER0 keyword no found -- /* TODO: Find out if that's actually working and not invalid... */ -- Fptr->dither_offset = 0; -- Fptr->request_dither_offset = 0; -- break; -- default: -- break; -- } -- } --#endif - - Fptr->compressimg = 1; - Fptr->maxelem = imcomp_calc_max_elem(Fptr->compress_type, -diff --git a/astropy/io/fits/src/compressionmodule.h b/astropy/io/fits/src/compressionmodule.h -index fb37a50fd4e..7c13387a5ba 100644 ---- a/astropy/io/fits/src/compressionmodule.h -+++ b/astropy/io/fits/src/compressionmodule.h -@@ -18,30 +18,15 @@ - #endif - - --#if CFITSIO_MAJOR >= 3 -- #if CFITSIO_MINOR >= 35 -- #define CFITSIO_SUPPORTS_Q_FORMAT_COMPRESSION -- #define CFITSIO_SUPPORTS_SUBTRACTIVE_DITHER_2 -- #else -- /* This constant isn't defined in older versions and has a different */ -- /* value anyways. */ -- #define NO_DITHER 0 -- #endif -- #if CFITSIO_MINOR >= 28 -- #define CFITSIO_SUPPORTS_GZIPDATA -+#if CFITSIO_MAJOR == 3 && CFITSIO_MINOR < 35 -+ #ifdef _MSC_VER -+ #pragma warning ( "your CFITSIO version is too old; use 3.35 or later" ) - #else -- #ifdef _MSC_VER -- #pragma warning ( "GZIP_COMPRESSED_DATA columns not supported" ) -- #else -- #warning "GZIP_COMPRESSED_DATA columns not supported" -- #endif -+ #warning "your CFITSIO version is too old; use 3.35 or later" - #endif - #endif - - --#define CFITSIO_LOSSLESS_COMP_SUPPORTED_VERS 3.22 -- -- - /* These defaults mirror the defaults in io.fits.hdu.compressed */ - #define DEFAULT_COMPRESSION_TYPE "RICE_1" - #define DEFAULT_QUANTIZE_LEVEL 16.0 - -From 16af35898484c4caa911811678c0b25247a09939 Mon Sep 17 00:00:00 2001 -From: Simon Conseil -Date: Mon, 2 Aug 2021 22:19:35 +0200 -Subject: [PATCH 3/3] Add changelog file - ---- - docs/changes/12006.other.rst | 2 ++ - 1 file changed, 2 insertions(+) - create mode 100644 docs/changes/12006.other.rst - -diff --git a/docs/changes/12006.other.rst b/docs/changes/12006.other.rst -new file mode 100644 -index 00000000000..76e98957006 ---- /dev/null -+++ b/docs/changes/12006.other.rst -@@ -0,0 +1,2 @@ -+Updated the bundled CFITSIO library to 4.0.0. When compiling with an external -+library, version 3.35 is required. diff --git a/astropy-pr12159-py310.patch b/astropy-pr12159-py310.patch deleted file mode 100644 index 1e766d4..0000000 --- a/astropy-pr12159-py310.patch +++ /dev/null @@ -1,137 +0,0 @@ -From dea513d07ab6bc5bb3585cc33ead4bb6df2f8a8d Mon Sep 17 00:00:00 2001 -From: "P. L. Lim" <2090236+pllim@users.noreply.github.com> -Date: Thu, 9 Sep 2021 15:51:50 -0400 -Subject: [PATCH] Backport PR #11962: Fix warnings with Python 3.10 - ---- - .github/workflows/ci_cron_weekly.yml | 6 +++--- - .github/workflows/ci_workflows.yml | 5 +++++ - astropy/convolution/convolve.py | 6 +++++- - astropy/io/fits/util.py | 6 +++--- - astropy/tests/tests/test_imports.py | 2 +- - astropy/utils/console.py | 2 +- - docs/changes/11962.other.rst | 1 + - tox.ini | 2 +- - 8 files changed, 20 insertions(+), 10 deletions(-) - create mode 100644 docs/changes/11962.other.rst - -diff --git a/.github/workflows/ci_cron_weekly.yml b/.github/workflows/ci_cron_weekly.yml -index 207fc7d372f..66ecabedd77 100644 ---- a/.github/workflows/ci_cron_weekly.yml -+++ b/.github/workflows/ci_cron_weekly.yml -@@ -29,10 +29,10 @@ jobs: - # that gives too many false positives due to URL timeouts. We also - # install all dependencies via pip here so we pick up the latest - # releases. -- - name: Python 3.7 with dev version of key dependencies -+ - name: Python 3.10 with dev version of key dependencies - os: ubuntu-latest -- python: 3.7 -- toxenv: py37-test-devdeps -+ python: '3.10.0-alpha - 3.10.0' -+ toxenv: py310-test-devdeps - - - name: Documentation link check - os: ubuntu-latest -diff --git a/.github/workflows/ci_workflows.yml b/.github/workflows/ci_workflows.yml -index ee3dd88fe4e..2d596e1f16c 100644 ---- a/.github/workflows/ci_workflows.yml -+++ b/.github/workflows/ci_workflows.yml -@@ -58,6 +58,11 @@ jobs: - python: 3.9 - toxenv: py39-test - -+ - name: Python 3.10 with minimal dependencies -+ os: ubuntu-latest -+ python: '3.10.0-alpha - 3.10.0' -+ toxenv: py310-test-devdeps -+ - # NOTE: In the build below we also check that tests do not open and - # leave open any files. This has a performance impact on running the - # tests, hence why it is not enabled by default. -diff --git a/astropy/convolution/convolve.py b/astropy/convolution/convolve.py -index 86ef46e0a72..416bcd4247b 100644 ---- a/astropy/convolution/convolve.py -+++ b/astropy/convolution/convolve.py -@@ -4,6 +4,7 @@ - - import os - import ctypes -+import warnings - from functools import partial - - import numpy as np -@@ -22,7 +23,10 @@ - LIBRARY_PATH = os.path.dirname(__file__) - - try: -- _convolve = load_library("_convolve", LIBRARY_PATH) -+ with warnings.catch_warnings(): -+ # distutils.sysconfig module is deprecated in Python 3.10 -+ warnings.simplefilter('ignore', DeprecationWarning) -+ _convolve = load_library("_convolve", LIBRARY_PATH) - except Exception: - raise ImportError("Convolution C extension is missing. Try re-building astropy.") - -diff --git a/astropy/io/fits/util.py b/astropy/io/fits/util.py -index 157b8634fdd..06e9108511c 100644 ---- a/astropy/io/fits/util.py -+++ b/astropy/io/fits/util.py -@@ -210,9 +210,9 @@ def ignore_sigint(func): - def wrapped(*args, **kwargs): - # Get the name of the current thread and determine if this is a single - # threaded application -- curr_thread = threading.currentThread() -- single_thread = (threading.activeCount() == 1 and -- curr_thread.getName() == 'MainThread') -+ curr_thread = threading.current_thread() -+ single_thread = (threading.active_count() == 1 and -+ curr_thread.name == 'MainThread') - - class SigintHandler: - def __init__(self): -diff --git a/astropy/tests/tests/test_imports.py b/astropy/tests/tests/test_imports.py -index 2ce1442447a..d13c956f0f9 100644 ---- a/astropy/tests/tests/test_imports.py -+++ b/astropy/tests/tests/test_imports.py -@@ -19,7 +19,7 @@ def onerror(name): - - for imper, nm, ispkg in pkgutil.walk_packages(['astropy'], 'astropy.', - onerror=onerror): -- imper.find_module(nm) -+ imper.find_spec(nm) - - - def test_toplevel_namespace(): -diff --git a/astropy/utils/console.py b/astropy/utils/console.py -index 797859d8ba6..3de95bb07d7 100644 ---- a/astropy/utils/console.py -+++ b/astropy/utils/console.py -@@ -121,7 +121,7 @@ def isatty(file): - ttys. - """ - if (multiprocessing.current_process().name != 'MainProcess' or -- threading.current_thread().getName() != 'MainThread'): -+ threading.current_thread().name != 'MainThread'): - return False - - if hasattr(file, 'isatty'): -diff --git a/docs/changes/11962.other.rst b/docs/changes/11962.other.rst -new file mode 100644 -index 00000000000..d57a7d978f2 ---- /dev/null -+++ b/docs/changes/11962.other.rst -@@ -0,0 +1 @@ -+Fix deprecation warnings with Python 3.10 -diff --git a/tox.ini b/tox.ini -index 3414bb3f3b5..42a6590f915 100644 ---- a/tox.ini -+++ b/tox.ini -@@ -1,6 +1,6 @@ - [tox] - envlist = -- py{37,38,39,dev}-test{,-alldeps,-oldestdeps,-devdeps,-numpy117,-numpy118,-numpy119}{,-cov}{,-clocale} -+ py{37,38,39,310,dev}-test{,-alldeps,-oldestdeps,-devdeps,-numpy117,-numpy118,-numpy119}{,-cov}{,-clocale} - build_docs - linkcheck - codestyle diff --git a/python-astropy-rpmlintrc b/python-astropy-rpmlintrc index cbb989f..39b9ae4 100644 --- a/python-astropy-rpmlintrc +++ b/python-astropy-rpmlintrc @@ -1,4 +1,6 @@ addFilter('devel-file-in-non-devel-package .*/wcs/.*') addFilter('hidden-file-or-dir .*/tests/data/.*') addFilter('zero-length .*/tests/data/.*') -addFilter('zero-length .*/index\.html') +# https://bugzilla.opensuse.org/show_bug.cgi?id=1191584 +addFilter('unstripped-binary-or-object .*python.*\.so') +addFilter('shared-library-without-dependency-information .*python.*\.so') diff --git a/python-astropy.changes b/python-astropy.changes index e35c9fb..afcaba7 100644 --- a/python-astropy.changes +++ b/python-astropy.changes @@ -1,3 +1,33 @@ +------------------------------------------------------------------- +Tue Dec 28 12:53:13 UTC 2021 - Ben Greiner + +- Update to version 5.0 + * https://docs.astropy.org/en/stable/whatsnew/5.0.html + * Astropy 5.0 is a major release that adds significant new + functionality since the 4.3.x series of releases. In addition, + it is a long-term support release (LTS) which will be supported + with bug fixes for two years. In particular, this release + includes: + * Support for reading, writing, and converting Cosmology + * Cosmology units module + * New Models + * Added support for dask arrays in tables + * Added support for registering array-like objects as mixin + columns + * Support for reading and writing tables to Parquet format + * Support for reading and writing tables to MRT format + * Support for masked quantity columns, including masked FITS + columns with units + * Converting SkyCoord to QTable + * New Unified I/O architecture + * In addition to these major changes, Astropy v5.0 includes a + large number of smaller improvements and bug fixes, which + are described in the Full Changelog. + https://docs.astropy.org/en/stable/changelog.html#changelog +- Drop patches fixed upstream + * astropy-pr12006-cfitsio4.patch + * astropy-pr12159-py310.patch + ------------------------------------------------------------------- Mon Dec 27 17:29:17 UTC 2021 - Ben Greiner diff --git a/python-astropy.spec b/python-astropy.spec index e3e266e..47dfc45 100644 --- a/python-astropy.spec +++ b/python-astropy.spec @@ -59,7 +59,7 @@ # upcoming python3 multiflavor: minimum supported python is 3.7 %define skip_python36 1 Name: python-astropy%{psuffix} -Version: 4.3.1 +Version: 5.0 Release: 0 Summary: Community-developed python astronomy tools License: BSD-3-Clause @@ -68,43 +68,46 @@ Source: https://files.pythonhosted.org/packages/source/a/astropy/astropy # Mark wcs headers as false positives for devel-file-in-non-devel-package # These are used by the python files so they must be available. Source100: python-astropy-rpmlintrc -# https://docs.astropy.org/en/v4.3post1/install.html#requirements -# PATCH-FIX-UPSTREAM astropy-pr12006-cfitsio4.patch gh#astropy/astropy#12006 -Patch1: https://github.com/astropy/astropy/pull/12006.patch#/astropy-pr12006-cfitsio4.patch -Patch2: https://github.com/astropy/astropy/pull/12159.patch#/astropy-pr12159-py310.patch +# https://docs.astropy.org/en/v5.0/install.html#requirements BuildRequires: %{python_module Cython >= 0.29.22} BuildRequires: %{python_module Jinja2} -BuildRequires: %{python_module devel >= 3.7} +BuildRequires: %{python_module PyYAML >= 3.13} +BuildRequires: %{python_module devel >= 3.8} BuildRequires: %{python_module extension-helpers} -BuildRequires: %{python_module numpy-devel >= 1.17} -BuildRequires: %{python_module pyerfa >= 1.7.3} -BuildRequires: %{python_module setuptools_scm} +BuildRequires: %{python_module numpy-devel >= 1.18} +BuildRequires: %{python_module packaging >= 19.0} +BuildRequires: %{python_module pyerfa >= 2.0} +BuildRequires: %{python_module setuptools_scm >= 6.2} BuildRequires: %{python_module setuptools} BuildRequires: fdupes BuildRequires: hdf5-devel BuildRequires: pkgconfig BuildRequires: python-rpm-macros +Requires: python-PyYAML >= 3.13 Requires: python-dbm -Requires: python-numpy >= 1.17 -Requires: python-pyerfa >= 1.7.3 +Requires: python-numpy >= 1.18 +Requires: python-packaging >= 19.0 +Requires: python-pyerfa >= 2.0 Requires(post): update-alternatives Requires(postun):update-alternatives Recommends: libxml2-tools Recommends: python-Bottleneck -Recommends: python-PyYAML >= 3.13 Recommends: python-asdf >= 2.6 Recommends: python-beautifulsoup4 Recommends: python-bleach Recommends: python-h5py Recommends: python-html5lib Recommends: python-jplephem -Recommends: python-matplotlib >= 3 +Recommends: python-matplotlib >= 3.1 Recommends: python-mpmath Recommends: python-pandas +Recommends: python-pyarrow >= 5 Recommends: python-scipy >= 1.1 Recommends: python-setuptools Recommends: python-sortedcontainers +Recommends: python-typing_extensions Conflicts: perl-Data-ShowTable +Conflicts: python-matplotlib = 3.4.0 %if %{with system_cfitsio} BuildRequires: pkgconfig(cfitsio) %endif @@ -117,18 +120,18 @@ BuildRequires: pkgconfig(wcslib) >= 7 %if %{with test} # SECTION Optional requirements BuildRequires: %{python_module Bottleneck} -BuildRequires: %{python_module PyYAML >= 3.13} BuildRequires: %{python_module asdf >= 2.6} BuildRequires: %{python_module beautifulsoup4} BuildRequires: %{python_module bleach} BuildRequires: %{python_module h5py} BuildRequires: %{python_module html5lib} BuildRequires: %{python_module jplephem} -BuildRequires: %{python_module matplotlib >= 3} +BuildRequires: %{python_module matplotlib >= 3.1} BuildRequires: %{python_module mpmath} BuildRequires: %{python_module pandas} -BuildRequires: %{python_module scipy >= 1.1} +BuildRequires: %{python_module scipy >= 1.3} BuildRequires: %{python_module sortedcontainers} +BuildRequires: %{python_module typing_extensions} BuildRequires: libxml2-tools # /SECTION # SECTION test requirements @@ -136,8 +139,7 @@ BuildRequires: libxml2-tools BuildRequires: %{python_module astropy = %{version}} BuildRequires: %{python_module ipython >= 4.2} BuildRequires: %{python_module objgraph} -BuildRequires: %{python_module packaging} -BuildRequires: %{python_module pytest-astropy} +BuildRequires: %{python_module pytest-astropy >= 0.9} BuildRequires: %{python_module pytest-mpl} BuildRequires: %{python_module pytest-xdist} BuildRequires: %{python_module sgp4} @@ -155,6 +157,8 @@ managing them. %if !%{with test} %prep %autosetup -p1 -n astropy-%{version} +# avoid rpmlint zero-length error for empty module +echo '# empty module' > astropy/samp/setup_package.py # Make sure bundled libs are not used %if %{with system_cfitsio} @@ -205,8 +209,6 @@ done # gh#astropy/astropy#12017 donttest+=" or test_stats" %endif -# https://github.com/astropy/astropy/issues/12050 -donttest+=" or (test_no_numpy_warnings and contours)" testselect_expr="${donttest:+-k \"not (${donttest# or })\"}" # http://docs.astropy.org/en/latest/development/testguide.html#running-tests # running pytest directly would require building the extensions inplace