X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/d0a304384f4207bdf7f8b1038c2226c312f5e954..a2c525b34c24e790e37d8735c28c708c17cf9f57:/data/stack.hh
diff --git a/data/stack.hh b/data/stack.hh
index bd94eb2d..a56e6c74 100644
--- a/data/stack.hh
+++ b/data/stack.hh
@@ -1,6 +1,6 @@
# C++ skeleton for Bison
-# Copyright (C) 2002-2012 Free Software Foundation, Inc.
+# Copyright (C) 2002-2015 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
@@ -16,12 +16,12 @@
# along with this program. If not, see .
m4_pushdef([b4_copyright_years],
- [2002-2012])
+ [2002-2015])
# b4_stack_define
# ---------------
m4_define([b4_stack_define],
-[[ template >
+[[ template >
class stack
{
public:
@@ -32,32 +32,36 @@ m4_define([b4_stack_define],
stack ()
: seq_ ()
{
+ seq_.reserve (200);
}
stack (unsigned int n)
: seq_ (n)
- {
- }
+ {}
inline
T&
- operator [] (unsigned int i)
+ operator[] (unsigned int i)
{
- return seq_[i];
+ return seq_[seq_.size () - 1 - i];
}
inline
const T&
- operator [] (unsigned int i) const
+ operator[] (unsigned int i) const
{
- return seq_[i];
+ return seq_[seq_.size () - 1 - i];
}
+ /// Steal the contents of \a t.
+ ///
+ /// Close to move-semantics.
inline
void
- push (const T& t)
+ push (T& t)
{
- seq_.push_front (t);
+ seq_.push_back (T());
+ operator[](0).move (t);
}
inline
@@ -65,7 +69,13 @@ m4_define([b4_stack_define],
pop (unsigned int n = 1)
{
for (; n; --n)
- seq_.pop_front ();
+ seq_.pop_back ();
+ }
+
+ void
+ clear ()
+ {
+ seq_.clear ();
}
inline
@@ -90,6 +100,8 @@ m4_define([b4_stack_define],
}
private:
+ stack (const stack&);
+ stack& operator= (const stack&);
/// The wrapped container.
S seq_;
};
@@ -102,8 +114,7 @@ m4_define([b4_stack_define],
slice (const S& stack, unsigned int range)
: stack_ (stack)
, range_ (range)
- {
- }
+ {}
inline
const T&
@@ -119,10 +130,7 @@ m4_define([b4_stack_define],
]])
b4_defines_if(
-[# We do want M4 expansion after # for CPP macros.
-m4_changecom()
-m4_divert_push(0)dnl
-@output(b4_dir_prefix[]stack.hh@)@
+[b4_output_begin([b4_dir_prefix[]stack.hh])
b4_copyright([Stack handling for Bison parsers in C++])[
/**
@@ -132,14 +140,14 @@ b4_copyright([Stack handling for Bison parsers in C++])[
]b4_cpp_guard_open([b4_dir_prefix[]stack.hh])[
-# include
+# include
]b4_namespace_open[
]b4_stack_define[
]b4_namespace_close[
]b4_cpp_guard_close([b4_dir_prefix[]stack.hh])
-m4_divert_pop(0)
-m4_popdef([b4_copyright_years])dnl
-m4_changecom([#])
+b4_output_end()
])
+
+m4_popdef([b4_copyright_years])