1 # C++ skeleton for Bison
3 # Copyright (C) 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc.
5 # This program is free software; you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 2 of the License, or
8 # (at your option) any later version.
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software
17 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
20 # We do want M4 expansion after # for CPP macros.
23 @
output(b4_dir_prefix
[]position
.hh@
)
24 b4_copyright([Positions
for Bison parsers in C
++],
25 [2002, 2003, 2004, 2005, 2006])[
29 ** Define the ]b4_namespace[::position class.
32 #ifndef BISON_POSITION_HH
33 # define BISON_POSITION_HH
39 namespace ]b4_namespace
[
41 /// Abstract a position.
45 ]m4_ifdef([b4_location_constructors
], [
46 /// Construct a position.
48 : filename (0), line (]b4_location_initial_line
[), column (]b4_location_initial_column
[)
54 inline void initialize (]b4_filename_type
[* fn
)
57 line
= ]b4_location_initial_line
[;
58 column
= ]b4_location_initial_column
[;
61 /** \name Line and Column related manipulators
64 /// (line related) Advance to the COUNT next lines.
65 inline void lines (int count
= 1)
67 column
= ]b4_location_initial_column
[;
71 /// (column related) Advance to the COUNT next columns.
72 inline void columns (int count
= 1)
74 column
= std::max (]b4_location_initial_column
[u
, column
+ count
);
79 /// File name to which this position refers.
80 ]b4_filename_type
[* filename
;
81 /// Current line number.
83 /// Current column number.
87 /// Add and assign a position.
88 inline const position
&
89 operator+= (position
& res
, const int width
)
95 /// Add two position objects.
97 operator+ (const position
& begin
, const int width
)
103 /// Add and assign a position.
104 inline const position
&
105 operator-= (position
& res
, const int width
)
107 return res
+= -width
;
110 /// Add two position objects.
111 inline const position
112 operator- (const position
& begin
, const int width
)
114 return begin
+ -width
;
116 ]m4_if(b4_define_location_comparison
, [1], [[
117 /// Compare two position objects.
119 operator== (const position
& pos1
, const position
& pos2
)
122 (pos1
.filename
== pos2
.filename
123 || pos1
.filename
&& pos2
.filename
&& *pos1
.filename
== *pos2
.filename
)
124 && pos1
.line
== pos2
.line
&& pos1
.column
== pos2
.column
;
127 /// Compare two position objects.
129 operator!= (const position
& pos1
, const position
& pos2
)
131 return !(pos1
== pos2
);
134 /** \brief Intercept output stream redirection.
135 ** \param ostr the destination output stream
136 ** \param pos a reference to the position to redirect
139 operator<< (std::ostream
& ostr
, const position
& pos
)
142 ostr
<< *pos
.filename
<< ':';
143 return ostr
<< pos
.line
<< '.' << pos
.column
;
147 #endif // not BISON_POSITION_HH]
148 @
output(b4_dir_prefix
[]location
.hh@
)
149 b4_copyright([Locations
for Bison parsers in C
++],
150 [2002, 2003, 2004, 2005, 2006])[
154 ** Define the ]b4_namespace[::location class.
157 #ifndef BISON_LOCATION_HH
158 # define BISON_LOCATION_HH
162 # include "position.hh"
164 namespace ]b4_namespace
[
167 /// Abstract a location.
171 ]m4_ifdef([b4_location_constructors
], [
172 /// Construct a location.
180 inline void initialize (]b4_filename_type
[* fn
)
182 begin
.initialize (fn
);
186 /** \name Line and Column related manipulators
189 /// Reset initial location to final location.
195 /// Extend the current location to the COUNT next columns.
196 inline void columns (unsigned int count
= 1)
201 /// Extend the current location to the COUNT next lines.
202 inline void lines (unsigned int count
= 1)
210 /// Beginning of the located region.
212 /// End of the located region.
216 /// Join two location objects to create a location.
217 inline const location
operator+ (const location
& begin
, const location
& end
)
219 location res
= begin
;
224 /// Add two location objects.
225 inline const location
operator+ (const location
& begin
, unsigned int width
)
227 location res
= begin
;
232 /// Add and assign a location.
233 inline location
& operator+= (location
& res
, unsigned int width
)
238 ]m4_if(b4_define_location_comparison
, [1], [[
239 /// Compare two location objects.
241 operator== (const location
& loc1
, const location
& loc2
)
243 return loc1
.begin
== loc2
.begin
&& loc1
.end
== loc2
.end
;
246 /// Compare two location objects.
248 operator!= (const location
& loc1
, const location
& loc2
)
250 return !(loc1
== loc2
);
253 /** \brief Intercept output stream redirection.
254 ** \param ostr the destination output stream
255 ** \param loc a reference to the location to redirect
257 ** Avoid duplicate information.
259 inline std::ostream
& operator<< (std::ostream
& ostr
, const location
& loc
)
261 position last
= loc
.end
- 1;
264 && (!loc
.begin
.filename
265 || *loc
.begin
.filename
!= *last
.filename
))
267 else if (loc
.begin
.line
!= last
.line
)
268 ostr
<< '-' << last
.line
<< '.' << last
.column
;
269 else if (loc
.begin
.column
!= last
.column
)
270 ostr
<< '-' << last
.column
;
276 #endif // not BISON_LOCATION_HH]