diff options
Diffstat (limited to 'skia/include/SkDeque.h')
-rw-r--r-- | skia/include/SkDeque.h | 75 |
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 |