/*
* Copyright 2011 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkPathHeap_DEFINED
#define SkPathHeap_DEFINED
#include "SkRefCnt.h"
#include "SkChunkAlloc.h"
#include "SkTDArray.h"
class SkPath;
class SkReadBuffer;
class SkWriteBuffer;
class SkPathHeap : public SkRefCnt {
public:
SK_DECLARE_INST_COUNT(SkPathHeap)
SkPathHeap();
SkPathHeap(SkReadBuffer&);
virtual ~SkPathHeap();
/** Copy the path into the heap, and return the new total number of paths.
Thus, the returned value will be index+1, where index is the index of
this newly added (copied) path.
*/
int append(const SkPath&);
/** Add the specified path to the heap using its gen ID to de-duplicate.
Returns the path's index in the heap + 1.
*/
int insert(const SkPath&);
// called during picture-playback
int count() const { return fPaths.count(); }
const SkPath& operator[](int index) const {
return *fPaths[index];
}
void flatten(SkWriteBuffer&) const;
private:
// we store the paths in the heap (placement new)
SkChunkAlloc fHeap;
// we just store ptrs into fHeap here
SkTDArray<SkPath*> fPaths;
class LookupEntry {
public:
LookupEntry(const SkPath& path);
int storageSlot() const { return fStorageSlot; }
void setStorageSlot(int storageSlot) { fStorageSlot = storageSlot; }
static bool Less(const LookupEntry& a, const LookupEntry& b) {
return a.fGenerationID < b.fGenerationID;
}
private:
uint32_t fGenerationID; // the SkPath's generation ID
// the path's index in the heap + 1. It is 0 if the path is not yet in the heap.
int fStorageSlot;
};
SkTDArray<LookupEntry> fLookupTable;
SkPathHeap::LookupEntry* addIfNotPresent(const SkPath& path);
typedef SkRefCnt INHERITED;
};
#endif