• 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 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 Iter {
54     public:
55         Iter(const SkDeque& d);
56         void* next();
57 
58     private:
59         SkDeque::Head*  fHead;
60         char*           fPos;
61         size_t          fElemSize;
62     };
63 
64 private:
65     Head*   fFront;
66     Head*   fBack;
67     size_t  fElemSize;
68     void*   fInitialStorage;
69     int     fCount;
70 
71     friend class Iter;
72 };
73 
74 #endif
75