mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-09 12:23:04 +00:00
Rename %before-definitions to %start-header and %after-definitions to
%end-header. Don't use these declarations to separate pre-prologue blocks from post-prologue blocks. Add new order-independent declarations %before-header and %after-header as alternatives to the traditional Yacc pre-prologue and post-prologue blocks. Discussed at <http://lists.gnu.org/archive/html/bison-patches/2006-06/msg00110.html>. * NEWS (2.3+): Update for these changes. * data/glr.c (b4_before_definitions): Update to... (b4_start_header): ... this. (b4_after_definitions): Update to... (b4_end_header): ... this. * data/glr.cc: Likewise. * data/lalr1.cc: Likewise. * data/yacc.c: Likewise. * doc/bison.texinfo (The prologue): Update names, and replace remaining prologue blocks with %*-header declarations. (Calc++ Parser): Likewise. (Bison Declaration Summary): Update names. (Bison Symbols): Update description. * src/parse-gram.y (PERCENT_AFTER_DEFINITIONS): Update to... (PERCENT_END_HEADER): ... this. (PERCENT_BEFORE_DEFINITIONS): Update to... (PERCENT_START_HEADER): ... this. (PERCENT_AFTER_HEADER, PERCENT_BEFORE_HEADER): New tokens. (declaration): Update token names and m4 macro names. When parsing %end-header and %start-header, invoke translate_code before muscle_code_grow, and no longer set global booleans to remember whether these declarations have been seen. Parse new %after-header and %before-header. * src/reader.c (before_definitions, after_definitions): Remove. (prologue_augment): Accept a new bool argument to specify whether to augment the pre-prologue or post-prologue. * src/reader.h (before_definitions, after_definitions): Remove these extern's. (prologue_augment): Add new bool argument. * src/scan-gram.l (PERCENT_AFTER_DEFINITIONS): Update to... (PERCENT_END_HEADER): ... this. (PERCENT_BEFORE_DEFINITIONS): Update to... (PERCENT_START_HEADER): ... this. (PERCENT_AFTER_HEADER, PERCENT_BEFORE_HEADER): New tokens. * tests/actions.at (Printers and Destructors): Update names.
This commit is contained in:
78
NEWS
78
NEWS
@@ -9,18 +9,16 @@ Changes in version 2.3+:
|
||||
helps to sanitize the global namespace during preprocessing, but POSIX Yacc
|
||||
requires them. Bison still generates an enum for token names in all cases.
|
||||
|
||||
* Handling of prologue blocks is now more consistent but potentially backward
|
||||
incompatible.
|
||||
* Handling of traditional Yacc prologue blocks is now more consistent but
|
||||
potentially incompatible with previous releases of Bison.
|
||||
|
||||
As before, you declare prologue blocks in your grammar file with the
|
||||
`%{ ... %}' syntax. To generate the pre-prologue, Bison concatenates all
|
||||
prologue blocks that you've declared before any %union. If you've declared a
|
||||
%union, Bison concatenates all prologue blocks that you've declared after it
|
||||
to generate the post-prologue. (The new %before-definitions and
|
||||
%after-definitions have a similar effect as %union on the prologues. See
|
||||
below.)
|
||||
prologue blocks that you've declared before the first %union. To generate
|
||||
the post-prologue, Bison concatenates all prologue blocks that you've
|
||||
declared after the first %union.
|
||||
|
||||
Previous versions of Bison inserted the pre-prologue into both the header
|
||||
Previous releases of Bison inserted the pre-prologue into both the header
|
||||
file and the code file in all cases except for LALR(1) parsers in C. In the
|
||||
latter case, Bison inserted it only into the code file. For parsers in C++,
|
||||
the point of insertion was before any token definitions (which associate
|
||||
@@ -30,38 +28,50 @@ Changes in version 2.3+:
|
||||
Now, Bison never inserts the pre-prologue into the header file. In the code
|
||||
file, it always inserts it before the token definitions.
|
||||
|
||||
* Bison now provides the %before-definitions and %after-definitions directives.
|
||||
* Bison now provides a more flexible alternative to the traditional Yacc
|
||||
prologue blocks: %before-header, %start-header, %end-header, and
|
||||
%after-header.
|
||||
|
||||
For example, in your grammar file:
|
||||
For example, the following declaration order in the grammar file reflects the
|
||||
order in which Bison will output these code blocks. However, you are free to
|
||||
declare these code blocks in your grammar file in whatever order is most
|
||||
convenient for you:
|
||||
|
||||
%{
|
||||
/* A pre-prologue block. For Yacc portability, Bison no longer puts this
|
||||
* in the header file. In the code file, Bison inserts it before any
|
||||
* %before-definitions blocks. */
|
||||
%}
|
||||
%before-definitions {
|
||||
/* Bison inserts this into both the header file and code file. In both
|
||||
* files, the point of insertion is before any Bison-generated token,
|
||||
* semantic type, location type, and class definitions. This is a good
|
||||
* place to define %union dependencies, for example. */
|
||||
%before-header {
|
||||
/* Bison treats this block like a pre-prologue block: it inserts it into
|
||||
* the code file before the contents of the header file. It does *not*
|
||||
* insert it into the header file. This is a good place to put
|
||||
* #include's that you want at the top of your code file. A common
|
||||
* example is `#include "system.h"'. */
|
||||
}
|
||||
%start-header {
|
||||
/* Bison inserts this block into both the header file and the code file.
|
||||
* In both files, the point of insertion is before any Bison-generated
|
||||
* token, semantic type, location type, and class definitions. This is a
|
||||
* good place to define %union dependencies, for example. */
|
||||
}
|
||||
%union {
|
||||
/* With previous versions of Bison, the first %union in your grammar file
|
||||
* separated the pre-prologue blocks from the post-prologue blocks. Now,
|
||||
* the first %union, %before-definitions, or %after-definitions does
|
||||
* that. */
|
||||
/* Unlike the traditional Yacc prologue blocks, the output order for the
|
||||
* new %*-header blocks is not affected by their declaration position
|
||||
* relative to any %union in the grammar file. */
|
||||
}
|
||||
%after-definitions {
|
||||
/* If you want something in the header file and in the code file and it
|
||||
* depends on any of the Bison-generated definitions in the header file,
|
||||
* put it here. */
|
||||
%end-header {
|
||||
/* Bison inserts this block into both the header file and the code file.
|
||||
* In both files, the point of insertion is after the Bison-generated
|
||||
* definitions. This is a good place to declare or define public
|
||||
* functions or data structures that depend on the Bison-generated
|
||||
* definitions. */
|
||||
}
|
||||
%{
|
||||
/* A post-prologue block. If you want something in the code file but not
|
||||
* in the header file and it depends on Bison-generated definitions, put
|
||||
* it here. In the code file, Bison inserts it after any
|
||||
* %after-definitions blocks. */
|
||||
%}
|
||||
%after-header {
|
||||
/* Bison treats this block like a post-prologue block: it inserts it into
|
||||
* the code file after the contents of the header file. It does *not*
|
||||
* insert it into the header file. This is a good place to declare or
|
||||
* define internal functions or data structures that depend on the
|
||||
* Bison-generated definitions. */
|
||||
}
|
||||
|
||||
If you have multiple occurrences of any one of the above declarations, Bison
|
||||
will concatenate the contents in declaration order.
|
||||
|
||||
* The option `--report=look-ahead' has been changed to `--report=lookahead'.
|
||||
The old spelling still works, but is not documented and may be removed
|
||||
|
||||
Reference in New Issue
Block a user