00001
00002
00003
00004
00005
00006
00007 #ifndef COH_TREE_SET_HPP
00008 #define COH_TREE_SET_HPP
00009
00010 #include "coherence/lang.ns"
00011
00012 #include "coherence/util/Comparator.hpp"
00013 #include "coherence/util/MappedSet.hpp"
00014 #include "coherence/util/SortedSet.hpp"
00015 #include "coherence/util/TreeMap.hpp"
00016
00017 COH_OPEN_NAMESPACE2(coherence,util)
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 class COH_EXPORT TreeSet
00032 : public cloneable_spec<TreeSet,
00033 extends<MappedSet>,
00034 implements<SortedSet> >
00035 {
00036 friend class factory<TreeSet>;
00037
00038
00039
00040 protected:
00041
00042
00043
00044
00045 TreeSet();
00046
00047
00048
00049
00050
00051
00052
00053 TreeSet(Comparator::View vComparator);
00054
00055
00056
00057
00058
00059
00060 TreeSet(SortedMap::Handle hMap);
00061
00062
00063
00064
00065
00066
00067 TreeSet(SortedMap::View vMap);
00068
00069
00070
00071
00072 TreeSet(const TreeSet& that);
00073
00074
00075
00076 public:
00077
00078
00079
00080 virtual Comparator::View comparator() const;
00081
00082
00083
00084
00085 virtual SortedSet::Handle subSet(Object::View vFromElement,
00086 Object::View vToElement);
00087
00088
00089
00090
00091 virtual SortedSet::View subSet(Object::View vFromElement,
00092 Object::View vToElement) const;
00093
00094
00095
00096
00097 virtual SortedSet::Handle headSet(Object::View vToElement);
00098
00099
00100
00101
00102 virtual SortedSet::View headSet(Object::View vToElement) const;
00103
00104
00105
00106
00107 virtual SortedSet::Handle tailSet(Object::View vFromElement);
00108
00109
00110
00111
00112 virtual SortedSet::View tailSet(Object::View vFromElement) const;
00113
00114
00115
00116
00117 virtual Object::View first() const;
00118
00119
00120
00121
00122 virtual Object::View last() const;
00123
00124
00125
00126 protected:
00127
00128
00129
00130
00131
00132 virtual void ensureMap();
00133
00134
00135
00136
00137
00138
00139 virtual SortedMap::Handle getSortedMap();
00140
00141
00142
00143
00144
00145
00146 virtual SortedMap::View getSortedMap() const;
00147 };
00148
00149 COH_CLOSE_NAMESPACE2
00150
00151 #endif // COH_TREE_SET_HPP