00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 #ifndef COH_LINKED_LIST_HPP
00017 #define COH_LINKED_LIST_HPP
00018 
00019 #include "coherence/lang.ns"
00020 
00021 #include "coherence/util/Collection.hpp"
00022 #include "coherence/util/ListIterator.hpp"
00023 #include "coherence/util/AbstractList.hpp"
00024 #include "coherence/util/SubList.hpp"
00025 
00026 COH_OPEN_NAMESPACE2(coherence,util)
00027 
00028 
00029 
00030 
00031 
00032 
00033 
00034 class COH_EXPORT LinkedList
00035     : public cloneable_spec<LinkedList,
00036         extends<AbstractList> >
00037     {
00038     friend class factory<LinkedList>;
00039 
00040     
00041 
00042     protected:
00043 
00044 
00045 
00046 
00047 
00048         LinkedList();
00049 
00050 
00051 
00052 
00053 
00054 
00055 
00056 
00057 
00058         LinkedList(Collection::View vc);
00059 
00060 
00061 
00062 
00063         LinkedList(const LinkedList& that);
00064 
00065 
00066 
00067 
00068         virtual ~LinkedList();
00069 
00070 
00071     
00072 
00073     public:
00074 
00075 
00076 
00077         virtual bool add(size32_t i, Object::Holder oh);
00078 
00079 
00080 
00081 
00082         virtual bool addAll(size32_t i, Collection::View vc);
00083 
00084 
00085 
00086 
00087         virtual Object::Holder get(size32_t i) const;
00088 
00089 
00090 
00091 
00092         using List::get;
00093 
00094 
00095 
00096 
00097         virtual size32_t indexOf(Object::View v) const;
00098 
00099 
00100 
00101 
00102         virtual size32_t lastIndexOf(Object::View v) const;
00103 
00104 
00105 
00106 
00107         virtual ListIterator::Handle listIterator(size32_t index = 0) const;
00108 
00109 
00110 
00111 
00112         virtual ListMuterator::Handle listIterator(size32_t index = 0);
00113 
00114 
00115 
00116 
00117         virtual Object::Holder remove(size32_t index);
00118 
00119 
00120 
00121 
00122         virtual Object::Holder set(size32_t index, Object::Holder oh);
00123 
00124 
00125 
00126 
00127         virtual List::View subList(size32_t fromIndex, size32_t toIndex) const;
00128 
00129 
00130 
00131 
00132         virtual List::Handle subList(size32_t fromIndex, size32_t toIndex);
00133 
00134 
00135     
00136 
00137     public:
00138 
00139 
00140 
00141         virtual size32_t size() const;
00142 
00143 
00144 
00145 
00146         virtual Iterator::Handle iterator() const;
00147 
00148 
00149 
00150 
00151         virtual Muterator::Handle iterator();
00152 
00153 
00154 
00155 
00156         virtual bool add(Object::Holder oh);
00157 
00158 
00159 
00160 
00161         virtual bool addAll(Collection::View vc);
00162 
00163 
00164 
00165 
00166         virtual bool remove(Object::View v);
00167 
00168 
00169 
00170 
00171         virtual bool removeAll(Collection::View vColl);
00172 
00173 
00174 
00175 
00176         virtual bool retainAll(Collection::View vCol);
00177 
00178 
00179 
00180 
00181         virtual void clear();
00182 
00183 
00184     
00185 
00186     protected:
00187 
00188 
00189 
00190         virtual void onEscape(bool fEscaped) const;
00191 
00192 
00193     
00194 
00195     public:
00196 
00197 
00198 
00199         class ListElement
00200             : public class_spec<ListElement>
00201             {
00202             friend class factory<ListElement>;
00203 
00204             
00205 
00206             protected:
00207 
00208 
00209 
00210 
00211 
00212 
00213 
00214 
00215 
00216 
00217                 ListElement(ListElement::Handle hNext,
00218                         ListElement::Handle hPrev, Object::Holder hObj);
00219 
00220 
00221             
00222 
00223             public:
00224 
00225 
00226 
00227 
00228 
00229 
00230 
00231 
00232 
00233 
00234 
00235 
00236 
00237                 template<class T> static TypedHandle<T>
00238                         nextElement(const TypedHandle<T>& thElement, size32_t c);
00239 
00240             
00241 
00242             public:
00243 
00244 
00245 
00246                 mutable MemberHandle<ListElement> next;
00247 
00248 
00249 
00250 
00251                 MemberHandle<ListElement> previous;
00252 
00253 
00254 
00255 
00256                 MemberHolder<Object> value;
00257             };
00258 
00259 
00260     
00261 
00262     public:
00263 
00264 
00265 
00266 
00267 
00268         class SubLinkedList
00269             : public class_spec<SubLinkedList,
00270                 extends<SubList> >
00271             {
00272             friend class factory<SubLinkedList>;
00273 
00274             
00275 
00276             protected:
00277 
00278 
00279 
00280 
00281 
00282 
00283 
00284 
00285 
00286 
00287 
00288                 SubLinkedList(size32_t fromIndex, size32_t toIndex,
00289                         List::Holder ohList);
00290 
00291 
00292             
00293 
00294             public:
00295 
00296 
00297 
00298                 virtual bool retainAll(Collection::View vColl);
00299 
00300 
00301 
00302 
00303                 virtual void clear();
00304 
00305 
00306 
00307 
00308                 virtual List::View
00309                         subList(size32_t fromIndex, size32_t toIndex) const;
00310 
00311 
00312 
00313 
00314                 virtual List::Handle
00315                         subList(size32_t fromIndex, size32_t toIndex);
00316             };
00317 
00318 
00319     
00320 
00321     protected:
00322 
00323 
00324 
00325 
00326 
00327 
00328 
00329         virtual void assertIndex(size32_t i) const;
00330 
00331     private:
00332 
00333 
00334 
00335 
00336 
00337         Object::Holder removeElement(ListElement::Handle hElement,
00338                 size32_t index);
00339 
00340 
00341 
00342 
00343 
00344 
00345 
00346         void addElement(ListElement::Handle hNext, Object::Holder oh);
00347 
00348     
00349 
00350     protected:
00351 
00352 
00353 
00354         size32_t m_cElements;
00355 
00356 
00357 
00358 
00359         mutable MemberHandle<ListElement> m_hHead;
00360 
00361 
00362 
00363 
00364         mutable MemberHandle<ListElement> m_hTail;
00365 
00366 
00367     
00368 
00369     friend class SubLinkedList;
00370     friend class LinkedListIterator;
00371     };
00372 
00373 COH_CLOSE_NAMESPACE2
00374 
00375 #endif // COH_LINKED_LIST_HPP