mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-11 13:23:04 +00:00
Merge remote-tracking branch 'origin/maint'
* origin/maint: maint: post-release administrivia version 3.0.4 gnulib: update build: re-enable compiler warnings, and fix them tests: c++: fix a C++03 conformance issue tests: fix a title c++: reserve 200 slots in the parser's stack tests: be more robust to unrecognized synclines, and try to recognize xlc tests: fix C++ conformance build: fix some warnings build: avoid infinite recursions on include_next
This commit is contained in:
@@ -633,7 +633,7 @@ main (int argc, const char *argv[])
|
||||
{
|
||||
int status;
|
||||
yydebug = !!getenv ("YYDEBUG");
|
||||
assert (argc == 2);
|
||||
assert (argc == 2); (void) argc;
|
||||
source = argv[1];
|
||||
status = yyparse ();
|
||||
switch (status)
|
||||
@@ -1530,10 +1530,13 @@ AT_DATA_GRAMMAR([[input.y]],
|
||||
|
||||
]AT_SKEL_CC_IF([[
|
||||
# include <iostream>
|
||||
static void
|
||||
report (std::ostream& yyo, int ival, float fval)
|
||||
namespace
|
||||
{
|
||||
yyo << "ival: " << ival << ", fval: " << fval;
|
||||
void
|
||||
report (std::ostream& yyo, int ival, float fval)
|
||||
{
|
||||
yyo << "ival: " << ival << ", fval: " << fval;
|
||||
}
|
||||
}
|
||||
]], [[
|
||||
# include <stdio.h>
|
||||
|
||||
@@ -342,7 +342,6 @@ AT_PARSER_CHECK([./list], 0,
|
||||
]],
|
||||
[[Destroy: ""
|
||||
Destroy: "0"
|
||||
Destroy: (0)
|
||||
Destroy: 1
|
||||
Destroy: "1"
|
||||
Destroy: ()
|
||||
@@ -719,6 +718,7 @@ $1
|
||||
#include <cstdlib> // size_t and getenv.
|
||||
#include <iostream>
|
||||
#include <set>
|
||||
#include <string>
|
||||
|
||||
bool debug = false;
|
||||
|
||||
@@ -751,7 +751,7 @@ $1
|
||||
~Object ()
|
||||
{
|
||||
log (this, "Object::~Object");
|
||||
objects::const_iterator i = instances.find (this);
|
||||
objects::iterator i = instances.find (this);
|
||||
// Make sure this object is alive.
|
||||
assert (i != instances.end ());
|
||||
Object::instances.erase (i);
|
||||
|
||||
@@ -94,8 +94,8 @@ main (int argc, const char **argv)
|
||||
status = ]AT_NAME_PREFIX[parse (]AT_PARAM_IF([[&result, &count]])[);
|
||||
if (fclose (input))
|
||||
perror ("fclose");
|
||||
assert (global_result == result);
|
||||
assert (global_count == count);
|
||||
assert (global_result == result); (void) result;
|
||||
assert (global_count == count); (void) count;
|
||||
return status;
|
||||
}
|
||||
]])
|
||||
|
||||
@@ -395,7 +395,7 @@ AT_CLEANUP
|
||||
|
||||
m4_pushdef([AT_CONSISTENT_ERRORS_CHECK], [
|
||||
|
||||
AT_SETUP([[parse.error=verbose and consistent errors: $1]])
|
||||
AT_SETUP([[parse.error=verbose and consistent errors: ]$1])
|
||||
|
||||
AT_BISON_OPTION_PUSHDEFS([$1])
|
||||
|
||||
|
||||
@@ -127,7 +127,7 @@ declarator : ID
|
||||
int
|
||||
main (int argc, char **argv)
|
||||
{
|
||||
assert (argc == 2);
|
||||
assert (argc == 2); (void) argc;
|
||||
if (!freopen (argv[1], "r", stdin))
|
||||
return 3;
|
||||
return yyparse ();
|
||||
|
||||
@@ -72,7 +72,7 @@ const char *input = YY_NULLPTR;
|
||||
int
|
||||
main (int argc, const char* argv[])
|
||||
{
|
||||
assert (argc == 2);
|
||||
assert (argc == 2); (void) argc;
|
||||
input = argv[1];
|
||||
return yyparse ();
|
||||
}
|
||||
|
||||
@@ -162,8 +162,8 @@ int main (int argc, const char **argv)
|
||||
}
|
||||
status = yyparse ();
|
||||
fclose (input);
|
||||
assert (global_result == result);
|
||||
assert (global_count == count);
|
||||
assert (global_result == result); (void) global_result; (void) result;
|
||||
assert (global_count == count); (void) global_count; (void) count;
|
||||
return status;
|
||||
}
|
||||
]])
|
||||
|
||||
@@ -19,13 +19,13 @@
|
||||
AT_BANNER([[User Actions.]])
|
||||
|
||||
|
||||
# AT_SYNCLINES_COMPILE(FILE)
|
||||
# --------------------------
|
||||
# _AT_SYNCLINES_COMPILE(FILE)
|
||||
# ---------------------------
|
||||
# Compile FILE expecting an error, and save in the file stdout the
|
||||
# normalized output. Ignore the exit status, since some compilers
|
||||
# (e.g. c89 on IRIX 6.5) trigger warnings on '#error', instead of
|
||||
# errors.
|
||||
m4_define([AT_SYNCLINES_COMPILE],
|
||||
m4_define([_AT_SYNCLINES_COMPILE],
|
||||
[AT_CHECK([$CC $CFLAGS $CPPFLAGS -c $1], [ignore], [], [stderr])
|
||||
|
||||
# Transform stderr into something like this:
|
||||
@@ -75,6 +75,12 @@ m4_define([AT_SYNCLINES_COMPILE],
|
||||
# When c++ is used to compiler C, we might have more messages (Clang 3.2):
|
||||
#
|
||||
# clang: warning: treating 'c' input as 'c++' when in C++ mode, this behavior is deprecated
|
||||
#
|
||||
#
|
||||
# xlc reports things like:
|
||||
#
|
||||
# "input.yy", line 80.21: 1540-0218 (S) The call does not match any parameter list for "operator<<".
|
||||
# "/usr/vacpp/include/iosfwd", line 32.6: 1506-205 (S) #error This file to be used only with IBM VisualAge C++ v4 and later compilers
|
||||
|
||||
AT_CHECK([[$PERL -p -0777 - stderr <<\EOF
|
||||
# 1. Remove useless lines.
|
||||
@@ -92,6 +98,8 @@ AT_CHECK([[$PERL -p -0777 - stderr <<\EOF
|
||||
|
||||
# 2. Normalize the lines we kept.
|
||||
|
||||
# xlc messages. Remove also error identifier (e.g., "1540-0218 (S)").
|
||||
s/^"(.*?)", line ([\w.]*): \d+-\d+ \(.\) /$][1:$][2: /gm;
|
||||
# Remove column.
|
||||
s/^([^:]+:\d+)[.:][^:]+:(.+)$/$][1:$][2/gm;
|
||||
# Map all combinations of "error: " and "#error: " to "#error ".
|
||||
@@ -101,13 +109,14 @@ EOF
|
||||
0, [stdout])
|
||||
])
|
||||
|
||||
# AT_TEST(TITLE, INPUT, ERROR-MSG)
|
||||
# --------------------------------
|
||||
# Check that compiling the parser produced from INPUT cause GCC
|
||||
# to issue ERROR-MSG.
|
||||
m4_pushdef([AT_TEST],
|
||||
[AT_SETUP([$1])
|
||||
AT_BISON_OPTION_PUSHDEFS
|
||||
|
||||
|
||||
# AT_SYNCLINES_COMPILE(FILE)
|
||||
# --------------------------
|
||||
# Compile FILE expecting an error, and save in the file stdout the
|
||||
# normalized output. If we can't get a trustable location
|
||||
# from the compiler, just skip the test.
|
||||
#
|
||||
# It seems impossible to find a generic scheme to check the location
|
||||
# of an error. Even requiring GCC is not sufficient, since for instance
|
||||
# the version modified by Apple:
|
||||
@@ -124,15 +133,29 @@ AT_BISON_OPTION_PUSHDEFS
|
||||
#
|
||||
# | input.y:2: "2"
|
||||
# | cpp-precomp: warning: errors during smart preprocessing, retrying in basic mode
|
||||
|
||||
m4_define([AT_SYNCLINES_COMPILE],
|
||||
[# Check if we can trust location translation.
|
||||
AT_DATA([syncline.c],
|
||||
[[#error "1"
|
||||
int i; /* avoids -pedantic warning about an empty translation unit. */
|
||||
]])
|
||||
|
||||
AT_SYNCLINES_COMPILE([syncline.c])
|
||||
_AT_SYNCLINES_COMPILE([syncline.c])
|
||||
AT_CHECK([[test "`cat stdout`" = 'syncline.c:1: @%:@error "1"' || exit 77]])
|
||||
|
||||
# Then work for real.
|
||||
_AT_SYNCLINES_COMPILE([$1])
|
||||
])
|
||||
|
||||
|
||||
# AT_TEST(TITLE, INPUT, ERROR-MSG)
|
||||
# --------------------------------
|
||||
# Check that compiling the parser produced from INPUT cause GCC
|
||||
# to issue ERROR-MSG.
|
||||
m4_pushdef([AT_TEST],
|
||||
[AT_SETUP([$1])
|
||||
AT_BISON_OPTION_PUSHDEFS
|
||||
|
||||
AT_DATA([[input.y]], [$2])
|
||||
AT_BISON_CHECK([-o input.c input.y])
|
||||
AT_SYNCLINES_COMPILE([input.c])
|
||||
|
||||
@@ -403,7 +403,7 @@ get_args (int argc, const char **argv)
|
||||
{
|
||||
int res;
|
||||
char *endp;
|
||||
assert (argc == 2);
|
||||
assert (argc == 2); (void) argc;
|
||||
res = strtol (argv[1], &endp, 10);
|
||||
assert (argv[1] != endp);
|
||||
assert (0 <= res);
|
||||
|
||||
Reference in New Issue
Block a user