… | |
… | |
19 | T pop_back () { return (T*)simplevec<void *>::pop_back (); } |
19 | T pop_back () { return (T*)simplevec<void *>::pop_back (); } |
20 | void erase (int i) { erase (begin () + i); } |
20 | void erase (int i) { erase (begin () + i); } |
21 | void erase (iterator i) { simplevec<void *>::erase ((void **)i); } |
21 | void erase (iterator i) { simplevec<void *>::erase ((void **)i); } |
22 | iterator begin () const { return (iterator)simplevec<void *>::begin (); } |
22 | iterator begin () const { return (iterator)simplevec<void *>::begin (); } |
23 | iterator end () const { return (iterator)simplevec<void *>::end (); } |
23 | iterator end () const { return (iterator)simplevec<void *>::end (); } |
24 | T &operator [](int i) { return *(T *)(&((*(simplevec<void *> *)this)[i])); } |
24 | T &operator [] (int i) { return * (T *) (& ((* (simplevec<void *> *)this)[i])); } |
25 | const T &operator [](int i) const { return *(const T *)(&((*(const simplevec<void *> *)this)[i])); } |
25 | const T &operator [] (int i) const { return * (const T *) (& ((* (const simplevec<void *> *)this)[i])); } |
26 | }; |
26 | }; |
27 | #endif |
27 | #endif |
28 | |
28 | |
29 | template <typename I, typename T> |
29 | template <typename I, typename T> |
30 | I find(I first, I last, const T& value) |
30 | I find (I first, I last, const T& value) |
31 | { |
31 | { |
32 | while (first != last && *first != value) |
32 | while (first != last && *first != value) |
33 | ++first; |
33 | ++first; |
34 | |
34 | |
35 | return first; |
35 | return first; |
… | |
… | |
37 | |
37 | |
38 | template<typename T> |
38 | template<typename T> |
39 | struct auto_ptr { |
39 | struct auto_ptr { |
40 | T *p; |
40 | T *p; |
41 | |
41 | |
42 | auto_ptr() : p(0) { } |
42 | auto_ptr () : p (0) { } |
43 | auto_ptr(T *a) : p(a) { } |
43 | auto_ptr (T *a) : p (a) { } |
44 | |
44 | |
45 | auto_ptr(auto_ptr<T> &a) |
45 | auto_ptr (auto_ptr<T> &a) |
46 | { |
46 | { |
47 | p = a.p; |
47 | p = a.p; |
48 | a.p = 0; |
48 | a.p = 0; |
49 | } |
49 | } |
50 | |
50 | |
51 | template<typename A> |
51 | template<typename A> |
52 | auto_ptr(auto_ptr<A> &a) |
52 | auto_ptr (auto_ptr<A> &a) |
53 | { |
53 | { |
54 | p = a.p; |
54 | p = a.p; |
55 | a.p = 0; |
55 | a.p = 0; |
56 | } |
56 | } |
57 | |
57 | |
58 | ~auto_ptr() |
58 | ~auto_ptr () |
59 | { |
59 | { |
60 | delete p; |
60 | delete p; |
61 | } |
61 | } |
62 | |
62 | |
63 | // void because it makes sense in our context |
63 | // void because it makes sense in our context |
64 | void operator =(T *a) |
64 | void operator = (T *a) |
65 | { |
65 | { |
66 | delete p; |
66 | delete p; |
67 | p = a; |
67 | p = a; |
68 | } |
68 | } |
69 | |
69 | |
70 | void operator =(auto_ptr &a) |
70 | void operator = (auto_ptr &a) |
71 | { |
71 | { |
72 | *this = a.p; |
72 | *this = a.p; |
73 | a.p = 0; |
73 | a.p = 0; |
74 | } |
74 | } |
75 | |
75 | |
76 | template<typename A> |
76 | template<typename A> |
77 | void operator =(auto_ptr<A> &a) |
77 | void operator = (auto_ptr<A> &a) |
78 | { |
78 | { |
79 | *this = a.p; |
79 | *this = a.p; |
80 | a.p = 0; |
80 | a.p = 0; |
81 | } |
81 | } |
82 | |
82 | |
83 | operator T *() const { return p; } |
83 | operator T * () const { return p; } |
84 | |
84 | |
85 | T *operator ->() const { return p; } |
85 | T *operator -> () const { return p; } |
86 | T &operator *() const { return *p; } |
86 | T &operator * () const { return *p; } |
87 | |
87 | |
88 | T *get () |
88 | T *get () |
89 | { |
89 | { |
90 | T *r = p; |
90 | T *r = p; |
91 | p = 0; |
91 | p = 0; |
… | |
… | |
97 | |
97 | |
98 | struct stringvec : simplevec<char *> |
98 | struct stringvec : simplevec<char *> |
99 | { |
99 | { |
100 | ~stringvec () |
100 | ~stringvec () |
101 | { |
101 | { |
102 | for (char **c = begin(); c != end(); c++) |
102 | for (char **c = begin (); c != end (); c++) |
103 | delete [] *c; |
103 | delete [] *c; |
104 | } |
104 | } |
105 | }; |
105 | }; |
106 | |
106 | |
107 | #endif |
107 | #endif |