• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2006 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef SkDeque_DEFINED
18 #define SkDeque_DEFINED
19 
20 #include "SkTypes.h"
21 
22 class SK_API SkDeque : SkNoncopyable {
23 public:
24     explicit SkDeque(size_t elemSize);
25     SkDeque(size_t elemSize, void* storage, size_t storageSize);
26     ~SkDeque();
27 
empty()28     bool    empty() const { return 0 == fCount; }
count()29     int     count() const { return fCount; }
elemSize()30     size_t  elemSize() const { return fElemSize; }
31 
32     const void* front() const;
33     const void* back() const;
34 
front()35     void* front() {
36         return (void*)((const SkDeque*)this)->front();
37     }
38 
back()39     void* back() {
40         return (void*)((const SkDeque*)this)->back();
41     }
42 
43     void* push_front();
44     void* push_back();
45 
46     void pop_front();
47     void pop_back();
48 
49 private:
50     struct Head;
51 
52 public:
53     class F2BIter {
54     public:
55         /**
56          * Creates an uninitialized iterator. Must be reset()
57          */
58         F2BIter();
59 
60         F2BIter(const SkDeque& d);
61         void* next();
62 
63         void reset(const SkDeque& d);
64 
65     private:
66         SkDeque::Head*  fHead;
67         char*           fPos;
68         size_t          fElemSize;
69     };
70 
71 private:
72     Head*   fFront;
73     Head*   fBack;
74     size_t  fElemSize;
75     void*   fInitialStorage;
76     int     fCount;
77 
78     friend class Iter;
79 };
80 
81 #endif
82