1 # C++ skeleton for Bison
 
   3 # Copyright (C) 2002-2012 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 3 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, see <http://www.gnu.org/licenses/>.
 
  18 m4_pushdef([b4_copyright_years],
 
  21 # We do want M4 expansion after # for CPP macros.
 
  24 @output(b4_dir_prefix[]stack.hh@)@
 
  25 b4_copyright([Stack handling for Bison parsers in C++],
 
  29  ** \file ]b4_dir_prefix[stack.hh
 
  30  ** Define the ]b4_namespace_ref[::stack class.
 
  33 #ifndef BISON_STACK_HH
 
  34 # define BISON_STACK_HH
 
  39   template <class T, class S = std::deque<T> >
 
  43     // Hide our reversed order.
 
  44     typedef typename S::reverse_iterator iterator;
 
  45     typedef typename S::const_reverse_iterator const_iterator;
 
  51     stack (unsigned int n) : seq_ (n)
 
  57     operator [] (unsigned int i)
 
  64     operator [] (unsigned int i) const
 
  78     pop (unsigned int n = 1)
 
  91     inline const_iterator begin () const { return seq_.rbegin (); }
 
  92     inline const_iterator end () const { return seq_.rend (); }
 
  98   /// Present a slice of the top of a stack.
 
  99   template <class T, class S = stack<T> >
 
 103     slice (const S& stack, unsigned int range)
 
 111     operator [] (unsigned int i) const
 
 113       return stack_[range_ - i];
 
 122 #endif // not BISON_STACK_HH[]dnl
 
 125 m4_popdef([b4_copyright_years])dnl