Go to the documentation of this file.00001
00002
00003
00004
00005 #include <algorithm>
00006
00007 ACE_BEGIN_VERSIONED_NAMESPACE_DECL
00008
00009 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00010 ACE_Vector<T, DEFAULT_SIZE>::ACE_Vector (const size_t init_size,
00011 ACE_Allocator* alloc)
00012 : ACE_Array<T> (init_size == 0 ? DEFAULT_SIZE : init_size, alloc),
00013 length_ (0)
00014 {
00015 this->curr_max_size_ = this->max_size ();
00016 }
00017
00018 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00019 ACE_Vector<T, DEFAULT_SIZE>::~ACE_Vector ()
00020 {
00021 }
00022
00023 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00024 size_t ACE_Vector<T, DEFAULT_SIZE>::capacity (void) const
00025 {
00026 return curr_max_size_;
00027 }
00028
00029 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00030 size_t ACE_Vector<T, DEFAULT_SIZE>::size (void) const
00031 {
00032 return length_;
00033 }
00034
00035 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00036 void ACE_Vector<T, DEFAULT_SIZE>::clear (void)
00037 {
00038 length_ = 0;
00039 }
00040
00041 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00042 void ACE_Vector<T, DEFAULT_SIZE>::pop_back (void)
00043 {
00044 if (length_ > 0)
00045 {
00046 --length_;
00047 ACE_Array<T>::size (length_);
00048 }
00049 }
00050
00051
00052
00053 template <class T, size_t DEFAULT_SIZE> ACE_INLINE bool
00054 ACE_Vector<T, DEFAULT_SIZE>::operator!= (const ACE_Vector<T, DEFAULT_SIZE> &s) const
00055 {
00056 return !(*this == s);
00057 }
00058
00059 template <class T, size_t DEFAULT_SIZE> ACE_INLINE void
00060 ACE_Vector<T, DEFAULT_SIZE>::swap (ACE_Vector &rhs)
00061 {
00062 ACE_Array<T>::swap (rhs);
00063 std::swap (this->length_, rhs.length_);
00064 std::swap (this->curr_max_size_, rhs.curr_max_size_);
00065 }
00066
00067
00068
00069 template <class T, size_t DEFAULT_SIZE> ACE_INLINE void
00070 ACE_Vector_Iterator<T, DEFAULT_SIZE>::dump (void) const
00071 {
00072
00073 }
00074
00075 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00076 ACE_Vector_Iterator<T, DEFAULT_SIZE>::ACE_Vector_Iterator (ACE_Vector<T, DEFAULT_SIZE> &v)
00077 : current_ (0),
00078 vector_ (v)
00079 {
00080
00081 }
00082
00083 template <class T, size_t DEFAULT_SIZE> ACE_INLINE int
00084 ACE_Vector_Iterator<T, DEFAULT_SIZE>::advance (void)
00085 {
00086
00087
00088 if (this->current_ < vector_.size ())
00089 {
00090 ++this->current_;
00091 return 1;
00092 }
00093 else
00094
00095 return 0;
00096 }
00097
00098 template <class T, size_t DEFAULT_SIZE> ACE_INLINE int
00099 ACE_Vector_Iterator<T, DEFAULT_SIZE>::done (void) const
00100 {
00101 ACE_TRACE ("ACE_Vector_Iterator<T>::done");
00102
00103 return this->current_ >= vector_.size ();
00104 }
00105
00106 ACE_END_VERSIONED_NAMESPACE_DECL
00107