• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1Boost.Wave: A Standard compliant C++ preprocessor library
2http://www.boost.org/
3
4Copyright (c) 2001-2013 Hartmut Kaiser. Distributed under the Boost
5Software License, Version 1.0. (See accompanying file
6LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7-------------------------------------------------------------------------------
8
9TODO (known issues):
10- Fix expansion of macros, which replacement-list terminates in a partial
11  macro expansion.
12- Try to remove the second parameter from the pp_iterator<>::force_include
13  function.
14- Fix the trigraph backslash problem in the re2c (C/C++ and IDL) scanners, if
15  there is the end of the (internal) buffer just in between a '??/' and a '\n'.
16
17-------------------------------------------------------------------------------
18
19CHANGELOG
20
21Boost V1.74:
22  - Fixed TRAC #10733: Hooks not called for expanding specific predefined macros
23  - Fixed #58: C++11 long long literals must use consistent case
24  - Repaired two samples and added a new one for macro naming enforcement
25  - Implemented C++20 changes for variadic macros, including __VA_OPT__()
26  - Added C++17 feature __has_include()
27  - Deprecate C++98 and C++03. Support will end with 1.77.
28
29Boost V1.73:
30  - Fixed TRAC #7822: waveidl sample does not use the IDL lexer
31  - Fixed TRAC #9874: Turning off 'include_next' support breaks include
32  - Fixed a typedef shadowing a class (MSVC warning 4458) - Conrad Poelman
33  - Updated waveidl to match recent changes in the RE2C lexer
34  - Samples now build cleanly
35  - Ensured samples and wave driver are covered by continuous integration
36
37Boost V1.55:
38 - Fixed #8848: Wave driver improperly processes 0xFFFFui64 token
39 - Fixed #9098: Wave driver option --c++0x invalid
40
41Boost V1.54:
42 - Fixed #8478: Make Boost.wave compatible with Clang's -Wimplicit-fallthrough
43   diagnostic.
44
45Boost V1.53:
46 - Fixed a problem with context<>::add_macro_definition which sometimes
47   appended a superfluous T_EOF to the macro replacement list.
48
49Boost V1.52.0:
50 - Added util::create_directories() wrapper to account for new behavior of
51   boost::filesystem::create_directories().
52 - Fixed an obscure problem when preprocessing directives wouldn't be recognized
53   if the previous line contained nothing but an empty macro invocation
54   (see new test case t_9_023.cpp)
55 - Added a new command line option --license=<file> to the Wave driver tool
56   which allows to pre-pend the content of a (license) file to every newly
57   created file. This option simplifies the implementation of partial
58   preprocessing as done on Phoenix, Fusion, etc.
59 - Changed the effect of the -N command line option to simply not expand
60   the macro by pretending it was not defined. Earlier the whole invocation
61   sequence was skipped, now we skip only the macro itself, which still expands
62   the arguments for the macro invocation.
63  - Fixed a couple of compilation warnings
64
65Boost V1.51.0
66 - Fixed #7050: Invalid memory write bug in lexing_exception
67 - Fixed #7159: Text-lines are processed as if they were preprocessing directives
68 - Changed --c++0x command line option to --c++11.
69
70Boost V1.50.0
71 - V2.3.2
72 - Fixed #6758: not all members are initialized by base_iteration_context
73   constructor.
74 - Fixed #6838: Adding include file with force_include makes Wave fail to emit
75   #line directive
76 - Added support for test of --forceinclude option to testwave executable,
77   added test case verifying #6838 is fixed.
78 - Fixed #6870: build wave driver failed
79
80Boost V1.48.0
81 - V2.3.1
82 - Added the flag support_option_emit_contnewlines allowing to control whether
83   backslash newline sequences are emitted by the Wave library. The default is
84   as before: these tokens will be silently ignored (after the token positions
85   have been properly updated). Note: this option is supported by the SLex lexer
86   module only.
87 - Fixed #5887: flex_string.hpp needs to include <ios>
88
89Boost V1.47.0
90- V2.3.0
91- After preprocessing the body of any #pragma wave option() the wave tool now
92  concatenates all adjacent string literals into a single string literal.
93- Fixed whitespace handling, added a corresponding set of test cases
94  (t_9_020.cpp)
95- Added a new preprocessing hook: locate_include_file allowing to customize the
96  way include files are located.
97- Added new command line option --noexpand/-N to the Wave driver allowing to
98  suppress macro expansion for a given macro name (works for both, object like
99  and function like macros). This option has to be used very carefully as it
100  not only leaves the whole macro invocation untouched in the generated output
101  but also removes this macro from consideration for Wave itself. This can
102  cause unexpected results if the suppressed macro would influence #ifdef's
103  later on.
104- Fixed Wave driver to retain all macros defined on the command line in
105  interactive mode.
106- Fixed problem #5554: wave slex parser eof without eol skips the last line.
107- Added the compile time configuartion option BOOST_WAVE_WCHAR_T_SIGNEDNESS,
108  which can be set to BOOST_WAVE_WCHAR_T_AUTOSELECT, BOOST_WAVE_WCHAR_T_FORCE_SIGNED,
109  or BOOST_WAVE_WCHAR_T_FORCE_UNSIGNED), it defaults to auto�select.
110- Fixed a problem in teh wave driver tool related to #pragma option(output).
111  If wave was invoked in rapid succession this erroneously appended to an
112  existing file instead of overwriting that file.
113- Fixed #5569: slex CONTLINE token works only for LF line endings
114
115Boost V1.46.0
116- V2.2.0
117- Added recognition of C++0x keywords to Re2C lexers.
118- Added --c++0x command line option to Wave to enabling the recognition of
119  C++0x keywords, converting those to C++0x tokens.
120- Adapted all of the library to play well with Boost.Filesystem V3 (which is
121  the default from now on).
122- Added support for extended character and string literals, added test case
123  (which required to add C++0x support to the test application).
124- Added proper predefined macros fro --c++0x mode. __cplusplus is currently
125  defined to 201101L, but this will change when the Standard is finalized.
126- Fixed a problem with object like macros, which when being adjacent to a
127  parenthesis, caused the parenthesis to disappear when the macro expansion
128  was suppressed by the expanding_object_like_macro() hook function.
129- Fixed a bug in pragma option(preserve), missing to set to preserve=1 if
130  after the previous value was preserve=2.
131- Changed the --preserve option of the wave tool to interprete the integer
132  argument in a slightly different way:
133      0: no whitespace is preserved,
134      1: only begin of line whitespace is preserved,
135      2: only begin of line whitespace and comments are preserved,
136      3: all whitespace is preserved
137  The #pragma wave option(preserve) now supports these arguments:
138  [0|1|2|3|push|pop].
139
140Boost V1.45.0
141- V2.1.0
142- Token pasting is well formed only as long as the formed token(s) are
143  pp_tokens as defined by the C++0x Standard. Until now, Wave allowed for
144  non-pp_tokens to be formed in --variadics mode.
145- Fixed a problem, which prevented reporting /##/ in a macro definition as
146  invalid token pasting.
147- Fixed problem preventing the skipped_token hook to be called for 'inactive'
148  conditional preprocessing directive tokens. Improved overall consistency in
149  reporting skipped tokens to the hooks function when processing conditional
150  preprocessing directives. Added a new test case verifying the skipped_token
151  hook gets called reproducibly (t_2_020.cpp).
152- Fixed a problem with the pp hooks 'expanding_object_like_macro' and
153  'expanding_function_like_macro', which when returning true were stopping all
154  preprocessing instead of just inhibiting the expansion of the macro.
155- Fixed a duplicated call to the pp hook skipped_token for preprocessing
156  directives inside inactive conditional branches.
157- Changing exception handling to fix clang++ regression errors.
158- Replaced assert() with BOOST_ASSERT to pacify the Boost inspect tool.
159
160Boost V1.44.0
161- V2.0.6
162- Added information about the file type to iteration context. This can be
163  either main_file, system_header, or user_header depending whether the handled
164  file is the main file to preprocess, a include file opened from `#include <>`,
165  or a include file opened from `#include ""`.
166- Added support for new Boost visibility macros. Properly exported all
167  exceptions, etc.
168
169Boost V1.43.0
170- V2.0.5
171- Fixed the wave driver application to strip leading and trailing whitespace
172  from macro names specified on the command line using -U.
173- Fixed line number counting for lines containing nothing but whitespace
174  followed by a C++ comment if the next line is a pp directive.
175- Fixed emitting of a #line directive after returned from an include file.
176- A couple of fixes allowing to properly report the current line number in
177  #line directives for different whitespace preserve modes (see --preserve/-p).
178- Added new preprocessing hook: emit_line_directive, allowing to customize the
179  format of the generated #line directive.
180- Changed --line/-l command line option of the wave driver application to
181  accept 0, 1, and 2 as options. The option values 0 and 1 behave as before
182  (disable/enable the generation of #line directives), while the option value 2
183  will generate the #line directive using the relative filename (instead of the
184  absolute filename emitted from option 1). The default option is value 1.
185- Added new example: emit_custom_line_directives, demonstrating the use of the
186  new preprocessing hook.
187- Added new preprocessing hook: found_unknown_directive, which is being invoked
188  whenever an unknown preprocessor directive (i.e. '#' followed by some
189  identifier) is detected. It allows to interpret the directive and to provide
190  some replacement text.
191- Added new example: custom_directives demonstrating the usage of the new
192  preprocessing hook.
193- Fixed #4113: cpp_lexer does not handle qualified backslashes correctly.
194- Fixed #3106: wave on VS2010 beta compiler generates error.
195
196Boost V1.42.0
197- V2.0.4
198- Fixed Wave for latest changes in multi_pass iterator.
199
200Boost V1.41.0
201- V2.0.3
202- Switched to Re2C V0.13.5
203- Fixed --list_includes/-l command line option of the wave driver tool to
204  correctly indent the generated list of included files.
205- Finally fixed all remaining examples. Everything seems to work fine now.
206- Specifying a custom token type now works as expected. The new lexer interface
207  introduced in V2.0 broke this part.
208- Removed old code related to pre Boost V1.31 (related to V1 of iterator
209  library).
210- Added a new commandline option --macrocounts/-c to the Wave driver application
211  which lists all macro invocation counts to an optionally specified file
212  (default is cout).
213- Fixed compilation problems caused by recent changes to the multi_pass iterator
214  from Spirit V2.1.
215- Added the new preprocessing hooks detected_pragma_once() and
216  detected_include_guard() which are getting called whenever either a #pragma
217  once has been detected or if the include guard heuristics detected an
218  include guard for a particular include file.
219- Added a new command line option to the wave driver tool: --listguards/-g
220  allowing to trace all include files which are either contain a #pragma once
221  or contain include guards.
222- Started to elminate g++ struct aliasing warnings (more to fix, mostly in
223  flex_string).
224
225Boost V1.40.0
226- V2.0.2
227- Fixed a long standing race condition inhibiting to use Wave in multi threaded
228  environments.
229- Incorporated the changes from latest version of the flex_string class (#2946).
230- Fixed another race condition triggering problems using Wave in multi-threaded
231  environments.
232
233Boost V1.39.0
234- V2.0.1
235- Fixed Wave to compile with BOOST_FILESYSTEM_NO_DEPRECATED defined (i.e. the
236  library doesn't use the deprecated filesystem interface anymore).
237
238Boost V1.37.0
239- Updated examples to reflect the recent changes in the used multi_pass
240  iterator.
241- Fixed documentation links still pointing to the old Boost CVS (thanks to
242  J�rgen Hunold for providing the patch).
243
244Boost V1.36.0
245- Wave Version 2.0 is a new major release introducing some breaking API changes,
246  preventing it to be used with Boost versions earlier than V1.36.0. The API
247  and hook interface have been streamlined for more consistency. See the
248  documentation for more details.
249
250- Added an additional template parameter to the context object, allowing to
251  specify any possibly derived type. This change propagates to the preprocessing
252  hooks, which now get passed the most derived context type as its first
253  argument allowing to access protected members in the original context type.
254  This fixes ticket #1752.
255- Fixed a problem during parsing of #pragma wave directive, where the value
256  sequence contained a closing parenthesis. This caused a premature end of the
257  pragma value parsing.
258- Fixed handling of support_option_single_line, which was ignored under certain
259  circumstances.
260- Fixed ticket #1766: Wrong evaluation of conditional preprocessor directives
261  with predefined macros __FILE__, __LINE__ and __INCLUDE_LEVEL__. This bug
262  triggered an error in constructs like #ifndef __FILE__. Thanks to Daniel
263  Wadehn for reporting and supplying a patch. Added corresponding regression
264  test: t_2_018.cpp.
265- Fixed a bug which reported a valid macro redefinition as invalid if the macro
266  replacement text referred to a second or higher parameter of this macro.
267- Fixed a problem in the wave tool to allow two errors to occur while
268  preprocessing two consecutive tokens.
269- Adjusted Spirit header includes to point to conform to the new directory
270  structure, removed support for Spirit versions earlier than V1.7.
271- Started to migrate to new multi_pass iterators from Spirit V2.0.
272
273Boost V1.35.0
274- Wave Version 1.3
275- Changed the return value of the 'evaluated_conditional_expression()' pp hook
276  to 'bool' allowing to force Wave to re-evaluate the current conditional
277  expression. This was suggested by Felipe Magno de Almeida.
278- Added a wave::context object as first parameter to all pp hook functions.
279  This is an interface compatibility breaking change. The new pp-hooks can be
280  disabled by defining the BOOST_WAVE_USE_DEPRECIATED_PREPROCESSING_HOOKS
281  compile time constant to something not equal to zero. By default this
282  constant will be defined to zero for Boost V1.35.0 and newer, switching to
283  the new interface by default.
284- Added optional support for the import keyword (needed for the C++ module
285  proposal). The identifier import will be recognized as a keyword, if
286  the compile time constant BOOST_WAVE_SUPPORT_IMPORT_KEYWORD is defined to
287  something not equal zero.
288- Added new preprocessing hook functions: found_error_directive() and
289  found_warning_directive() to be called when #error/#warning directives are
290  encountered. This was suggested by Andreas S�bj�rnsen.
291- Added a new sample to Wave: hannibal, a partial C++ parser implementation
292  initially written by Danny Havenith (http://havenith-verlinden.nl/hannibal/)
293  who agreed to add this here. Thanks!
294- Added new preprocessing hook function: found_line_directive() to be called
295  when a #line directive is encountered. This was suggested by Andreas
296  S�bj�rnsen.
297- Improved command line handling for the wave applet.
298- Incorporated latest bug fixes for the Hannibal sample provided by Danny
299  Havenith.
300- Added loading of a wave.cfg file from anywhere up the filesystem hierarchy
301  starting from the main input file for the wave driver applet up to the
302  root of the file system.
303- Added support_option_emit_pragma_directive to allow to control at runtime,
304  whether unknown #pragma directives should be emitted or not. To maintain
305  compatibility with earlier versions this option is by default on if the
306  compile time constant BOOST_WAVE_EMIT_PRAGMA_DIRECTIVES was defined to
307  be not equal to zero and it is off otherwise.
308- Enabled XML serialization support.
309- Added the throw_exception preprocessing hook, which gets called for every
310  occurring error (whenever an exception would have been thrown). The default
311  of this new hook function is to throw the corresponding exception, which
312  reproduces the old behavior.
313- Implemented a new preprocessing hook: generated_token(), which get's called
314  whenever a token is about to be returned form the library. This function may
315  be used to alter the token before it gets returned to the calling
316  application.
317- Added a new sample 'real_positions' demonstrating the new generated_token()
318  preprocessing hook and showing how to use Wave with a new token type without
319  using a new lexer type.
320- Factored out the pure lex_input_interface to simplify writing different lexer
321  types for Wave.
322- Added the token_statistics sample showing how to use Xpressive to build a
323  lexer for Wave.
324- Changed the list_includes sample to use a lexer which is based on the lexertl
325  library written by Ben Hanson (http://www.benhanson.net/lexertl.html).
326- Added a new support_option: insert_whitespace, allowing to switch off
327  whitespace insertion which is normally (by default) in place to disambiugate
328  C++ tokens, which would otherwise form different tokens in the output.
329- Added a new commandline option to the Wave applet: --disambiguate, allowing
330  to control whitespace insertion. The default value for this option is
331  --disambiguate=1, resembling the previous behaviour. Specifying the option
332  --disambiguate=0 allows to suppress whitespace insertion alltogether.
333- Added pragma option values push and pop to the line, preserve and output
334  options allowing to store and restore the current option. The syntax is:
335    #pragma wave options(<option>: push) and
336    #pragma wave options(<option>: pop)
337  where <option> may be line, preserve or output. Thanks to Eric Niebler for
338  suggesting this feature.
339- Added the possibility to use static pre-compiled DFA tables for the lexertl
340  based lexer.
341- Incorporated the changes from Andrei's latest version of the flex_string
342  class.
343- Added the is_macro_defined(name) function to the context object as described
344  in the documentation. This function is usable with any string type compatible
345  with std::string.
346- Changed behavior of the --force_include functionality, which now looks for
347  the file to be (force-)included in the current directory first.
348- Switched to Re2C V0.11.2
349- Added const specifiers to some of the context member functions.
350- Fixed a problem in the SLex C++ lexer (cpp_tokens example).
351- Fixed a runtime problem in the Re2C generated lexers when fed with
352  empty input files (thanks to Leo Davis for reporting and providing a patch).
353- Added the is_eoi() function to token classes, returning true if the token
354  has been initialized to be the end of input token (T_EOI) (thanks to Ovanes
355  Markarian for suggesting this).
356- Added missing #includes <cstring>, <cstdlib>, and <new> to flex_string.hpp.
357- Added missing #include <climits> to cpp_chlit_grammar.hpp.
358- Changed found_include_directive hook function to return a bool indicating,
359  whether the file should be included (true) or skipped (false). Thanks to
360  Felipe Magno de Almeida for suggesting this feature.
361- Added code to the wave driver applet ignoring a #import directive (the whole
362  directive is passed through to the output) whenever the pp constant
363  BOOST_WAVE_SUPPORT_MS_EXTENSIONS is defined to something not equal to zero.
364- Fixed the wave driver applet to correctly continue after a error or warning.
365- Added a macro introspection facility allowing to iterate on all defined macro
366  names.
367- Added a new commandline option --macronames/-m to the Wave driver application
368  which lists all defined macros and their definitions to an optionally
369  specified file (default is cout).
370- Fixed configuration to take into account thread related build settings.
371- Added the BOOST_WAVE_SUPPORT_LONGLONG_INTEGER_LITERALS pp constant allowing
372  to recognize large integer literals (larger in size than long/unsigned long)
373  even if these do not have a 'll' suffix. This pp constant is effective only,
374  if the target platform supports long long integers (BOOST_HAS_LONG_LONG is
375  defined).
376- The following preprocessing hooks now return a boolean value, which when
377  returning 'true' cause the Wave library to skip the execution of the related
378  preprocessing action:
379    . found_directive: allows to skip the whole directive it is called for
380    . expanding_object_like_macro: allows to skip expansion of the given object
381        like macro, the macro symbol is copied to the output
382    . expanding_function_like_macro: allows to skip the expansion of the given
383        function like macro, the whole macro invocation (including all
384        macro invocation parameters) are copied to the output without any
385        further processing.
386- Changed the interpretation of the return value of the found_include_directive
387  preprocessing hook: a return value of 'false' now processes the file
388  to be included normally and a return value of 'true' now skips the processing
389  of the include file directive (the file doesn't get included).
390  This change was necessary to make the return values of the preprocessing
391  hooks consistent. Now return 'false' generally means: normal execution and
392  return 'true' generally means: skip execution of the corresponding
393  preprocessor action.
394- Fixed compilation problems on gcc, fixed ambiguity with boost code (detail
395  namespace was ambigious).
396- Fixed predefined macro support to be thread safe.
397- Added missing file to real_positions example. Thanks to Ludovic Aubert for
398  spotting the problem.
399- Unterminated C++/C comment diagnostics are now a warning and not an error
400  anymore.
401- Applied patch provided by Jens Seidel making sure every header compiles on
402  its own.
403- Updates to the documentation.
404- Fixed a problem in flex_string::compare() (#include_next was non-functional).
405- Fixed a bug in the pp hook expanding_function_like_macro(), where the seqend
406  parameter was set to the first token after the closing parenthesis instead of
407  pointing at it.
408- Added the BOOST_WAVE_SUPPORT_THREADING allowing to explicitly control
409  whether the Wave library is built with threading support enabled. If not
410  defined the build settings will be picked up from the Boost build environment
411  (BOOST_HAS_THREADS).
412- Fixed a whitespace insertion glitch, where whitespace got inserted
413  unconditionally between two operators even if one of these was a comma.
414- Fixed #line directive after a macro invocation containing newlines to
415  correctly reference the line number.
416- Positions of macros defined on the command line now get properly reported as
417  "<command line>":1:...
418- Added testing of the preprocessor hooks.
419
420Boost V1.34.0
421- Wave Version 1.2.4
422- Added the possibility to explicitly enable/disable the generation of #line
423  directives. Added a corresponding commandline argument to the Wave driver
424  tool (--line/-L) which takes either 0 or 1 as its parameter.
425- Added support for #pragma wave option(command: value) directives, which
426  supports the following commands:
427   . #pragma wave option(line: [0|1])
428        Enable/disable generation of #line directives
429   . #pragma wave option(preserve: [0|1|2])
430        Control whitespace preservation
431   . #pragma wave option(output: ["filename" | null | default])
432        Redirect output to the given file (or no output, if 'null' is specified,
433        or output to the file as given on the command line, if 'default' is
434        specified).
435        The filename is resolved relative to the directory of the processed
436        file.
437  These new #pragma directives are implemented in the Wave driver tool only.
438  It is possible to combine several options in one #pragma directive, i.e.
439  #pragma wave option(line: 0, preserve: 2).
440- Changed the signature of the may_skip_whitespace() preprocessing hook to
441  additionally take the preprocessing context as its first parameter.
442- Added the possibility to the Wave tool to disable initial output by
443  specifying a '-' as the output file. This is useful for syntax checks only or
444  in conjunction with the #pragma wave option(output: ...) to restrict the
445  generated output.
446- Improved error reporting in the Wave tool on bad output file stream state.
447- Switched to Re2C V0.10.0
448- Fixed some of the VC7.1 /W4 warnings.
449- The Wave tool now creates the directory hierarchy of output files as needed.
450- Applied some optimization, which causes skipping of the parsing for almost
451  all preprocessor directives when the if block status is false. This gains
452  upto 10-20% in speed for average applications.
453- Added error diagnostic for #elif without matching #if, which was missing
454  under certain circumstances.
455- Avoided the evaluation of #elif expressions if one of the previous #if/#elif
456  blocks of the same level was true. This gains upto another 5% of speed for
457  average applications.
458- The MS specific integer suffix 'i64' is now correctly supported by the Re2C
459  and SLex lexer components (only when BOOST_WAVE_SUPPORT_MS_EXTENSIONS is
460  defined during compilation).
461- Changed the Wave tool to print the column number of an error/warning along
462  with the line number. The new format is: 'filename:line:column: error text'.
463- It is now possible to recover from the unbalanced #if/#endif statement
464  warning in a proper way.
465- The Wave library now automaticaly recognizes include guards in headers files
466  and uses this information to avoid opening these header files more than once.
467  This speeds up things by upto 10-20% depending on the concrete include files.
468- Fixed the failing test t_6_023.cpp. Error reporting for illformed #else
469  directives was broken (because of some recent changes).
470- Fixed the failing test t_5_007.cpp. This was caused by the automatic include
471  guard detection, which prevented the second inclusion of the specified
472  include file the test was relying on.
473- Added the possibility to switch off the automatic include guard detection.
474- Added a new command line option to the Wave tool: --noguard/-G, which
475  disables the automatic include guard detection.
476- Now a header with include guards will be included correctly for a second time
477  after its include guard symbol gets undefined.
478- Added the generating platform to Wave's full version string.
479- Made the Wave tool fully interactive when started with input from stdin and
480  and output to stdout. In this mode the Wave tool preprocesses the input
481  line by line and not only after receiving the full input as normally.
482- Added serialization support for the wave::context object, which stores
483  all information about defined macros and all #pragma once header information.
484- Added the command line option --state (-s) to the Wave tool, which tries to
485  load the serialized information from the file given as the argument to
486  --state and save the state information at the end to the same file.
487  This option is available in interactive mode only.
488- Added possibility to verify the compatibility of the configuration used
489  during compilation of the Wave library with the config info used for the
490  application. Added a corresponding test to the Wave tool.
491- Added a new predefined macro __WAVE_CONFIG__ which expands to an integer
492  literal containg the configuration information the library was compiled
493  with.
494- Added proper versioning support to the serialization of state.
495- Fixed the macro tracing information to contain the column numbers of the macro
496  definitions as well (the format used is the same as for error messages).
497- Fixed a memory leak in the flex_string copy on write code (thanks to Tobias
498  Schwinger for reporting this bug).
499- Fixed a memory corruption bug in the Re2C scanner buffer management code
500  (thanks to Andreas S�bj�rnsen for spotting the bug).
501- Fixed a major performance bottleneck in the lex_token class. This speeds up
502  Wave for upto another 20-40% depending on the amount of macro expansions to
503  perform.
504- Added the BOOST_SPIRIT_USE_BOOST_ALLOCATOR_FOR_TREES and the
505  BOOST_SPIRIT_USE_LIST_FOR_TREES Spirit configration constants to the
506  wave_config.hpp to allow to fine tune the generated Spirit tree code. VC7.1
507  gives best results when both are defined.
508- Fixed a memory corruption bug triggered by a possible dangling reference.
509- Fixed Wave tools startup crash when compiled with VC8.
510- Added the name of the generating compiler (BOOST_COMPILER) to the full
511  Wave version info.
512- Fixed all Jamfile.v2 to correctly disable RTTI for VC7.1.
513- Added #pragma message("...") to be optionally supported by the Wave library.
514  This may be enabled by defining the BOOST_WAVE_SUPPORT_PRAGMA_MESSAGE pp
515  constant to some value different from zero.
516- Fixed a couple of typos in the file cpp.cpp preventing it to compile on
517  gcc 4.1.0 (thanks to Richard Guenther for reporting these).
518- Richard Guenther fixed another buffer overrun problem in the Re2C scanner.
519- Fixed Jamfile.v2 files for all sample applications.
520- Fixed a bug which lead to reporting of an illegal preprocessing directive
521  inside not-evaluated conditional blocks under certain circumstances (thanks
522  to Tobias Schwinger for reporting).
523- Fixed '#define true ...', '#define false ...' and other constructs, i.e. the
524  usage of the boolean keywords as identifiers during the preprocessing. Added
525  a corresponding test case (t_9_017.cpp). Thanks to Andreas S�bj�rnsen for
526  reporting.
527- Corrected the Jamfile[.v2] of the waveidl sample to refer to correct file
528  names (thanks to Juergen Hunold for submitting a patch).
529- Fixed a bug which prevented the main iterator from returning a T_EOF token
530  at the overall end of the input.
531- Fixed a problem, where non-evaluated #elif directives never got passed to the
532  skippen_token() pp hook (thanks to Andreas S�bj�rnsen for reporting).
533- Fixed a problem in the get_tokenname() function.
534- Added a missing #define BOOST_WAVE_SOURCE 1 to the wave_config_constant.cpp
535  file.
536- Fixed exception specifications to catch all exceptions by const&.
537- Fixed predefined macros to appear to be defined at a position referring to
538  a file named "<built-in>". Thanks to Andreas S�bj�rnsen for reporting.
539- Fixed the Re2C lexer not to segfault on empty files anymore.
540- Stripped leading and trailing whitespace for all lines in a config file (Wave
541  driver tool).
542- Fixed RTTI build issue for VC7.1/bjam --v2 (thanks to Rene Rivera for
543  submitting a patch for the Wave Jamfile.v2).
544- Fixed certain problems reported by the Boost inspection tool.
545- Fixed a couple of SunPro5.8 warnings.
546- Fixed a bug resulting in a crash if a macro was redefined with a shorter
547  expansion list as it was defined initially. Added a corresponding test case.
548- Fixed a bug causing an infinite loop when there was a missing endif in the
549  main preprocessed file.
550- Improved error recovery for illegal preprocessing directive errors.
551- Improved error handling and error recovery for conditional expressions
552  (#if/#elif expressions).
553- Wave now passes 160 out of 161 tests from the MCPP V2.6.1 validation
554  testsuite!
555- Added new warning for invalid #line number and filename arguments
556- Improved error diagnostics for invalid #line directives containing arbitrary
557  tokens after at the end of the line.
558- Improved error handling wrt the misuse of the __VA_ARG__ token in macro
559  definitions.
560- The warning, that a file is not terminated by a newline is now issued for all
561  files, not only for the main file (as previous).
562- Added a couple of new test cases to verify various diagnostics.
563- Fixed wave applet not to report missing #endif's when in interactive mode.
564- Cleaned up the Re2C lexer code.
565- Fixed a bug, where a empty line followed by an arbitrary token and followed
566  by a preprocessing directive interpreted the preprcessing directive as if it
567  were the first non-whitespace token on the line. This error occurred only
568  if the #line directive generation was suppressed. Thanks to Joan Grant for
569  reporting this problem.
570- Fixed a problem in the Wave applet which prevented the correct recognition of
571  Windows file paths in a configuration file, if this path was enclosed in
572  quotes.
573- Extended the copyright notice to include the year 2007.
574- Fixed a problem in preserve=1 mode, when a C style comment triggered the
575  generation of a #line directive.
576- Worked around a linker issue for the True64/CXX compiler, complaining about
577  multiple defined symbols when using the flex_string class.
578- Added missing documentation for the context::get_macro_definition function.
579
580Sat Feb 18 2005
581- Version 1.2.3
582- Added a missing throw() specification to the function
583  cpp_exception::get_related_name().
584- Fix Boost bug ([ boost-Bugs-1395857 ] wave redefines BSIZE).
585- Added missing calls to the skipped_token() preprocessing hook which wasn't
586  called for pp directives inside disabled #if blocks.
587- Made the context<> type noncopyable.
588- Introduced the --extended/-x command line option to the wave driver
589  executable, which enables the #pragma wave system() directive. This directive
590  is now disabled by default because it may cause a potential security threat.
591- Changed the what() function of the macro_handling_exception class, which now
592  correctly returns the name of the exception type itself.
593- Added a diagnostic message to the wave driver executable, which is issued
594  whenever a #pragma wave system() directive is found, but the -x (--extended)
595  command line argument was not given.
596- Fixed long integer suffix to be allowed to be mixed case (1Ll or 2lL).
597- Fixed the BOOST_PP_CAT(1e, -1) pp-token bug. Wave now correctly recognizes
598  pp-number tokens, which are converted to C++ tokens right before they are
599  returned from the library.
600- Moved the implementation of the token_id query functions (get_token_name(),
601  get_token_value()) to a separate source file.
602- Fixed a bug, which prevented to prefer pp-numbers in files preprocessed as
603  a result of #include directives.
604- Fixed a bug, which prevented to open #include'd files specified by an
605  absolute path.
606- Fixed a problem in the expression parser value type.
607- Fixed a dynaload compilation problem with VC7.1 of the re2c lexer tests.
608
609Sat Dec 24 13:33:53 CST 2005
610- Version 1.2.2
611- Added three new preprocessing hooks: 'found_directive', 'skipped_token' and
612  'evaluated_conditional_expression' (thanks to Andreas S�bj�rnsen for the
613  suggestions).
614- Removed hook forwarding functions in the context_type.
615- Added missing include_next case branches for get_directivename() function.
616- Added new sample: advanced_hooks.
617- Fixed a possible buffer overflow in the cpplexer and cpp exception classes.
618- Made the cpp_grammar thread safe.
619- Removed the need for the get_directivename() function. Fixed typos in the
620  predefined token table.
621- Removed assertions from get_token_name() and get_token_value() and replaced
622  these with more meaningful code.
623- Added the BOOST_WAVE_USE_STRICT_LEXER configuration constant which allows to
624  decide, whether the '$' character will be recognized as a part of identifiers
625  or not (the default is BOOST_WAVE_USE_STRICT_LEXER == 0, i.e. '$' will be
626  recognized as part of identifiers).
627- Added the possibility to testwave to extract a tagged comment based on a
628  preprocessor constant (testwave V0.4.0).
629- Made the predefined_macros_grammar thread safe.
630- Added dll support for the generated Wave libraries.
631- Added the const_iterator based exlicit instantiations for the Re2C lexer to
632  the built Wave library and dll.
633- Added the whitespace handling policy to the context object. This actually is
634  no separate policy, it's a new preprocessing hook allowing to decide, whether
635  a concrete token has to be skipped.
636- Changed the --preserve option of the wave tool to take a single integer
637  argument (0: no whitespace is preserved, 1: only comments are preserved,
638  2: all whitespace is preserved)
639- Edited the command line option descriptions of the wave driver.
640- Fixed broken tags in documentation (magically inserted by DreamWeaver).
641- Merged the new whitespace_handling policy with the existing preprocessing
642  hooks. The name of the new preprocessing hook ist may_skip_whitespace().
643- Fixed compatibility issues for CW9.4 in the Wave test aplication.
644- Added get_errorcode() member to the wave exception classes allowing to
645  get back the reason for the exception.
646- Added boost::wave::is_recoverable(cpp_exception const&) alowing to decide,
647  whether it is possible to continue after a cpp_exception has been thrown.
648  This is a temporary hack to overcome the current limitation of the library
649  not allowing to do generic error recovery. It allows to recover from 75% of
650  the generated errors types.
651- The --timer command line option for the Wave driver now prints the elapsed
652  time correctly even if a preprcessing error occurred.
653- Fixed an error recovery problem which skipped one token after continuing in
654  case this was a pp directive.
655- Added the --autooutput (-E) option to the Wave driver applet which redirects
656  the generated output to a file named after the input file changing the file
657  extension to '.i'.
658- Changed all throw's to boost::throw_exception.
659- Added the possibility to configure the command keyword for the wave specific
660  #pragma directives. It is now possible to define a string literal via
661  BOOST_WAVE_PRAGMA_COMMAND, which will be recognized and all corresponding
662  #pragmas are dispatched to the interpret_pragma() preprocessing hook.
663  The default value for BOOST_WAVE_PRAGMA_COMMAND is "wave", just to ensure
664  complete backward compatibility.
665- Added missing #pragma warning(pop) directives.
666- Fixed a bug wrt error propagation in the expression parser.
667- Fixed an assertion fired when cpp_token is used to process the quick_start
668  sample.
669- Fixed a (Windows specific) bug which triggered a boost::file_system exception
670  under certain conditions.
671- Switched to Re2C V0.9.11
672- Fixed a problem with the new '-E' (--autooutput) option.
673- Added better error reporting for duplicate macro definitions to the Wave
674  tool. Added the macro_handling_exception type containing the corresponding
675  macro name via the new (virtual) get_related_name() function.
676- Added the get_severity() function to the exceptions thrown by the Wave
677  library.
678- Extended the copyright notice to include the year 2006.
679
680Mon Dec  5 22:05:22 CST 2005
681Boost V1.33.1
682- Version 1.2.1
683- Fixed bug reported as Sourceforge bug 1274584.
684- Switched to Re2C V0.9.9.
685- Fixed a bug where the 'parameters' and 'definition' parameters to the
686  defined_macro callback of the preprocessing hooks were always empty (thanks
687  to Stefan Seefeld for reporting).
688- Fixed missing namespace specifiers in token definition macros (thanks to
689  Jozsef Mihalicza for reporting).
690- Enabled --preserved and --long_long modes by default for the cpp_tokens
691  sample.
692- Newline tokens reported a wrong line number (offset by one) when using the
693  Re2C generated lexer (thanks to Jozsef Mihalicza for pointing this out).
694- Changed file positions to carry 'unsigned int' line and column numbers.
695- Fixed tokens of a generated #line directive to carry the correct column
696  numbers.
697- Tokens now contain the correct filename, line and column numbers even if
698  a #line directive was encountered.
699- Fixed wrong line numbering in reference comments of the tests t_5_002.cpp and
700  t_5_035.cpp.
701- Made sure, that preprocessor expression errors get ignored for 'passive'
702  #elif branches.
703- Fixed an issue reported by the gcc debug stl.
704- Added the <vc-7_1-stlport><*><rtti>off directive to all of the V1 Jamfiles.
705
706Wed Aug 17 20:21:00 CST 2005
707Boost V1.33.0
708Version 1.2
709- Fixed name clash wrt T_DIVIDE on FreeBSD.
710- Fixed documentation of the different language_support flags.
711- The support for long long suffixes is no longer bound to the variadics mode,
712  it has to be enabled by the new long_long mode (default in C99).
713- Fixed compilation if BOOST_WAVE_DUMP_PARSE_TREE is defined.
714- Fixed lexer error message wrt long_long mode.
715- Stefan Seefeld fixed a bug in the lexer, where include_next was assumed for
716  included files containg a "include_" in their name.
717- Fixed some trigraph token id's in the lexers.
718- Added column information to the re2c generated lexer.
719- Added tests for the different lexers.
720- Fixed the found_include_directive preprocessing hook to carry the information
721  about #include_next directives as well.
722- Separated the different lexer tests.
723- Fixed a bug in the whitespace eater.
724- Fixed a bug where Wave emitted the found C++ comments in --preserve mode even
725  if these were found inside of disabled #if/#endif blocks.
726- Removed the function local static grammars to avoid possible raise conditions
727  and to make CW8.3 happy.
728- Unified lexer interface, adjusted namespaces.
729- Added lexer testcases to the regression tests.
730- Fixed test cases to scale to 64 bit platforms.
731- Disabled the MS specific extensions in the lexer tests in a platform related
732  way.
733- Added special handling of the eof tokens inside the lexer iterator classes
734  for Comeau.
735- Applied a workaround proposed by David Abrahams to make the slex lexer work
736  on the CodeWarrior platforms.
737
738Sun May  8 17:22:59 WEDT 2005
739Version 1.1.17
740- Added ill_formed_character_literal and ill_formed_integer_literal errors.
741- Improved error handling and diagnostics for integer overflow in #if/#elif
742  expressions.
743- Fixed a bug in the testwave application which prevented the correct
744  recognition of expected errors under certain circumstances.
745- Fixed a portability problem (for gcc 3.3.x) in the testwave application.
746- Enforced that #if/#endif are balanced file wise.
747- Changed the command line arguments for the Wave testrun to use absolute
748  directories.
749- Changed the test application to return a value != zero if one of the given
750  config files were not found.
751- Fixed a command line parsing problem caused by a change in the parameter
752  handling inside in the program_options library.
753- Switched to the most recent version of re2c (V0.9.7.dev).
754- Fixed a como compilation error and several como --a warnings.
755- The T_EOF token doesn't carry the value of the previous token anymore.
756- Added operator==() to the token classes to fix the ambiguity error reported
757  by the True64 compiler.
758- Improved the error message, when empty arguments are used in pure C++ mode.
759- Added character literal out of range testing and an additional corresponding
760  error message.
761- Fixed parsing of long character literals (such as '\x1234').
762- Fixed almost all problems diagnosed by the Boost inspection report.
763- Several fixes to make the True64 compiler happy.
764- Added the long long suffix handling to the C99 mode (LL/ll).
765- Fixed a bug in the slex regex specifications.
766
767Thu Apr  7 10:07:45 WEDT 2005
768Version 1.1.16
769- Fixed a bug in the white space eating component, which prevented a C++
770  comment to be suppressed if it followed after another whitespace.
771- Fixed the inconsistencies between the documentation and the behaviour wrt the
772  different include search paths. See the Wave driver docs for details of how
773  the '-I', '-I-', and '-S' options work.
774- Allowed to specify more than one config file ('@' syntax) on the command line
775  of the wave driver executable.
776- Changed copyrights in all files to reflect the acceptance of Wave into Boost.
777- Unknown preprocessing directives were not recognised as such anymore.
778- If comments shouldn't be preserved all C++ comments are replaced by newline
779  tokens (instead of beeing igored completely).
780- Fixed a bug in the white space eater component.
781- Fixed a bug which reported wrong line numbers for error encountered during
782  retokenisation (concatination).
783- Fixed a bug in the unescaping code.
784- Fixed a compilation error of the testwave executable (added a missing
785  namespace specifier).
786- Added a missing header to make cpp.re.cpp compile on CW.
787- The predefined macro __BASE_FILE__ now returns a properly escaped file name
788  string.
789- Fixed the function boost::wave::util::impl::unescape_lit().
790- Added the Wave unit test framework. For now it contains about 60 unit tests
791  executed by a special test driver (testwave).
792- Added the '$F' replacement string to the testwave application. This allows
793  to handle file paths sensitive comparison of the expected and real results.
794- Fixed a minor problem in the whitespace eating component.
795- Added optional trigraph conversion.
796- Changed all size_t, time_t etc. to std::size_t, std::time_t etc (for CW).
797- If the comments should not be preserved every C comment containing at minimum
798  one newline is now converted to a newline token.
799- Added the lexed_tokens sample.
800- Fixed warnings and errors reported by the CodeWarrior compiler.
801- Added the '$V' replacement string to the testwave application. It expands to
802  the current BOOST_LIB_VERSION.
803- Diagnosed the attempt to redefine the alternative operators as and, or etc.
804- Improved error handling.
805- Disabled the flex_string class for VC7, enabled to fallback to std::string
806  for this compiler.
807- Renamed files to comply with the Boost rules.
808- Added the first part of the MCPP validation suite to the Wave unit tests.
809- Added even more missing "using namespace std;" statements for functions from
810  the C runtime library. The Wave test suite now contains more than 100 unit
811  tests.
812- Added the $P/$P(basename) replacement string to the testwave application
813  which expands to the full path of the current file ($P) or to the current
814  directory/basename ($P(basename)).
815- Fixed a bunch of portability problmes revealed by the regression tests on
816  different platforms. Thanks to Stefan Slapeda for his support to make it work
817  on the cw-9_4 toolset (win32).
818
819Tue Mar 22 14:52:45 WEST 2005
820Version 1.1.15
821- Fixed a bug where the complete set of C99 predefined macros were pre-defined
822  when in C++ mode and variadics were enabled.
823- When in variadics or C99 mode the __BASE_FILE__ predefined macro expanded to
824  <Unknown>.
825- Added the --listincludes option to the Wave driver executable which allows to
826  log the file names of the include files opened.
827- Fixed a gcc warning in token_cache.hpp (unused variable end).
828- Changed the logic behind #include_next. It now starts searching with the
829  next directory after the directory the current file (the file containing the
830  #include_next directive) is located in.
831- Changed the signature of the undefined_macro preprocessing hook to take the
832  token itself and not the macro name only. This is important to pass the full
833  context information about the position of the #undef directive to the
834  user provided hook (thanks to Stefan Seefeld for pointing that out).
835- Fixed several broken links in the Context Policy topic.
836- Fixed a bug in the handling of the #include_next directive inside of
837  non-evaluated #if blocks.
838- Fixed a bug in the #include_next handling code (thanks to Stefan Seefeld).
839- Changed the signature of the opened_include_file() preprocessing hook which
840  now receives not only the absolute file name of the openend include file but
841  additionally gets passed the (possibly) relative path of the openend include
842  file. This concrete format of the relative path depends on the format of the
843  include search directory given to the library.
844- Added a new preprocessing hook 'found_include_directive()' which gets called
845  for every #include directive (even for those where the file to include
846  doesn't exist) and which gets passed the (expanded) token sequence found
847  after the #include directive token.
848- The file names passed to the preprocessing hooks are now normalised.
849- Changed the opened_include_file() preprocessing hook to receive the correct
850  relative path even if the included file was found in the current directory.
851- Fixed a bug which reported 'defined(or)' as invalid (similarly all the other
852  alternative bit operation token types).
853- Fixed a bug which prevented to define variadic macros from the command line.
854- Added a 'preserve comments' mode to preserve the comments in the input stream
855  not inserted into macro definitions.
856- Added a new --preserve (-p) command line switch to the wave driver
857  application to allow comments to be preserved in the generated output stream.
858
859Mon Feb 21 09:30:04 WEST 2005
860Version 1.1.14 (Fixes in response to the Boost review)
861
862Wave was accepted into Boost!
863
864With special thanks to Tom Brinkman, who volunteered to be the review manager.
865
866With thanks to David Abrahams, Beman Dewes, Reece Dunn, Larry Evans,
867Doug Gregor, Joel de Guzman, Baptiste Lepilleur, Andy Little, Paul Mensonides,
868Dan Nuffer, Andreas Pokorny, Vladimir Prus, Gennadiy Rozental, Michiel Salters,
869Jonathan Turkanis, Chris Uzdavinis, Pavel Vozenilek, Michael Walter for bug
870reports, fixes and hints.
871
872- Added support for the MS extensions #region and #endregion, which simply get
873  ignored by Wave. The support for these is enabled only, when the pp constant
874  BOOST_WAVE_SUPPORT_MS_EXTENSIONS is defined. Otherwise these get flagged as
875  an illegal preprocessor directive (as before).
876- Fixed a problem, where the replacement text for a #pragma directive got lost
877  if this directive was on the last line of a processed (include-)file.
878- Changed the default value for BOOST_WAVE_SUPPORT_MS_EXTENSIONS for non-
879  Windows systems to zero.
880- Updated outdated external links in the documentation.
881- Fixed certain grammatical and stylistic quirks in the documentation.
882- Fixed a problem in libs/wave/build/Jamfile.v2 (as reported by Larry Evans).
883  Fixed the Jamfile.v2 in the samples directories accordingly.
884- Added the '<toolset>vc-7_1:<rtti>off' to all Jamfile.v2 files to adjust for
885  the internal buffer overflow bug in the VC7.1 compiler (reported by Joel de
886  Guzman).
887- Changed the '<toolset>vc-7_1:<rtti>off' to '<toolset>vc-7.1:<rtti>off' as
888  required by the Boost.Build.v2 library (suggested by Vladimir Prus).
889- Finally fixed the Jamfile.v2 file (after a suggestion from Reece Dunn)
890- Fixed the column number reported for tokens for Slex lexer based
891  configurations (reported by Baptiste Lepilleur).
892- Added the __BASE_FILE__ predefined macro, which contains a string literal
893  of the main file name to preprocess (the one the context<> template was
894  created with). (suggested by Pavel Vozenilek)
895- Used the boost::reverse_iterator instead of the std::reverse_iterator
896  for the flex_string class to allow compilation of Wave with VC7.0
897  (as suggested by Reece Dunn).
898- Fixed a problem in the include_path template, which throwed a
899  boost::filesystem exception whenever a character was used in a file name
900  to include, which is marked as illegal by the default name checker of the
901  boost::filesystem::path.
902
903Version 1.1.13 (Boost review candidate 2, bug fixed version)
904- Fixed a problem, where the context<> template referenced temporary iterator
905  objects from the underlying stream (thanks to Michiel Salters for reporting
906  this).
907- Fixed a bug in the re2c lexer, which allowed to dereference the end iterator
908  of the underlying input stream (thanks to Doug Gregor for pointing this out).
909- Fixed several assertions fired by the iterator checking code of the VC8 stl.
910
911Version 1.1.12 (Boost review candidate)
912- A rough performance analysis showed, that 30% of the time is spent parsing
913  the input for pp directives (cpp_grammar), 35% of the time is spent inside
914  the flex_string code, mainly in the copy constructor and assignment
915  operator, 15% of the time is spent inside the list and vector member
916  functions, 10% is spent for memory allocation but only 1% of the time is
917  spent in the re2c lexer.
918- Identified a performance problem, where the token_cache was instantiated
919  for every created lexer object, but needed to be initialised only once.
920- Added #include <wave_version.hpp> to wave_config.hpp
921- Fixed problems reported by the gcc 3.4.1 compiler.
922- Adjusted Jamfiles for the new toolset names introduced in Boost V1.32.
923
924Version 1.1.11
925- Updated copyrights.
926- Fixed some bugs introduced by the latest refactoring.
927- Tried to fix the expansion of macros, which replacement-list terminates in a
928  partial macro expansion. No success so far.
929
930Version 1.1.10
931- Refactored some of the macro map (macro namespace) code (added comments,
932  splitted into separate files),
933- Fixed some typename errors in cpp_macromap.hpp (thanks to Vladimir Prus).
934- Fixed the BoostBuild V2 Jamfiles (thanks to Vladimir Prus).
935
936Version 1.1.9
937- Moved all of the #pragma wave option(value) operators out of the wavelib into
938  the wave driver program. Removed enable_trace() and trace_flags() policy
939  functions. Renamed trace_policy into context_policy.
940- Added the defined_macro() and undefined_macro() preprocessing hooks to allow
941  easily to build macro cross referencers and such.
942
943Version 1.1.8
944- Replaced the usage of the string::erase() and string::insert() functions,
945  which were the only non-const string member functions used.
946- Token pasting is now well defined in variadics mode (was in C++0x mode only).
947- Changed the timing code in the wave driver to include the parsing of
948  files included by the --forceinclude command line switch.
949- Performance measurements (very informal) [sec], the files are some of the
950  preprocessor specific test cases from Paul Mensonides chaos_pp library.
951
952                        std::string   flex_string   const_string   const_string
953                                                      12 Byte        28 Byte
954    arithmetic.cpp        2.543          1.742         0.951           1.001
955    array.cpp             2.453          1.762         0.951           1.011
956    comparison.cpp        0.560          0.340         0.270           0.280
957    control.cpp           0.590          0.340         0.290           0.300
958    debug.cpp             0.370          0.310         0.190           0.190
959    detection.cpp         0.050          0.060         0.030           0.030
960    extended.cpp          0.370          0.260         0.190           0.190
961    facilities.cpp        0.610          0.340         0.290           0.300
962    iteration.cpp         1.081          0.550         0.410           0.450
963    list.cpp              1.742          1.141         0.811           0.851
964    logical.cpp           0.070          0.200         0.040           0.040
965    punctuation.cpp       0.030          0.080         0.020           0.020
966    repetition.cpp        1.392          0.851         0.650           0.690
967    selection.cpp         0.440          0.270         0.210           0.220
968    slot.cpp              0.680          0.350         0.240           0.270
969    tuple.cpp             0.420          0.240         0.190           0.210
970
971
972Wed Aug 25 13:23:27 WEDT 2004
973Version 1.1.7
974- Branched for Boost Release.
975- Removed several features from the code base:
976  . removed C++0x support
977  . removed TST support
978- Fixed the program_option validator syntax, which has changed since the last
979  update.
980- Removed misleading configuration options from the cpp_config.hpp file,
981  because the application will have to use the same config options as were used
982  during the compilation of the library.
983- Changed the naming convention of typedef'd types in the library. Removed the
984  _t suffix, wherever possible.
985- Updated the documentation to reflect the removal of the C++0x features.
986
987- Changed the licensing scheme to:
988// Copyright 2004 Joe Coder. Distributed under the Boost
989// Software License, Version 1.0. (See accompanying file
990// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
991
992Mon May 24 10:02:47 WEDT 2004
993Version 1.1.6
994- Fixed a incompatibility with the new program_options version.
995
996Version 1.1.5
997Version 1.0.6
998- Fixed a bug, which reported an #include statement as ill formed, if it was
999  followed by an empty C comment only. This was an error in the cpp.re regular
1000  expression for C comments. Additionally, since this change simplified the
1001  Re2C generated lexer a lot it was possible to remove the compiler workaround
1002  for the VC7.1 compiler which prevented the optimization of this lexer.
1003
1004Mon Mar 29 09:36:59 WEDT 2004
1005- Corrected the signature of the main() functions (was main(int, char const*[])).
1006
1007Sun Mar 28 12:55:59 WEDT 2004
1008Version 1.1.4
1009- Fixed a problem, where the first returned token was lost, whenever a
1010  --forceinclude file was given.
1011- Adjusted the Wave driver and the other samples to use the new program_options
1012  library syntax (V1.1.x only).
1013
1014Mon Mar  1 19:14:21 WEST 2004
1015Version 1.1.2
1016Version 1.0.4
1017- Fixed a problem, which does not report an error, if in a #define statement in
1018  between a macro name and its replacement list were no whitespace given.
1019- Fixed a bug, which generated an unexpected exception of the $ character in the
1020  input.
1021- Macro definitions, which differ by whitespace only (one definition contains
1022  whitespace at a certain position, the other definition does not) are correctly
1023  reported as a warning now.
1024- Fixed a problem, where different formal argument names during macro
1025  redefinition were not flagged as a warning.
1026- A wide character string used in a #line directive wasn't flagged as an error.
1027
1028Sun Feb 29 19:10:14 WEST 2004
1029Used the test suite distributed with the mcpp V2.4 preprocessor to fix a bunch
1030of mostly minor issues:
1031- Fixed trigraph backslash followed by a newline handling (??/ \n) in the
1032  re2c (C/C++ and IDL) scanners.
1033- Fixed a digraph/trigraph token type handling problem during macro expansion.
1034- Fixed a digraph/trigraph token type problem during handling of the null
1035  preprocessor directive.
1036- Fixed several signed/unsigned conversion bugs in the expression evaluator.
1037- Fixed the || and && operators in the expression evaluator to stop evaluation,
1038  as only the outcome of the overall expression is determined.
1039- Fixed the expression evaluation engine to detect divide by zero errors.
1040- Fixed a bug with operator || and && arithmetic (the deduced type was wrong).
1041- Fixed a bug with the unary operators ! and - which IN conjunction with an
1042  arithmetic operation yielded A wrong result type.
1043- Fixed a bug, which reported a macro definition as an invalid redefinition, if
1044  it was different from the original definition only by different whitespaces.
1045- Fixed a bug, which reported the redefinition of one of the alternative tokens
1046  as 'and', 'bit_and' etc. as invalid.
1047- Fixed a bug in the character literal parser, which prevented the recognition
1048  of multibyte character literals.
1049
1050- Moved the cpp_token_ids.hpp header into the main wave.hpp header, because the
1051  values defined therein aren't changeable by the user anyway.
1052- Fixed some spelling errors in the documentation (thanks to Rob Stewart).
1053
1054Tue Feb  3 20:20:16 WEST 2004
1055- Fixed the problem, that macro definitions in a config file were flagged as
1056  an error, if there was any whitespace in between the -D and the macro name
1057  (same problem existed for -P).
1058
1059Fri Jan 30 20:28:27 WEST 2004
1060- Fixed a missing boostification in the trace support header.
1061- Added a missing std:: namespace qualification to the list_includes.cpp sample
1062  file.
1063- Fixed line ending problems with the cpp.re and idl.re files.
1064- Added quick_start sample.
1065
1066Sun Jan 25 20:26:45 WEST 2004
1067This version was submitted to Boost as the review candidate (V1.1.0)
1068- Fixed invalid explicit instantiation syntax as reported by the Comeau
1069  compiler.
1070- Added a missing header to flex_string.hpp.
1071
1072Sat Jan 24 19:47:44 WEST 2004
1073- Completely decoupled the used lexer from the preprocessor.
1074- Unfortunately had to change the template interface of the context class. It
1075  now instead of the token type takes the type of the lexer to use.
1076- Reintroduced the cpp_tokens, list_includes and waveidl samples.
1077  . cpp_tokens is based on the SLex lexer
1078  . list_includes shows the usage of the include file tracing capability
1079  . waveidl uses the Re2C based IDL lexer in conjunction with the default token
1080    type
1081
1082Tue Jan 13 20:43:04 WEST 2004
1083- Fixed several compilation issues under linux (gcc 3.2.3, gcc 3.3, gcc 3.3.2,
1084  gcc 3.4, Intel V7.1)
1085- Fixed a compatibility problem with Spirit versions older than V1.7.
1086
1087Mon Jan 12 20:39:50 WEST 2004
1088- Boostified the code base:
1089  . Moved code into namespace boost.
1090  . Prefixed all pp constants with "BOOST_".
1091  . Refactured the directory structure.
1092- Removed IDL mode and SLex lexer from the code base. These will be re-added as
1093  samples.
1094- Changed the Wave configuration system to be more flexible (all
1095     #if defined(BOOST_WAVE_...) changed to #if BOOST_WAVE_... != 0),
1096  which allows to configure the library without changing the code base itself
1097
1098Sat Jan 10 18:17:50 WEST 2004
1099- Incorporated Andrei Alexandrescu's latest changes to the flex_string class,
1100  which resulted in an overall spedd gain of about 5-10%.
1101
1102Wed Jan  7 17:46:45 WEST 2004
1103- Found a major performance hole! The achieved general speedup is about 50-70%.
1104- Added missing old MS specific extensions to the re2c lexer (_based,
1105  _declspec, _cdecl, _fastcall, _stdcall, _inline and _asm).
1106- Added support for #include_next (as implemented by gcc).
1107- Fixed compilation problems with gcc 3.3.1
1108- Avoid to look up in symbol table of a potential macro name twice.
1109- Added the Spirit SLex lexer sample to the Wave source tree, because it was
1110  removed from the Spirit distribution.
1111- Removed the configuration option, which allowed to reverse the names stored
1112  in the symbol tables.
1113- Implemented experimental support for using a TST (ternary search tree) as the
1114  container for the symbol tables.
1115
1116Sun Jan  5 12:30:50     2004
1117- Released V1.0.0
1118
1119Sun Jan  4 00:11:50     2004
1120- Removed tabs from the flex_string.hpp file.
1121- Modified the input_functor.hpp file to sqeeze out some milliseconds at
1122  runtime.
1123- The --timer option now prints the overall elapsed time even if an error
1124  occurred.
1125- Added support for #pragma once.
1126
1127Fri Jan  2 22:58:54     2004
1128- Fixed a bug in the code, which predefines the preprocessor constants.
1129- Fixed a bug in intlit_grammar<> initialisation code.
1130
1131Thu Jan  1 21:15:03     2004
1132- Fixed a bug while predefining a macro with a value through the commmand line.
1133- Fixed a bug, which reported a macro definition as illegal, if the redefined
1134  macro was a function like macro with parameters.
1135- Fixed a bug, if concatenation of two tokens resulted in a C++ comment start
1136  token.
1137
1138Thu Jan  1 15:01:54     2004
1139- Finished license migration.
1140
1141Wed Dec 31 12:23:55     2003
1142- Changed the copyright and licensing policiy to be Boost compatible.
1143
1144Wed Dec 31 12:01:14     2003
1145- Fixed a problem while compiling certain headers from the Microsoft Windows
1146  SDK:
1147        #define CreateWindowA(lpClassName, lpWindowName, dwStyle, x, y,\
1148        nWidth, nHeight, hWndParent, hMenu, hInstance, lpParam)\
1149        CreateWindowExA(0L, lpClassName, lpWindowName, dwStyle, x, y,\
1150        nWidth, nHeight, hWndParent, hMenu, hInstance, lpParam)
1151  where essentially is no whitespace between the parameter list and the macro
1152  replacement list.
1153- Fixed a problem with the MS extension __declspec, which now is recognized
1154  correctly.
1155
1156Sat Dec 27 14:48:29     2003
1157- Fixed remaining problems with assign/assign_a.
1158- Fixed some gcc warnings about signed/unsigned comparision mismatch.
1159
1160Tue Nov 11 20:51:41 WEST 2003
1161- Changed the IDL mode to recognize identifiers only. All keywords (except
1162  'true' and 'false') are returned as identifiers. This allows for easy
1163  extension of the IDL language. The drawback is, that after preprocessing
1164  there needs to be just another lexing stage, which recognizes the keywords.
1165- Fixed a possible problem, when in between a #if/#elif directive and a
1166  subsequent opening parenthesis Wave finds no whitespace:
1167    #if(_WIN_VER >= 0x0500)
1168  is now recognized correctly.
1169  (This problem was pointed out by Porter Schermerhorn).
1170
1171Sun Nov  9 21:05:23 WEST 2003
1172- Started to work on implementation of an IDL lexer for the TAO idl compiler.
1173  . Branched off the Re2C C++ lexer and related files as a starting point for
1174    the new IDL lexer. Added connfiguration means to allow compile time
1175    decision, in which mode to operatoe (C++ or IDL).
1176  . Implemented the Re2C based IDL lexing component.
1177  . Fixed all occurrences of non-IDL tokens (as T_COLON_COLON and T_ELLIPSIS)
1178
1179Sat Nov  8 20:05:52 WEST 2003
1180- Version 1.0.0
1181- Munged the email addresses embedded within the source files.
1182- Adjusted for the new actor names in Spirit (assign_a and append_a).
1183
1184Thu Aug 21 16:54:20     2003
1185- Removed the internally used macro 'countof()' to avoid possible nameclashes
1186  with user code.
1187- Fixed a bug, which prevented the execution of the concatination operator '##'
1188  while expanding object-like macros.
1189
1190Tue Aug  5 10:04:00     2003
1191- Fixed a false assertion, if a #pragma directive started with some whitespace
1192  on the line.
1193- Added the #pragma wave timer() directive to allow rough timings during
1194  processing. This is done on top of a new callback hook for unrecognized
1195  #pragmas, which allows to easily add new pragma commands without changing
1196  the Wave library.
1197- Fixed a bug in the whitespace insertion engine, which prevented the insertion
1198  of a whitespace token in between two consecutive identifier tokens or a
1199  integer literal token followed by an identifier token.
1200- Fixed a bug during macro concatenation, which allowed to concatenate
1201  unrelated tokens from the input stream:
1202    #define CAT(a, b) PRIMITIVE_CAT(a, b)
1203    #define PRIMITIVE_CAT(a, b) a ## b
1204    #define X() B
1205    #define ABC 1
1206    CAT(A, X() C) // AB C
1207    CAT(A, X()C)  // correct: AB C, was 1
1208- Fixed a 64 bit portability problem.
1209- Added pragma wave timer(suspend) and wave timer(resume)
1210- Fixed a ODR problem with static initialization data for predefined macros.
1211- Ported the iterators to the new iterator_adaptors.
1212- Updated the documentation to reflect the recent changes
1213
1214Sun Jun 29 12:35:00     2003
1215- Fixed 64 bit compatibility warnings.
1216- Fixed a bug, which prevented the correct recognition of a #line directive, if
1217  only the filename part of this directive was generated by a macro expansion.
1218- Fixed a bug during macro expansion of conditional expressions, which
1219  prevented the correct expansion of certain scoped macros.
1220
1221Fri Jun 27 09:50:14     2003
1222- Changed the output of the overall elapsed time (option --timer) to cerr.
1223- Added a configuration constant WAVE_REVERSE_MACRONAMES_FOR_SYMBOLTABLE, which
1224  reverses the macro names while storing them into the symbol table, which
1225  allows to speed up name lookup especially, if the macro names are very long
1226  and if these share a common prefix.
1227- Fixed a very subtle bug, which prevented the recognition of fully qualified
1228  macro names during the macro expansion of conditionals expressions (for
1229  #if/#elif).
1230- Improved the error output for the illformed pp expression error.
1231
1232Thu Jun 26 08:20:30     2003
1233- Done a complete spell check of the source code comments.
1234
1235Wed Jun 25 20:33:52     2003
1236- Changed the conditional expression engine to work with integer numeric
1237  literals only. Distinguished signed and unsigned literals.
1238- Importing a region twice is allowed now.
1239- Fixed a bug, which does not removed all placeholder tokens from a expanded
1240  token sequence while evaluating conditional expressions (C++0x mode only).
1241
1242Wed Jun 25 15:01:51     2003
1243- Changed the conditional expression engine to respect the type of numeric
1244  literals, now expressions like '#if 1 / 10 == 0' evaluate correctly (to true
1245  :-)
1246- Fixed a bug, where macro names referring to global macros (as ::A::B) were
1247  not correctly recognized under certain circumstances.
1248- Empty parameter lists for macros with ellipses only sometimes generated a
1249  placemarker token in the output:
1250    #define STR(...) #__VA_ARGS__
1251    STR()   // resulted in "�" instead of "" .
1252
1253Wed Jun 25 08:35:06     2003
1254- Fixed several gcc compilation errors (missing typename's etc.)
1255- Fixed a compilation problem, if Wave is built on top of the SLEX scanner.
1256- Reformatted the --timer output from pure seconds to a more reasonable format.
1257
1258Fri Jun 20 19:33:30     2003
1259- Changed the enable_tracing function of the tracing_policies to take a
1260  trace_flags variable instead of a bool, to allow to control tracing with more
1261  granulation.
1262- Added the tracing_enabled function to the tracing_policies, which returns the
1263  current tracing status.
1264- Updated the documentation of the tracing policies.
1265
1266Thu Jun 19 21:45:39     2003
1267- Reactivated the list_includes sample with the help of the new include file
1268  tracing facility.
1269
1270Thu Jun 19 17:55:35     2003
1271- Eliminated the TraceT template parameter from the macromap<> template.
1272- Added two hooks to the trace policy to allow to trace the opening and
1273  closing of include files.
1274
1275Thu Jun 19 14:08:10     2003
1276- Added the command line option --timer, which enables the output to std::cout
1277  of the overall elapsed time during the preprocessing of the given file.
1278
1279Fri Jun 13 09:11:29     2003
1280- Emitted an error message, if an ellipses was found as a formal macro
1281  parameter and variadics were disabled.
1282- Fixed a false error message, that the last line was not terminated with a
1283  newline, which occurred, if no output was generated by the last line of the
1284  source file.
1285
1286Thu Jun 12 15:20:22     2003
1287- Fixed the recent change in argument expansion for the variadics/C99/C++0x
1288  mode.
1289- Fixed a problem, where an additional whitespace between _Pragma and the
1290  opening parenthesis resulted in a false error message.
1291- Used a pool allocator for the token sequence containers (std::list<>'s),
1292  which gives a speed gain of more than 60% (while profiling the Order
1293  library).
1294
1295Wed Jun 11 22:18:54     2003
1296- Fixed a macro scoping/expansion problem, when a macro returned a full scope
1297  which is continued on the call site to form a full qualified name, the name
1298  wasn't recognized correctly:
1299    # region A
1300    #  define MACRO 1
1301    #  region B
1302    #   define MACRO 2
1303    #  endregion
1304    # endregion
1305    # define ID(x) x
1306    ID(A)::MACRO     // 1
1307    ID(A::B)::MACRO  // 2, was expanded to A::B::MACRO
1308- Changed the expansion of macro arguments such, that these will be expanded
1309  only, if the result is to be used for substitution during the expansion
1310  of the replacement list.
1311
1312Wed Jun 11 14:40:29     2003
1313- Included a whitespace eating finite state machine (FSM) for minimal
1314  whitespace in the generated output. This was suggested by Paul Mensonides.
1315- Updated the acknowledgement section
1316
1317Wed Jun  4 08:03:04     2003
1318- Fixed a bug reported by Faisal Vali, which prevented the correct evaluation
1319  of conditional expressions, if these referenced macro names, which expanded
1320  to a sequence containing non-expandable tokens.
1321- Fixed the above bug for #elif directives too (in the first place this was
1322  fixed for #if directives only)
1323
1324Mon May 26 22:15:40     2003
1325- Added missing copyrights in several files.
1326- Fixed false output, if a unknown _Pragma were encountered.
1327- Fixed a macro expansion problem with qualified names, were constructs like
1328  the following were not expanded correctly:
1329    #define ID(x) x
1330    #region SCOPE
1331    #  define TEST 1
1332    #endregion
1333    ID(SCOPE::) TEST    // should expand to 1
1334- Changed #import semantics for macros from copy semantics to reference
1335  semantics, i.e. macros are now considered to be implicitly imported into the
1336  scope, where they are defined. If a macro is imported into another scope and
1337  the original macro is undefined, the imported macro still exists. Further,
1338  if the imported macro is expanded, then while rescanning the original macro
1339  is disabled too:
1340    #region A
1341    #  define B(x) x
1342    #endregion
1343    #import A
1344    B    (A::B) (*) // A::B(*)
1345    A::B (B)    (*) // B(*)
1346    B    (B)    (*) // B(*)
1347    A::B (A::B) (*) // A::B(*)
1348- Fixed a recently introduced problem, where placemarker tokens slipped through
1349  to the output under certain conditions (in variadics/C99/C++0x modes only).
1350
1351Mon May 19 16:30:49     2003
1352- Fixed a bug, which prevented the recognition of the __lparen__, __rparen__ or
1353  __comma__ alternative tokens, if these were the first token after an emitted
1354  #line directive (reported by Vesa Karvonen).
1355- Added an optimization, that only those tokens are considered for a macro
1356  expansion, which may result in an expansion.
1357
1358Tue May 13 18:16:26     2003
1359- Fixed a newly introduced problem, where a omitted argument consisting out
1360  of whitespace only were failed to be replaced by a placemarker token. This
1361  lead to problems with constructs like the following:
1362    #define paste(a, b, c) a ## b ## c
1363    paste(1, , 3)  // should expand to 13, but expanded to 1## 3
1364- Fixed a problem with the tracing support, which throwed an unexpected
1365  exception if there were too few arguments given while expanding a macro.
1366- Allowed to open and to import the global scope ('#region ::' and
1367  '#import ::').
1368- Fixed a bug, if more than one file was given with a --forceinclude command
1369  line option.
1370
1371Sat May 10 21:30:29     2003
1372- Added __STDC_FULL_REGION__ and __STDC_CURRENT_REGION__ to the list of not
1373  undefinable macros.
1374- In normal C++ mode and C99 mode the #ifdef/#ifndef and the operator defined()
1375  should not support qualified names. This is fixed now.
1376- Updated the documentation.
1377- Fixed minor gcc -Wall compilation warnings.
1378- Added better error support for qualified names used as arguments for #ifdef,
1379  #ifndef and operator defined().
1380
1381Sat May 10 09:51:18     2003
1382- Removed the feature, that the comma before the ellipsis parameter in a macro
1383  definition may be omitted.
1384- Resolved an issue with the expansion of qualified macros, when these
1385  qualified names were partially generated by a previous macro expansion
1386- Allowed to specify fully qualified names as arguments to the #region directive
1387
1388Wed May  7 22:44:21     2003
1389- Changed the names of __SCOPE__ and __FULL_SCOPE__ predefined macros to
1390  __STDC_CURRENT_REGION__ and __STDC_FULL_REGION__ resp. The names are subject
1391  to change if the #region keyword actually will be renamed to #scope/#module
1392  or whatever.
1393- In C++0x mode it is now possible to omit the last comma before a variadics
1394  ellipsis in a macro definition:
1395    #define cat_i(a, b, c, d, e ...) a ## b ## c ## d ## e
1396- Fixed a bug in the stringize code, where an ellipsis to stringize resulted in
1397  stringizing of the first ellipsis parameter only. Preserved the original
1398  whitespace delimiting in between the ellipsis arguments.
1399- Introduced the wave::language_support enum for convenient switching of the
1400  supported language features throughout the library.
1401- Fixed a bug, which prevented the definition of the predefined macro
1402  __WAVE_HAS_VARIADICS__, if --variadics were given on the command line.
1403
1404Tue May  6 15:49:45     2003
1405- Made predefined macros available at every macro scope without qualification.
1406- Predefined a new macro in C++0x mode: __STDC_GLOBAL__, which is defined at
1407  global macro scope only and equals to '1' (integer literal).
1408- In C++0x mode there are two new predefined macros:
1409    __SCOPE__:      expands to the last part of the qualified name of the
1410                    current macro scope
1411    __FULL_SCOPE__: expands to the full qualified name of the current macro
1412                    scope
1413
1414Mon May  5 23:02:48     2003
1415- Fixed a problem in the new well defined token pasting code, which occurred for
1416  constructs like the following:
1417    #define is_empty(...) is_empty_ ## __VA_ARGS__ ## _other
1418  i.e. where two or more '##' operators were contained in the replacement text.
1419- Implemented __comma__, __lparen__ and __rparen__ alternative pp-tokens, which
1420  may be used as the ',', '(' and ')' tokens during preprocessing. These are
1421  only converted to there respective string representation in a special
1422  translation phase after preprocessing. This was proposed by Vesa Karvonen.
1423- Changed the macro scoping rules to: "If a qualified name does not find a
1424  nested name, it is not a qualified name to the preprocessor." This seems to
1425  be the simplest usable solution for the possible ambiguities.
1426- Fixed a bug in the macro expansion engine in C++0x mode, where the skipping
1427  of whitespace inside of a qualified name wasn't consistent.
1428
1429Sun May  4 10:48:53     2003
1430- Fixed a bug in the expression grammar, which prevented 'not' to be recognized
1431  as a valid operator.
1432- Qualified names are now supported as parameters to #ifdef and #ifndef too.
1433- Remove one specialization of the macro expansion engine. It gets instantiated
1434  only twice now (for the main input iterator and for list<>'s  of tokens.
1435- Simplified the required explicit specialization of the defined_grammar
1436  template. It has to be explicitly instantiated by providing the token type
1437  only (just as for the explicit instantiations of the other grammars).
1438
1439Fri May  2 22:44:27     2003
1440- Qualified names are now allowed as parameters to the operator defined() in
1441  C++0x mode.
1442- Separated the defined() functionality into a separate translation unit to
1443  work around a VC7.1 ICE.
1444
1445Fri May  2 15:38:26     2003
1446- The C++0x mode now has a special set of predefined macros.
1447- The predefined macro __WAVE_HAS_VARIADICS__ is now defined in C99 and C++0x
1448  modes too (--variadics is implied for these modes).
1449- Updated the documentation to reflect the recent changes and additions.
1450- In C++0x mode Wave now supports macro scopes:
1451    - new keywords #region/#endregion/#import
1452    - qualified macro names
1453- In C++0x mode Wave now supports token pasting of unrelated tokens. These are
1454  concatenated, the result is re-tokenized and inserted into the output stream.
1455- Fixed a minor bug in the macro expansion engine, if a qualified function-like
1456  macro was found in an object-like context.
1457- Fixed an issue with well defined token pasting of unrelated tokens.
1458
1459Tue Apr 29 08:47:37     2003
1460- Fixed a bug in the macro expansion engine, which prevented the expansion
1461  of a certain macro under specific conditions (if the left of two tokens to
1462  concatenate were a disabled one (T_NONREPLACABLE_IDENTIFIER), then the
1463  resulting token was disabled too).
1464- Added additional diagnostics to the Wave driver to disambiguate the C99 and
1465  C++0x modes.
1466- Implemented a new API function and a corresponding Wave driver command line
1467  option, which allows to specify one or more include files to be preprocessed
1468  before the regular file is preprocessed (the files are processed as normal
1469  input and all the resulting output is included, before processing the regular
1470  input file). The Wave driver command line option is --forceinclude (-F).
1471- Wave now compiles the Order library from Vesa Karvonen.
1472
1473Mon Apr 28 07:57:10     2003
1474- Fixed a bug in the macro expansion engine.
1475- Removed a lot of (not needed) whitespace in the generated output (but still
1476  not optimal).
1477
1478Sat Apr 26 20:30:53     2003
1479- Fixed a bug in the initialization code of the Slex lexer while working in
1480  C99 mode (reported by Reece Dunn).
1481
1482Fri Apr 18 08:37:35     2003
1483- Fixed the handling of option_value's inside of pragma directives:
1484    _Pragma("wave option(option_value)")
1485  inside which all all whitespaces were deleted.
1486- Started to implement experimental macro scoping.
1487
1488Thu Apr 10 10:20:07     2003
1489- Fixed a problem with the #pragma wave stop(), where only the first token
1490  inside the stop directive was output, when the preprocessor stops in result
1491  of this pragma.
1492- Implemented a new #pragma wave system(command), which spawns a new operation
1493  system command exactly as specified inside the system directive, intercepts
1494  the stdout output of this process, retokenizes this output and inserts the
1495  generated token sequence in place of the original #pragma or operator _Pragma.
1496  Please note that the generated output is _not_ subject to any macro expansion
1497  before its insertion as the replacement of the pragma itself. If you need to
1498  macro expand the replacement text, you always may force this by writing:
1499    #define SCAN(x) x
1500    SCAN(_Pragma("wave system(...)"))
1501  which re-scans the replacement once.
1502- Replaced the Wave position_iterator with the boost::spirit::position_iterator
1503  (without any problems!).
1504
1505Mon Apr  7 10:45:30     2003
1506- Fixed macro_trace_policies::expand_object_like_macro not to be called with
1507  the formal arguments as one of its parameters.
1508- Updated the documentation to reflect the changes needed for the tracing
1509  stuff.
1510
1511Mon Mar 31 19:07:05     2003
1512- Fixed variadics support in the trace output.
1513- Fixed preprocessing of operator _Pragma() before it's execution.
1514- Added _Pragma("wave stop(errmsg)") (#pragma wave stop(errmsg)) to allow
1515  diagnostics output from inside macro expansion.
1516- Fixed operator _Pragma for unknown pragmas (these are simply put through to
1517  the output).
1518- Implemented a maximal possible include nesting depth to avoid an out of
1519  memory error. The initial value for this is configurable through the compile
1520  time constant WAVE_MAX_INCLUDE_LEVEL_DEPTH, which defaults to 1024, if not
1521  given.
1522  Additionally this may be enlarged through a new command line option:
1523  -n/--nesting (Wave driver only).
1524
1525Sun Mar 30 20:40:17     2003
1526- Implemented the predefined macro __INCLUDE_LEVEL__, which expands to a
1527  decimal integer constant that represents the depth of nesting in include
1528  files. The value of this macro is incremented on every '#include' directive
1529  and decremented at every end of file.
1530- Implemented the operator _Pragma(). It is recognized in C99 mode and whenever
1531  variadics are enabled.
1532
1533Sun Mar 30 08:30:12     2003
1534- Changed the tracing format to be more readable.
1535- Changed the tracing #pragmas to
1536    enable tracing:     #pragma wave trace(enable)
1537    disable tracing:    #pragma wave trace(disable)
1538  or
1539    enable tracing:     #pragma wave trace(1)
1540    disable tracing:    #pragma wave trace(0)
1541- Changed the semantics of the -t (--traceto) switch. Without any -t switch
1542  there isn't generated any trace output at all, even, if the corresponding
1543  #pragma directives are found. To output the trace info to a file, the
1544  '-t file' syntax may be used, to output to std::cerr, the '-t-' (or '-t -')
1545  syntax may be used.
1546
1547Fri Mar 28 17:27:25     2003
1548- Added a new template parameter to the wave::context<> object, which allows
1549  to specify a policy for controlling the macro expansion tracing. The default
1550  macro_trace_policy does no tracing at all. This way one can add specific
1551  macro expansion tracing facilities to the library.
1552- #pragma directives starting with a STDC identifier are no longer not macro
1553  expanded in C++ mode, in C++ mode these are now expanded as usual, in C99
1554  mode not.
1555- The tracing can be enabled/disabled from inside the preprocessed stream by
1556  inserting a special #pragma directive:
1557    enable tracing:     #pragma wave_option(trace: enable)
1558    disable tracing:    #pragma wave_option(trace: disable)
1559- The Wave driver now allows to specify a destination for the macro expansion
1560  tracing trough a new command line switch: '-t path' or '--traceto path'. If
1561  this option isn't given, the trace output goes to stderr.
1562- The Wave driver now allows to specify the name of the file, where the
1563  preprocessed result stream is to be saved: '-o path' or '--output path'. If
1564  this option is not given, the output goes to stdout.
1565
1566Wed Mar 26 20:39:11     2003
1567- Fixed a problem with alternative tokens (as 'and', 'or' etc.) and trigraph
1568  tokens, which were not correctly recognized inside #if/#elif expressions.
1569- Alternative tokens ('and', 'or' etc.) are no longer subject to a possible
1570  macro redefinition.
1571- Fixed the special handling of 'true' and 'false' during the macro expansion
1572  of #if/#elif expressions.
1573
1574Tue Mar 25 12:12:35     2003
1575- Released Wave V0.9.1
1576
1577Mon Mar 24 13:34:27     2003
1578- Implemented placemarkers, i.e. Wave now supports empty arguments during macro
1579  invocations. This must be enabled by means of a new pp constant:
1580  WAVE_SUPPORT_VARIADICS_PLACEMARKERS which must be defined to enable the
1581  placemarker and variadics code and by defining the command line option
1582  '--variadics' (Wave driver only).
1583- Implemented variadics, i.e. Wave now supports macros with variable parameter
1584  counts. This must be enabled by means of the pp constant:
1585  WAVE_SUPPORT_VARIADICS_PLACEMARKERS which must be defined to enable the
1586  placemarker and variadics code and by defining the command line option
1587  '--variadics' (Wave driver only).
1588- Implemented a C99 mode. This mode enables variadics and placemarkers by
1589  default and rejects some specific C++ tokens (as the alternate keywords and
1590  '::', '->*', '.*'). This mode must be enabled by the means of the pp constant
1591  WAVE_SUPPORT_VARIADICS_PLACEMARKERS (see above). The C99 mode is enabled by
1592  the command line switch '--c99' (Wave driver only).
1593  This involved some changes in the C99/C++ lexers.
1594
1595Fri Mar 21 16:02:10     2003
1596- Fixed a bug in the macro expansion engine, which prevented the expansion of
1597  macros, which name was concatenated out of a identifier and a integer
1598  followed directly by another identifier:
1599    #define X() X_ ## 0R()  // note: _zero_ followed by 'R'
1600    #define X_0R() ...
1601    X() // expanded to:  X_0R(), but should expand to ...
1602  This is a problem resulting from the fact, that the Standard requires the
1603  preprocessor to act on so called pp-tokens, but Wave acts on C++ tokens.
1604
1605Thu Mar 20 21:39:21     2003
1606- Fixed a problem with expression parsing (#if/#elif constant expressions),
1607  which failed to produce an error message for expressions like
1608    #if 1 2 3 4 5
1609  i.e. where the token sequence starts with a valid constant expression, but
1610  the remainder of the line contained other tokens than whitespace.
1611- Integrated the flex_string class from Andrei Alexandrescu (published on the
1612  CUJ site) to get COW-string behaviour for the token values and position
1613  filename strings. This resulted in a major overall speedup (about 2-3 times
1614  faster in dependency of the complexity of pp usage in the input stream).
1615- Fixed a bug, which reported ill formed #if/#else expressions as errors, even
1616  if the current if block status (conditional compilation status) is false.
1617- Added a warning, if the last line of a file does not end with a newline.
1618- Improved error recognition and handling for malformed preprocessor directives
1619
1620Mon Mar 17 19:53:29     2003
1621- Fixed a concatenation problem: constructs like a##b##c where expanded
1622  incorrectly.
1623- Optimized the recognition of pp directives:
1624    - the parser is used only, if the next non-whitespace token starts a pp
1625      directive
1626    - null directives now are recognized without calling the parser
1627    - the parser isn't called anymore, if the if_block_status is false and no
1628      conditional pp directive (#if etc.) is to be recognized.
1629  These optimizations give a speed improvement by upto 40%.
1630- Removed adjacent whitespace during macro expansion (needs to be revised,
1631  since there is some whitespace left, which may be removed)
1632
1633Sun Mar 16 23:19:11     2003
1634- Fixed a problem with include paths given on the command line, if the file
1635  to preprocess was not given as a full path (driver executable).
1636- Fixed a problem with path names containing blanks (driver executable).
1637- Cleaned command line and argument handling (driver executable).
1638- Fixed a severe memory leak.
1639- Fixed a bug, if a C++ keyword was used as a macro name or macro parameter
1640  name, which prevented the macro recognition and expansion to function
1641  properly.
1642- Implemented the WAVE_SUPPORT_MS_EXTENSIONS compiler switch for the re2c
1643  generated lexer too.
1644- Fixed a problem, which caused an internal T_PLACEHOLDER token to show up
1645  outside the macro replacement engine.
1646- Fixed a problem with macro #include directives, which prevents to find the
1647  file to include, if after the macro expansion the token sequence representing
1648  the filename began or ended with at least one whitespace token.
1649- Fixed a problem, which caused a false error message if the '#' character was
1650  to be concatenated with an arbitrary other token.
1651- The concatenation of a whitespace token with an arbitrary other token was
1652  reported as illegal token pasting (but it is certainly not).
1653
1654Sat Mar 15 21:43:56     2003
1655- Added a default constructor to the wave::util::file_position template.
1656- Report the concatenation of unrelated tokens as an error.
1657- Finished the documentation.
1658
1659Fri Mar 14 20:14:18     2003
1660- More work on documentation
1661- Changed file_position to expose accessor functions (the member variables are
1662  marked as private now). This opens up the possibility to provide another
1663  file_position implementation, which may be optimized in some way.
1664- Fixed a problem with the token name table, the alternate and trigraph token
1665  names were printed incorrectly.
1666- Fixed a bug, which prevented the correct recognition of 'defined X' (without
1667  parenthesises).
1668- Fixed a bug, which allowed to redefine and undefine the predefined name
1669  'defined'.
1670- Fixed a bug, which prevents the correct recognition of a macro based #include
1671  directive, if it expands to something like #include <...>.
1672- Fixed a bug, which prevented the recognition of duplicate macro parameter
1673  names.
1674- Removed the insertion of additional whitespace inside of string literals
1675  (during stringizing).
1676
1677Wed Mar 12 19:16:40     2003
1678- Fixed a bug, which prevented the instantiation of the wave::context object
1679  with auxiliary iterators. The token type isn't coupled anymore with the
1680  iterator type.
1681  This required some changes in the interface:
1682    - The wave::context object now has three template parameters (the iterator
1683      type, the token type and the input policy type)
1684    - The token type does not have the iterator type as it's template parameter
1685      anymore.
1686- Implemented a new position_iterator template on top of the iterator_adaptor<>
1687  template to make it work even for input_iterator type iterators.
1688- Fixed a bug in the regular expressions for the Slex lexer.
1689- The function 'set_sys_include_delimiter()' was renamed to
1690  'set_sysinclude_delimiter()' to better fit the naming scheme of the other
1691  functions.
1692- Wrote more documentation
1693- Unified the different token definitions of the lexers, so that there is only
1694  one token type left. This required some changes in the interface:
1695    - There is no need anymore to explicitly specify the namespace of the token
1696      type to use.
1697- Added the command line option -P to the Wave driver program, which predefines
1698  a macro (i.e. defines it such, that is _not_ undefinable through an #undef
1699  directive from inside the preprocessed program).
1700
1701Sat Mar  8 07:46:43     2003
1702- Released Wave 0.9.0
1703
1704Thu Mar  6 20:02:44     2003
1705- Compiled Wave with IntelV7.0/DinkumwareSTL (from VC6sp5)
1706- Fixed new compilation problems with gcc -Wall
1707- Fixed the list_includes and cpp_tokens samples to compile and link correctly.
1708- Fixed a bug, where a wrong filename was reported by the generated #line
1709  directive.
1710- Fixed a bug, where the __FILE__ macro was expanded without '\"' around the
1711  filename.
1712- The generated #line directives and the expanded __FILE__ macro now report
1713  the filename in a native (to the system) format. Additionally the generated
1714  string literals are now escaped correctly.
1715
1716Wed Mar  5 21:11:14     2003
1717- Reorganized the directory structure to mirror the namespace structure of the
1718  library
1719- Fixed a bug, where the complete input after the first found #include
1720  directive were eaten up.
1721- Fixed a bug, where the __LINE__ macro expanded to a incorrect linenumber, if
1722  the __LINE__ macro was encountered on a line after a '\\' '\n' sequence.
1723
1724Tue Mar  4 11:50:24     2003
1725- The new name of the project is 'Wave'.
1726- Adjusted namespaces, comments etc. to reflect the new name.
1727- Added the command line option -U [--undefine], which allows to remove one of
1728  the predefined macros (except __LINE__, __FILE__, __DATE__, __TIME__,
1729  __STDC__ and __cplusplus)
1730
1731Sun Mar  2 20:10:04     2003
1732- Fixed a bug while expanding macros without any definition part (empty macros)
1733- The pp-iterator will not emit a newline for every recognized preprocessing
1734  directive anymore. The generated output is much more condensed this way.
1735- The pp-iterator now emits #line directives at appropriate places.
1736- Added an additional parser to the library, which may be used to parse macros
1737  given in the command line syntax, i.e. something like 'MACRO(x)=definition'.
1738- Added the possibility to the cpp driver sample, to add macros from the
1739  command line through the -D command line switch.
1740- Martin Wille contributed a test script to allow automatic testing of the
1741  cpp driver sample by feeding all files contained in the test_files directory
1742  through the cpp driver and comparing the generated output with the
1743  corresponding expectations.
1744- Added config file support to allow for predefined option sets (for instance
1745  for the emulation of other compilers)
1746- Changed the way, how include paths are defined. It resembles now the
1747  behaviour of gcc.
1748  Any directories specified with '-I' options before an eventually given '-I-'
1749  option are searched only for the case of '#include "file"', they are not
1750  searched for '#include <file>' directives. If additional directories are
1751  specified with '-I' options after a '-I-' option was given, these directories
1752  are searched for all '#include' directives. In addition, the '-I-' option
1753  inhibits the use of the current directory as the first search directory for
1754  '#include "file"'. Therefore, the current directory is searched only if it is
1755  requested explicitly with '-I.'. Specifying both '-I-' and '-I.' allows to
1756  control precisely which directories are searched before the current one
1757  and which are searched after.
1758- Added config file support to the cpp driver.
1759- stored not only the current 'name' of a file (given eventually by a #line
1760  directive) but in parallel the actual full file system name of this file too.
1761
1762Tue Feb 25 21:44:19     2003
1763- Fixed the warnings emitted by gcc -Wall.
1764- Fixed a bug in the cpp grammar, which causes to failing the recognition of
1765  certain preprocessor directives if at the end of this directive were placed
1766  a C++ comment.
1767- Simplified and extended the insertion of whitespace tokens at places, where
1768  otherwise two adjacent tokens would form a new different token, if
1769  retokenized.
1770
1771Mon Feb 24 19:13:46     2003
1772- defined() functionality was broken
1773- added missing typename keywords
1774- added missing using namespace statements, where appropriate
1775- added a warning, when a predefined macro is to be undefined (by an #undef
1776  directive)
1777- removed the 'compile in C mode' hack for the re2c generated lexer (VC7.1
1778  (final beta) is not able to compile it with optimizations switched on
1779  anyway :( )
1780- compiled with gcc 3.2 and Intel V7.0 (20030129Z)
1781
1782Sun Feb 23 23:39:33  2003
1783- Fixed a couple of 'missing typename' bugs (thanks to Martin Wille)
1784- Added code to insert whitespace at places, where otherwise two adjacent
1785  tokens would form a new different token, if retokenized.
1786- Fixed a severe macro expansion bug.
1787- Added the handling of invalid or not allowed universal character values
1788  inside of string literals and character literals.
1789
1790Sat Feb 22 20:52:06  2003
1791- Bumped version to 0.9.0
1792- Added test for invalid or not allowed universal character values (see
1793  C++ Standard 2.2.2 [lex.charset] and Annex E)
1794- Fixed a bug with newlines between a macro name and the opening parenthesis
1795  during the macro expansion and a bug with newlines inside the parameter list
1796  during the macro expansion.
1797- Added the following predefined macros:
1798    __SPIRIT_PP__
1799        expands to the version number of the pp-iterator lib (i.e. 0x0090 for
1800        V0.9.0)
1801    __SPIRIT_PP_VERSION__
1802        expands to the full version number of the pp-iterator lib (i.e.
1803        0x00900436 for V0.9.0.436)
1804    __SPIRIT_PP_VERSION_STR__
1805        expands to the full version string of the pp-iterator lib (i.e.
1806        "0.9.0.436")
1807
1808Fri Feb 21 22:09:04  2003 (feature complete!)
1809- Allowed to optionally compile the Re2c generated lexer in 'C' mode, because
1810  at least the VC7.1 (final beta) compiler has problems to compile it in 'C++'
1811  mode with optimizations switch on
1812- Implemented #error and #warning (optional) directives (C++ standard 16.5).
1813  Additionally there are now allowed the following preprocessor configuration
1814  constants:
1815    CPP_PREPROCESS_ERROR_MESSAGE_BODY
1816        if defined, preprocesses the message body of #error and #warning
1817        directives to allow for better diagnostics.
1818    CPP_SUPPORT_WARNING_DIRECTIVE
1819        if defined, then the #warning directive will be recognized such, that
1820        a warning with the given message will be issued
1821- Adjusted the error handling for the Re2c generated C++ lexer, so that any
1822  error inside the lexer is now propagated as an cpplexer_exception.
1823- Implemented the #line directive (C++ standard 16.4)
1824- Implemented #pragma directive (C++ standard 16.6)
1825  Additionally there are now allowed the following preprocessor configuration
1826  constants:
1827    CPP_RETURN_PRAGMA_DIRECTIVES
1828        if defined, then the whole pragma directive is returned as a token
1829        sequence to the caller, if not defined the whole pragma directive is
1830        skipped
1831    CPP_PREPROCESS_PRAGMA_BODY
1832        if defined, then the #pragma body will be preprocessed
1833- Implemented #include directive with macro arguments (C++ standard 16.2.4)
1834- Made the namespace structure finer granulated to leave only the main
1835  interface classes in the main namespace cpp. All other classes are moved into
1836  sub-namespaces to reflect the logical dependencies
1837- Reorganized the public interface of the context<> template class, made all
1838  non relevant functions into the protected.
1839- Implemented predefined macros (__LINE__ et.al.) (C++ standard 16.8)
1840- Further documentation work
1841
1842Wed Feb 19 23:44:47  2003
1843- Corrected a lot of bugs in the macro expansion engine, which now should be
1844  conformant to the C++ standard.
1845- # (null) directive (C++ standard 16.7)
1846
1847Sun Feb 16 08:40:38  2003
1848- Added a macro expansion engine which expands macros with arguments
1849  C++ standard 16.3 [cpp.replace]
1850- Added a new sample: cpp_tokens. This sample preprocesses a given file and
1851  prints out the string representations of all tokens returned from the pp
1852  iterator
1853- Added documentation (to be continued!)
1854- Added a couple of small test files to test elementary functionality
1855  (the tests mainly were contributed by Paul Mensonides)
1856- The main cpp sample is now a simple preprocessor driver program, which
1857  outputs the string representation of the preprocessed input stream. Use
1858  cpp --help to get a hint, how to use it.
1859- Fixed a bug in the preprocessor grammar which failed to recognize a pp
1860  statement, if there was a C++ comment at the end of the line
1861- Added '#' operator (C++ standard 16.3.2) [cpp.stringize]
1862- Fixed a bug in the slex based C++ lexer to handle the concatenation
1863  characters correctly ('\\' followed by a '\n')
1864
1865Sun Feb  9 23:01:00  2003
1866- Improved error handling for #if et.al.
1867- Fixed a pair of lexer errors
1868- Implemented the #if/#elif statements, the sample now contains a complete C++
1869  expression evaluation engine (for the calculation of the outcome of the
1870  #if/#elif statement conditions)
1871- Implemented macro replacement (with parameters)
1872- Implemented the '##' [cpp.concat] operator
1873- Implemented the defined() [cpp.cond] operator
1874
1875Sun Feb  2 23:28:24  2003
1876- Implemented the  #define, #undef, #ifdef, #ifndef, #else and #endif
1877  statements
1878- Added optional parse tree output as xml stream (controlled through the config
1879  pp constant CPP_DUMP_PARSE_TREE)
1880
1881Fri Jan 31 21:30:55  2003
1882- Fixed different minor issues and a border case (#include statement at the
1883  last line of a included file)
1884
1885Wed Jan 29 21:13:32  2003
1886- Fixed exception handling to report the correct error position
1887- Fixed another bug in the stream position calculation scheme
1888- Added a more elaborate sample 'list_includes' which lists the dependency
1889  information for a given source file (see test/list_includes/readme.txt).
1890
1891Sat Jan 18 22:01:03  2003
1892- Fixed a bug in the stream position calculation scheme
1893- Made cpp::exceptions more standard conformant (added 'throw()' at appropriate
1894  places)
1895- Overall housekeeping :-)
1896
1897Wed Jan 15 21:54:20  2003
1898Changes since project start (still 0.5.0)
1899- Added #include <...> and #include "..." functionality
1900- pp directives are now generally recognized
1901- Decoupled the C++ lexers and the pp grammar to separate compilation
1902  units (optionally) to speed up compilation (a lot!)
1903
1904Thu Jan  2 12:39:30  2003
1905A completely new version 0.5.0 of the C preprocessor was started. It's a
1906complete rewrite of the existing code base. The main differences are:
1907- The preprocessor is now implemented as an iterator, which returns the
1908  current preprocessed token from the input stream.
1909- The preprocessing of include files isn't implemented through recursion
1910  anymore. This follows directly from the first change. As a result of this
1911  change the internal error handling is simplified.
1912- The C preprocessor iterator itself is fed by a new unified C++ lexer
1913  iterator. BTW, this C++ lexer iterator could be used standalone and is not
1914  tied to the C preprocessor. There are two different C++ lexers implemented
1915  now, which are functionally completely identical. These expose a similar
1916  interface, so the C preprocessor could be used with both of them.
1917- The C++ lexers integrated into the C preprocessor by now are:
1918    Slex:   A spirit based table driven regular expression lexer (the slex
1919            engine originally was written by Dan Nuffer and is available as a
1920            separate Spirit sample).
1921    Re2c:   A C++ lexer generated with the help of the re2c tool. This C++
1922            lexer was written as a sample by Dan Nuffer too.
1923  It isn't hard to plug in additional different C++ lexers. There are plans to
1924  integrate a third one written by Juan Carlos Arevalo-Baeza, which is
1925  available as a Spirit sample.
1926
1927-------------------------------------------------------------------------------
1928Tue Feb 12 22:29:50  2002
1929Changes from 0.2.3 to 0.2.4:
1930- Moved XML dumping functions to the main Spirit directory
1931- Fixed operator '##', it was not correctly implemented somehow :-(
1932
1933Sun Feb 10 21:07:19  2002
1934Changes from 0.2.2 to 0.2.3:
1935- Implemented concatenation operator '##' (cpp.concat)
1936- Removed defined() functionality for Intel compiler (it ICE's) until this
1937  issue is resolved
1938- Separated code for dumping a parse tree to XML for inclusion in the main
1939  Spirit headers
1940
1941Thu Jan 17 23:51:21  2002
1942Changes from 0.2.1 to 0.2.2:
1943- Fixes to compile with gcc 2.95.2 and gcc 3.0.2 (thanks Dan Nuffer)
1944- Reformatted the grammars to conform to a single formatting guideline
1945- Assigned explicit rule_id's to the rules of cpp_grammar, so that the
1946  access code to the embedded definition class is not needed anymore
1947- Fixed a remaining const problem
1948
1949Tue Jan 15 23:40:40  2002
1950Changes from 0.2.0 to 0.2.1:
1951- Corrected handling of defined() operator
1952- In preprocessing conditionals undefined identifiers now correctly
1953  replaced by '0'
1954- Fixed several const problems
1955- Added parse_node_iterator for traversing one node in a parse_tree
1956  without going deeper down the hierarchy than one level (this is useful,
1957  if all inspected tokens arranged along a single node in the parse tree.
1958  The main difference to the parse_tree_iterator is, that the underlying
1959  iterator generally can be adjusted correctly after advancing the attached
1960  parse_node_iterator
1961- Fixed a problem with gcc 2.95.2, which doesn't have a <sstream> header
1962- Prepared usage of slex for lexer states
1963
1964Sun Jan 13 10:21:16  2002
1965Changes from 0.1.0 to 0.2.0:
1966- Added operator 'defined()'
1967- Added directive '#warning'
1968- Corrected error reporting
1969- Added command line option -I- for finer control of the searched include
1970  directories (-I and -I- should now work as in gcc, see readme.html for
1971  more info)
1972- Corrected conditional preprocessing (should be fully functional now)
1973- Fixed existing code base for changes made in parse tree support
1974- Moved parse tree utility functions to a separate header (prepared for
1975  inclusion to the Spirit main library)
1976