diff options
author | Andrea Monaco <andrea.monaco@autistici.org> | 2021-12-12 10:24:28 +0100 |
---|---|---|
committer | Arjun Shankar <arjun@redhat.com> | 2021-12-22 14:46:39 +0100 |
commit | c6d7d6312c21bbcfb236d48bb7c11cedb234389f (patch) | |
tree | d925a19f712eda759ea052d9a8ba6d98c9fd419d | |
parent | 163f625cf9becbb82dfec63a29e566324129c0cd (diff) | |
download | glibc-c6d7d6312c21bbcfb236d48bb7c11cedb234389f.tar glibc-c6d7d6312c21bbcfb236d48bb7c11cedb234389f.tar.gz glibc-c6d7d6312c21bbcfb236d48bb7c11cedb234389f.tar.bz2 glibc-c6d7d6312c21bbcfb236d48bb7c11cedb234389f.zip |
intl/plural.y: Avoid conflicting declarations of yyerror and yylex
bison-3.8 includes these lines in the generated intl/plural.c:
#if !defined __gettexterror && !defined YYERROR_IS_DECLARED
void __gettexterror (struct parse_args *arg, const char *msg);
#endif
#if !defined __gettextlex && !defined YYLEX_IS_DECLARED
int __gettextlex (YYSTYPE *yylvalp, struct parse_args *arg);
#endif
Those default prototypes provided by bison conflict with the
declarations later on in plural.y. This patch solves the issue.
Reviewed-by: Arjun Shankar <arjun@redhat.com>
-rw-r--r-- | intl/plural.y | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/intl/plural.y b/intl/plural.y index e02e74541c..2ee128ba01 100644 --- a/intl/plural.y +++ b/intl/plural.y @@ -40,6 +40,11 @@ # define __gettextparse PLURAL_PARSE #endif +/* Later we provide those prototypes. Without these macros, bison may + generate its own prototypes with possible conflicts. */ +#define YYLEX_IS_DECLARED +#define YYERROR_IS_DECLARED + %} %parse-param {struct parse_args *arg} %lex-param {struct parse_args *arg} |