-
Notifications
You must be signed in to change notification settings - Fork 63
/
ustack.h
41 lines (37 loc) · 1.48 KB
/
ustack.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// This file is part of the uSTL library, an STL implementation.
//
// Copyright (c) 2005 by Mike Sharov <[email protected]>
// This file is free software, distributed under the MIT License.
#pragma once
namespace ustl {
/// \class stack ustack.h ustl.h
/// \ingroup Sequences
///
/// \brief Stack adapter to uSTL containers.
///
template <typename T>
class stack {
public:
typedef T value_type;
typedef size_t size_type;
typedef ptrdiff_t difference_type;
typedef T& reference;
typedef const T& const_reference;
typedef T* pointer;
typedef const T* const_pointer;
public:
inline stack (void) : m_Storage () { }
explicit inline stack (const vector<T>& s) : m_Storage (s) { }
explicit inline stack (const stack& s) : m_Storage (s.m_Storage) { }
inline bool empty (void) const { return (m_Storage.empty()); }
inline size_type size (void) const { return (m_Storage.size()); }
inline reference top (void) { return (m_Storage.back()); }
inline const_reference top (void) const { return (m_Storage.back()); }
inline void push (const value_type& v) { m_Storage.push_back (v); }
inline void pop (void) { m_Storage.pop_back(); }
inline bool operator== (const stack& s) const { return (m_Storage == s.m_Storage); }
inline bool operator< (const stack& s) const { return (m_Storage.size() < s.m_Storage.size()); }
private:
vector<T> m_Storage; ///< Where the data actually is.
};
} // namespace ustl