ConcurrentSkipListMap.h 7.53 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53

// DO NOT EDIT THIS FILE - it is machine generated -*- c++ -*-

#ifndef __java_util_concurrent_ConcurrentSkipListMap__
#define __java_util_concurrent_ConcurrentSkipListMap__

#pragma interface

#include <java/util/AbstractMap.h>

class java::util::concurrent::ConcurrentSkipListMap : public ::java::util::AbstractMap
{

public: // actually package-private
  virtual void initialize();
private:
  jboolean casHead(::java::util::concurrent::ConcurrentSkipListMap$HeadIndex *, ::java::util::concurrent::ConcurrentSkipListMap$HeadIndex *);
  ::java::lang::Comparable * comparable(::java::lang::Object *);
public: // actually package-private
  virtual jint compare(::java::lang::Object *, ::java::lang::Object *);
  virtual jboolean inHalfOpenRange(::java::lang::Object *, ::java::lang::Object *, ::java::lang::Object *);
  virtual jboolean inOpenRange(::java::lang::Object *, ::java::lang::Object *, ::java::lang::Object *);
private:
  ::java::util::concurrent::ConcurrentSkipListMap$Node * findPredecessor(::java::lang::Comparable *);
  ::java::util::concurrent::ConcurrentSkipListMap$Node * findNode(::java::lang::Comparable *);
  ::java::lang::Object * doGet(::java::lang::Object *);
  ::java::lang::Object * getUsingFindNode(::java::lang::Comparable *);
  ::java::lang::Object * doPut(::java::lang::Object *, ::java::lang::Object *, jboolean);
  jint randomLevel();
  void insertIndex(::java::util::concurrent::ConcurrentSkipListMap$Node *, jint);
  void addIndex(::java::util::concurrent::ConcurrentSkipListMap$Index *, ::java::util::concurrent::ConcurrentSkipListMap$HeadIndex *, jint);
public: // actually package-private
  virtual ::java::lang::Object * doRemove(::java::lang::Object *, ::java::lang::Object *);
private:
  void tryReduceLevel();
public: // actually package-private
  virtual ::java::util::concurrent::ConcurrentSkipListMap$Node * findFirst();
  virtual ::java::util::Map$Entry * doRemoveFirstEntry();
private:
  void clearIndexToFirst();
public: // actually package-private
  virtual ::java::util::concurrent::ConcurrentSkipListMap$Node * findLast();
private:
  ::java::util::concurrent::ConcurrentSkipListMap$Node * findPredecessorOfLast();
public: // actually package-private
  virtual ::java::util::Map$Entry * doRemoveLastEntry();
  virtual ::java::util::concurrent::ConcurrentSkipListMap$Node * findNear(::java::lang::Object *, jint);
  virtual ::java::util::AbstractMap$SimpleImmutableEntry * getNear(::java::lang::Object *, jint);
public:
  ConcurrentSkipListMap();
  ConcurrentSkipListMap(::java::util::Comparator *);
  ConcurrentSkipListMap(::java::util::Map *);
  ConcurrentSkipListMap(::java::util::SortedMap *);
Tom Tromey committed
54
  virtual ::java::util::concurrent::ConcurrentSkipListMap * ConcurrentSkipListMap$clone();
55 56 57 58 59 60 61 62 63 64 65 66 67
private:
  void buildFromSorted(::java::util::SortedMap *);
  void writeObject(::java::io::ObjectOutputStream *);
  void readObject(::java::io::ObjectInputStream *);
public:
  virtual jboolean containsKey(::java::lang::Object *);
  virtual ::java::lang::Object * get(::java::lang::Object *);
  virtual ::java::lang::Object * put(::java::lang::Object *, ::java::lang::Object *);
  virtual ::java::lang::Object * remove(::java::lang::Object *);
  virtual jboolean containsValue(::java::lang::Object *);
  virtual jint size();
  virtual jboolean isEmpty();
  virtual void clear();
Tom Tromey committed
68
  virtual ::java::util::NavigableSet * ConcurrentSkipListMap$keySet();
69 70 71
  virtual ::java::util::NavigableSet * navigableKeySet();
  virtual ::java::util::Collection * values();
  virtual ::java::util::Set * entrySet();
Tom Tromey committed
72
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$descendingMap();
73 74 75 76 77 78 79 80 81
  virtual ::java::util::NavigableSet * descendingKeySet();
  virtual jboolean equals(::java::lang::Object *);
  virtual ::java::lang::Object * putIfAbsent(::java::lang::Object *, ::java::lang::Object *);
  virtual jboolean remove(::java::lang::Object *, ::java::lang::Object *);
  virtual jboolean replace(::java::lang::Object *, ::java::lang::Object *, ::java::lang::Object *);
  virtual ::java::lang::Object * replace(::java::lang::Object *, ::java::lang::Object *);
  virtual ::java::util::Comparator * comparator();
  virtual ::java::lang::Object * firstKey();
  virtual ::java::lang::Object * lastKey();
Tom Tromey committed
82 83 84 85 86 87
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$subMap(::java::lang::Object *, jboolean, ::java::lang::Object *, jboolean);
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$headMap(::java::lang::Object *, jboolean);
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$tailMap(::java::lang::Object *, jboolean);
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$subMap(::java::lang::Object *, ::java::lang::Object *);
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$headMap(::java::lang::Object *);
  virtual ::java::util::concurrent::ConcurrentNavigableMap * ConcurrentSkipListMap$tailMap(::java::lang::Object *);
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
  virtual ::java::util::Map$Entry * lowerEntry(::java::lang::Object *);
  virtual ::java::lang::Object * lowerKey(::java::lang::Object *);
  virtual ::java::util::Map$Entry * floorEntry(::java::lang::Object *);
  virtual ::java::lang::Object * floorKey(::java::lang::Object *);
  virtual ::java::util::Map$Entry * ceilingEntry(::java::lang::Object *);
  virtual ::java::lang::Object * ceilingKey(::java::lang::Object *);
  virtual ::java::util::Map$Entry * higherEntry(::java::lang::Object *);
  virtual ::java::lang::Object * higherKey(::java::lang::Object *);
  virtual ::java::util::Map$Entry * firstEntry();
  virtual ::java::util::Map$Entry * lastEntry();
  virtual ::java::util::Map$Entry * pollFirstEntry();
  virtual ::java::util::Map$Entry * pollLastEntry();
public: // actually package-private
  virtual ::java::util::Iterator * keyIterator();
  virtual ::java::util::Iterator * valueIterator();
  virtual ::java::util::Iterator * entryIterator();
  static ::java::util::List * toList(::java::util::Collection *);
public:
  virtual ::java::util::SortedMap * subMap(::java::lang::Object *, ::java::lang::Object *);
  virtual ::java::util::NavigableMap * subMap(::java::lang::Object *, jboolean, ::java::lang::Object *, jboolean);
  virtual ::java::lang::Object * clone();
  virtual ::java::util::SortedMap * tailMap(::java::lang::Object *);
  virtual ::java::util::NavigableMap * tailMap(::java::lang::Object *, jboolean);
  virtual ::java::util::SortedMap * headMap(::java::lang::Object *);
  virtual ::java::util::NavigableMap * headMap(::java::lang::Object *, jboolean);
  virtual ::java::util::Set * keySet();
  virtual ::java::util::NavigableMap * descendingMap();
public: // actually package-private
  static ::java::lang::Object * access$9();
private:
  static const jlong serialVersionUID = -8627078645895051609LL;
  static ::java::util::Random * seedGenerator;
  static ::java::lang::Object * BASE_HEADER;
121
  ::java::util::concurrent::ConcurrentSkipListMap$HeadIndex * volatile __attribute__((aligned(__alignof__( ::java::util::AbstractMap)))) head;
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136
  ::java::util::Comparator * comparator__;
  jint randomSeed;
  ::java::util::concurrent::ConcurrentSkipListMap$KeySet * keySet__;
  ::java::util::concurrent::ConcurrentSkipListMap$EntrySet * entrySet__;
  ::java::util::concurrent::ConcurrentSkipListMap$Values * values__;
  ::java::util::concurrent::ConcurrentNavigableMap * descendingMap__;
  static ::java::util::concurrent::atomic::AtomicReferenceFieldUpdater * headUpdater;
  static const jint EQ = 1;
  static const jint LT = 2;
  static const jint GT = 0;
public:
  static ::java::lang::Class class$;
};

#endif // __java_util_concurrent_ConcurrentSkipListMap__