123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- # C++ skeleton for Bison
- # Copyright (C) 2002-2013 Free Software Foundation, Inc.
- # This program is free software: you can redistribute it and/or modify
- # it under the terms of the GNU General Public License as published by
- # the Free Software Foundation, either version 3 of the License, or
- # (at your option) any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with this program. If not, see <http://www.gnu.org/licenses/>.
- m4_pushdef([b4_copyright_years],
- [2002-2013])
- # b4_stack_define
- # ---------------
- m4_define([b4_stack_define],
- [[ template <class T, class S = std::vector<T> >
- class stack
- {
- public:
- // Hide our reversed order.
- typedef typename S::reverse_iterator iterator;
- typedef typename S::const_reverse_iterator const_iterator;
- stack ()
- : seq_ ()
- {
- }
- stack (unsigned int n)
- : seq_ (n)
- {
- }
- inline
- T&
- operator[] (unsigned int i)
- {
- return seq_[seq_.size () - 1 - i];
- }
- inline
- const T&
- operator[] (unsigned int i) const
- {
- return seq_[seq_.size () - 1 - i];
- }
- /// Steal the contents of \a t.
- ///
- /// Close to move-semantics.
- inline
- void
- push (T& t)
- {
- seq_.push_back (T());
- operator[](0).move (t);
- }
- inline
- void
- pop (unsigned int n = 1)
- {
- for (; n; --n)
- seq_.pop_back ();
- }
- void
- clear ()
- {
- seq_.clear ();
- }
- inline
- typename S::size_type
- size () const
- {
- return seq_.size ();
- }
- inline
- const_iterator
- begin () const
- {
- return seq_.rbegin ();
- }
- inline
- const_iterator
- end () const
- {
- return seq_.rend ();
- }
- private:
- stack (const stack&);
- stack& operator= (const stack&);
- /// The wrapped container.
- S seq_;
- };
- /// Present a slice of the top of a stack.
- template <class T, class S = stack<T> >
- class slice
- {
- public:
- slice (const S& stack, unsigned int range)
- : stack_ (stack)
- , range_ (range)
- {
- }
- inline
- const T&
- operator [] (unsigned int i) const
- {
- return stack_[range_ - i];
- }
- private:
- const S& stack_;
- unsigned int range_;
- };
- ]])
- b4_defines_if(
- [b4_output_begin([b4_dir_prefix[]stack.hh])
- b4_copyright([Stack handling for Bison parsers in C++])[
- /**
- ** \file ]b4_dir_prefix[stack.hh
- ** Define the ]b4_namespace_ref[::stack class.
- */
- ]b4_cpp_guard_open([b4_dir_prefix[]stack.hh])[
- # include <vector>
- ]b4_namespace_open[
- ]b4_stack_define[
- ]b4_namespace_close[
- ]b4_cpp_guard_close([b4_dir_prefix[]stack.hh])
- b4_output_end()
- ])
- m4_popdef([b4_copyright_years])
|