mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-21 10:13:03 +00:00
* data/lalr1.cc (position.hh): New subfile, including the extended
and Doxygen'ed documentation of class Position. (location.hh): Use it. Document a` la Doxygen. With the help of Benot Perrot.
This commit is contained in:
@@ -1,3 +1,11 @@
|
|||||||
|
2003-02-20 Akim Demaille <akim@epita.fr>
|
||||||
|
|
||||||
|
* data/lalr1.cc (position.hh): New subfile, including the extended
|
||||||
|
and Doxygen'ed documentation of class Position.
|
||||||
|
(location.hh): Use it.
|
||||||
|
Document a` la Doxygen.
|
||||||
|
With the help of Benoît Perrot.
|
||||||
|
|
||||||
2003-02-20 Akim Demaille <akim@epita.fr>
|
2003-02-20 Akim Demaille <akim@epita.fr>
|
||||||
|
|
||||||
* tests/calc.at (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): Define
|
* tests/calc.at (AT_CHECK_PUSHDEFS, AT_CHECK_POPDEFS): Define
|
||||||
|
|||||||
192
data/lalr1.cc
192
data/lalr1.cc
@@ -872,59 +872,207 @@ namespace yy
|
|||||||
|
|
||||||
#endif // not BISON_STACK_HH]
|
#endif // not BISON_STACK_HH]
|
||||||
dnl
|
dnl
|
||||||
@output location.hh
|
@output position.hh
|
||||||
b4_copyright([Location class for Bison C++ parsers], [2002, 2003])[
|
b4_copyright([Position class for Bison C++ parsers], [2002, 2003])[
|
||||||
|
|
||||||
#ifndef BISON_LOCATION_HH
|
/**
|
||||||
# define BISON_LOCATION_HH
|
** \file position.hh
|
||||||
|
** Define the Location class.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef BISON_POSITION_HH
|
||||||
|
# define BISON_POSITION_HH
|
||||||
|
|
||||||
# include <iostream>
|
# include <iostream>
|
||||||
# include <string>
|
# include <string>
|
||||||
|
|
||||||
namespace yy
|
namespace yy
|
||||||
{
|
{
|
||||||
|
/** \brief Abstract a Position. */
|
||||||
class Position
|
class Position
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Position ()
|
/** \brief Initial column number. */
|
||||||
: filename (), line (1), column (0)
|
static const unsigned int initial_column = 0;
|
||||||
{}
|
/** \brief Initial line number. */
|
||||||
|
static const unsigned int initial_line = 1;
|
||||||
|
|
||||||
|
/** \name Ctor & dtor.
|
||||||
|
** \{ */
|
||||||
|
public:
|
||||||
|
/** \brief Construct a Position. */
|
||||||
|
Position () :
|
||||||
|
filename (),
|
||||||
|
line (initial_line),
|
||||||
|
column (initial_column)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/** \} */
|
||||||
|
|
||||||
|
|
||||||
|
/** \name Line and Column related manipulators
|
||||||
|
** \{ */
|
||||||
|
public:
|
||||||
|
/** \brief (line related) Advance to the LINES next lines. */
|
||||||
|
inline void lines (int lines = 1)
|
||||||
|
{
|
||||||
|
column = initial_column;
|
||||||
|
line += lines;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief (column related) Advance to the COLUMNS next columns. */
|
||||||
|
inline void columns (int columns = 1)
|
||||||
|
{
|
||||||
|
column += columns;
|
||||||
|
}
|
||||||
|
/** \} */
|
||||||
|
|
||||||
|
public:
|
||||||
|
/** \brief File name to which this position refers. */
|
||||||
std::string filename;
|
std::string filename;
|
||||||
int line;
|
/** \brief Current line number. */
|
||||||
int column;
|
unsigned int line;
|
||||||
|
/** \brief Current column number. */
|
||||||
|
unsigned int column;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/** \brief Add and assign a Position. */
|
||||||
|
inline const Position&
|
||||||
|
operator+= (Position& res, const int width)
|
||||||
|
{
|
||||||
|
res.columns (width);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Add two Position objects. */
|
||||||
|
inline const Position
|
||||||
|
operator+ (const Position& begin, const int width)
|
||||||
|
{
|
||||||
|
Position res = begin;
|
||||||
|
return res += width;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Add and assign a Position. */
|
||||||
|
inline const Position&
|
||||||
|
operator-= (Position& res, const int width)
|
||||||
|
{
|
||||||
|
return res += -width;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Add two Position objects. */
|
||||||
|
inline const Position
|
||||||
|
operator- (const Position& begin, const int width)
|
||||||
|
{
|
||||||
|
return begin + -width;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Intercept output stream redirection.
|
||||||
|
** \param ostr the destination output stream
|
||||||
|
** \param pos a reference to the Position to redirect
|
||||||
|
*/
|
||||||
inline std::ostream&
|
inline std::ostream&
|
||||||
operator<< (std::ostream& ostr, const Position& pos)
|
operator<< (std::ostream& ostr, const Position& pos)
|
||||||
{
|
{
|
||||||
if (pos.filename != "")
|
if (pos.filename != "")
|
||||||
ostr << pos.filename << ':';
|
ostr << pos.filename << ':';
|
||||||
ostr << pos.line << '.' << pos.column;
|
return ostr << pos.line << '.' << pos.column;
|
||||||
return ostr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline Position
|
}
|
||||||
operator- (const Position& pos, int col)
|
#endif // not BISON_POSITION_HH]
|
||||||
{
|
@output location.hh
|
||||||
Position res (pos);
|
b4_copyright([Location class for Bison C++ parsers], [2002, 2003])[
|
||||||
res.column -= col;
|
|
||||||
return res;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
** \file location.hh
|
||||||
|
** Define the Location class.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef BISON_LOCATION_HH
|
||||||
|
# define BISON_LOCATION_HH
|
||||||
|
|
||||||
|
# include <iostream>
|
||||||
|
# include <string>
|
||||||
|
# include "position.hh"
|
||||||
|
|
||||||
|
namespace yy
|
||||||
|
{
|
||||||
|
|
||||||
|
/** \brief Abstract a Location. */
|
||||||
class Location
|
class Location
|
||||||
{
|
{
|
||||||
|
/** \name Ctor & dtor.
|
||||||
|
** \{ */
|
||||||
public:
|
public:
|
||||||
|
/** \brief Construct a Location. */
|
||||||
|
Location (void) :
|
||||||
|
begin (),
|
||||||
|
end ()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/** \} */
|
||||||
|
|
||||||
|
|
||||||
|
/** \name Line and Column related manipulators
|
||||||
|
** \{ */
|
||||||
|
public:
|
||||||
|
/** \brief Reset initial location to final location. */
|
||||||
|
inline void step (void)
|
||||||
|
{
|
||||||
|
begin = end;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Extend the current location to the COLUMNS next columns. */
|
||||||
|
inline void columns (unsigned columns = 1)
|
||||||
|
{
|
||||||
|
end += columns;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Extend the current location to the LINES next lines. */
|
||||||
|
inline void lines (unsigned lines = 1)
|
||||||
|
{
|
||||||
|
end.lines (lines);
|
||||||
|
}
|
||||||
|
/** \} */
|
||||||
|
|
||||||
|
|
||||||
|
public:
|
||||||
|
/** \brief Beginning of the located region. */
|
||||||
Position begin;
|
Position begin;
|
||||||
|
/** \brief End of the located region. */
|
||||||
Position end;
|
Position end;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Don't issue twice the line number when the location is on a single
|
/** \brief Join two Location objects to create a Location. */
|
||||||
line. */
|
inline const Location operator+ (const Location& begin, const Location& end)
|
||||||
|
{
|
||||||
|
Location res = begin;
|
||||||
|
res.end = end.end;
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
inline std::ostream&
|
/** \brief Add two Location objects */
|
||||||
operator<< (std::ostream& ostr, const Location& pos)
|
inline const Location operator+ (const Location& begin, unsigned width)
|
||||||
|
{
|
||||||
|
Location res = begin;
|
||||||
|
res.columns (width);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Add and assign a Location */
|
||||||
|
inline Location &operator+= (Location& res, unsigned width)
|
||||||
|
{
|
||||||
|
res.columns (width);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief Intercept output stream redirection.
|
||||||
|
** \param ostr the destination output stream
|
||||||
|
** \param pos a reference to the Position to redirect
|
||||||
|
**
|
||||||
|
** Don't issue twice the line number when the location is on a single line.
|
||||||
|
*/
|
||||||
|
inline std::ostream& operator<< (std::ostream& ostr, const Location& pos)
|
||||||
{
|
{
|
||||||
ostr << pos.begin;
|
ostr << pos.begin;
|
||||||
if (pos.begin.filename != pos.end.filename)
|
if (pos.begin.filename != pos.end.filename)
|
||||||
|
|||||||
Reference in New Issue
Block a user