2008-12-17 15:59:43 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2006 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* 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"
|
|
|
|
|
2011-03-15 21:27:08 +00:00
|
|
|
class SK_API SkDeque : SkNoncopyable {
|
2008-12-17 15:59:43 +00:00
|
|
|
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();
|
2011-02-22 13:16:38 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
void pop_front();
|
|
|
|
void pop_back();
|
|
|
|
|
|
|
|
private:
|
|
|
|
struct Head;
|
|
|
|
|
|
|
|
public:
|
2011-02-22 13:16:38 +00:00
|
|
|
class F2BIter {
|
2008-12-17 15:59:43 +00:00
|
|
|
public:
|
2011-03-03 13:54:13 +00:00
|
|
|
/**
|
|
|
|
* Creates an uninitialized iterator. Must be reset()
|
|
|
|
*/
|
|
|
|
F2BIter();
|
|
|
|
|
2011-02-22 13:16:38 +00:00
|
|
|
F2BIter(const SkDeque& d);
|
2008-12-17 15:59:43 +00:00
|
|
|
void* next();
|
|
|
|
|
2011-03-03 13:54:13 +00:00
|
|
|
void reset(const SkDeque& d);
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
private:
|
|
|
|
SkDeque::Head* fHead;
|
|
|
|
char* fPos;
|
|
|
|
size_t fElemSize;
|
|
|
|
};
|
|
|
|
|
|
|
|
private:
|
|
|
|
Head* fFront;
|
|
|
|
Head* fBack;
|
|
|
|
size_t fElemSize;
|
|
|
|
void* fInitialStorage;
|
|
|
|
int fCount;
|
2011-02-22 13:16:38 +00:00
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
friend class Iter;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|