summaryrefslogtreecommitdiffstats
path: root/skia/include/SkDeque.h
diff options
context:
space:
mode:
Diffstat (limited to 'skia/include/SkDeque.h')
-rw-r--r--skia/include/SkDeque.h75
1 files changed, 75 insertions, 0 deletions
diff --git a/skia/include/SkDeque.h b/skia/include/SkDeque.h
new file mode 100644
index 0000000..b66a541
--- /dev/null
+++ b/skia/include/SkDeque.h
@@ -0,0 +1,75 @@
+/* include/graphics/SkDeque.h
+**
+** Copyright 2006, Google Inc.
+**
+** Licensed under the Apache License, Version 2.0 (the "License");
+** you may not use this file except in compliance with the License.
+** You may obtain a copy of the License at
+**
+** http://www.apache.org/licenses/LICENSE-2.0
+**
+** Unless required by applicable law or agreed to in writing, software
+** distributed under the License is distributed on an "AS IS" BASIS,
+** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+** See the License for the specific language governing permissions and
+** limitations under the License.
+*/
+
+#ifndef SkDeque_DEFINED
+#define SkDeque_DEFINED
+
+#include "SkTypes.h"
+
+class SkDeque : SkNoncopyable {
+public:
+ explicit SkDeque(size_t elemSize);
+ SkDeque(size_t elemSize, void* storage, size_t storageSize);
+ ~SkDeque();
+
+ bool empty() const { return 0 == fCount; }
+ int count() const { return fCount; }
+ size_t elemSize() const { return fElemSize; }
+
+ const void* front() const;
+ const void* back() const;
+
+ void* front() {
+ return (void*)((const SkDeque*)this)->front();
+ }
+
+ void* back() {
+ return (void*)((const SkDeque*)this)->back();
+ }
+
+ void* push_front();
+ void* push_back();
+
+ void pop_front();
+ void pop_back();
+
+private:
+ struct Head;
+
+public:
+ class Iter {
+ public:
+ Iter(const SkDeque& d);
+ void* next();
+
+ private:
+ SkDeque::Head* fHead;
+ char* fPos;
+ size_t fElemSize;
+ };
+
+private:
+ Head* fFront;
+ Head* fBack;
+ size_t fElemSize;
+ void* fInitialStorage;
+ int fCount;
+
+ friend class Iter;
+};
+
+#endif