X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/1c7ec959b1dddfbf594d5b76572e4b473c055be2..6656c9b52a306b394fb6529f735924db0f08c1a2:/data/stack.hh diff --git a/data/stack.hh b/data/stack.hh index ab1049c1..22d89fbb 100644 --- a/data/stack.hh +++ b/data/stack.hh @@ -18,21 +18,10 @@ m4_pushdef([b4_copyright_years], [2002-2012]) -b4_output_begin([b4_dir_prefix[]stack.hh]) -b4_copyright([Stack handling for Bison parsers in C++], - [2002-2012])[ - -/** - ** \file ]b4_dir_prefix[stack.hh - ** Define the ]b4_namespace_ref[::stack class. - */ - -]b4_cpp_guard_open([b4_dir_prefix[]stack.hh])[ - -# include - -]b4_namespace_open[ - template > +# b4_stack_define +# --------------- +m4_define([b4_stack_define], +[[ template > class stack { public: @@ -40,11 +29,13 @@ b4_copyright([Stack handling for Bison parsers in C++], typedef typename S::reverse_iterator iterator; typedef typename S::const_reverse_iterator const_iterator; - stack () : seq_ () + stack () + : seq_ () { } - stack (unsigned int n) : seq_ (n) + stack (unsigned int n) + : seq_ (n) { } @@ -52,21 +43,21 @@ b4_copyright([Stack handling for Bison parsers in C++], T& operator [] (unsigned int i) { - return seq_[i]; + return seq_[seq_.size () - 1 - i]; } inline const T& operator [] (unsigned int i) const { - return seq_[i]; + return seq_[seq_.size () - 1 - i]; } inline void push (const T& t) { - seq_.push_front (t); + seq_.push_back (t); } inline @@ -74,20 +65,32 @@ b4_copyright([Stack handling for Bison parsers in C++], pop (unsigned int n = 1) { for (; n; --n) - seq_.pop_front (); + seq_.pop_back (); } inline - unsigned int - height () const + 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 (); } + inline + const_iterator + begin () const + { + return seq_.rbegin (); + } + + inline + const_iterator + end () const + { + return seq_.rend (); + } private: + /// The wrapped container. S seq_; }; @@ -113,9 +116,27 @@ b4_copyright([Stack handling for Bison parsers in C++], 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 + +]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])