1 /* Cycript - Optimizing JavaScript Compiler/Runtime
2 * Copyright (C) 2009-2015 Jay Freeman (saurik)
5 /* GNU Affero General Public License, Version 3 {{{ */
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as published by
9 * the Free Software Foundation, either version 3 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #ifndef YY_CY_STACK_HH_INCLUDED
23 #define YY_CY_STACK_HH_INCLUDED
27 template <class Type_>
30 typedef std::reverse_iterator<Type_ *> const_iterator;
39 for (size_t i(0); i != size_; ++i)
43 void reserve(size_t capacity) {
45 Type_ *data(static_cast<Type_ *>(::operator new(sizeof(Type_) * capacity_)));
48 for (size_t i(0); i != size_; ++i) {
50 new (data + i) Type_(old);
54 ::operator delete(data_);
68 ::operator delete(data_);
71 _finline Type_ &operator [](size_t i) {
75 _finline const Type_ &operator [](size_t i) const {
79 _finline void push(Type_ &t) {
80 if (size_ == capacity_)
81 reserve(capacity_ * 2);
82 new (data_++) Type_(t);
91 _finline void pop(unsigned int size) {
92 for (; size != 0; --size)
101 _finline size_t size() const {
105 _finline const_iterator begin() const {
106 return const_iterator(data_);
109 _finline const_iterator end() const {
110 return const_iterator(data_ - size_);
114 stack(const stack &);
115 stack &operator =(const stack &);
118 template <class Type_, class Stack_ = stack<Type_> >
121 slice(const Stack_ &stack, unsigned int range) :
127 _finline const Type_ &operator [](unsigned int i) const {
128 return stack_[range_ - i];
132 const Stack_ &stack_;
138 #endif/*YY_CY_STACK_HH_INCLUDED*/