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 {
00014 length_ = 0;
00015 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 --length_;
00046 }
00047
00048
00049
00050 template <class T, size_t DEFAULT_SIZE> ACE_INLINE bool
00051 ACE_Vector<T, DEFAULT_SIZE>::operator!= (const ACE_Vector<T, DEFAULT_SIZE> &s) const
00052 {
00053 return !(*this == s);
00054 }
00055
00056 template <class T, size_t DEFAULT_SIZE> ACE_INLINE void
00057 ACE_Vector<T, DEFAULT_SIZE>::swap (ACE_Vector &rhs)
00058 {
00059 ACE_Array<T>::swap (rhs);
00060 std::swap (this->length_, rhs.length_);
00061 std::swap (this->curr_max_size_, rhs.curr_max_size_);
00062 }
00063
00064
00065
00066
00067 template <class T, size_t DEFAULT_SIZE> ACE_INLINE void
00068 ACE_Vector_Iterator<T, DEFAULT_SIZE>::dump (void) const
00069 {
00070
00071 }
00072
00073 template <class T, size_t DEFAULT_SIZE> ACE_INLINE
00074 ACE_Vector_Iterator<T, DEFAULT_SIZE>::ACE_Vector_Iterator (ACE_Vector<T, DEFAULT_SIZE> &v)
00075 : current_ (0),
00076 vector_ (v)
00077 {
00078
00079 }
00080
00081 template <class T, size_t DEFAULT_SIZE> ACE_INLINE int
00082 ACE_Vector_Iterator<T, DEFAULT_SIZE>::advance (void)
00083 {
00084
00085
00086 if (this->current_ < vector_.size ())
00087 {
00088 ++this->current_;
00089 return 1;
00090 }
00091 else
00092 {
00093
00094 return 0;
00095 }
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