Merge "Add create_trivial_array" into nyc-dev

am: 339fc0a1d2

* commit '339fc0a1d213fed1201443838a9536651ad2ca3b':
  Add create_trivial_array
This commit is contained in:
Chris Craik
2016-02-22 21:49:15 +00:00
committed by android-build-merger
4 changed files with 11 additions and 4 deletions

View File

@@ -239,7 +239,7 @@ void LayerBuilder::flushLayerClears(LinearAllocator& allocator) {
// put the verts in the frame allocator, since
// 1) SimpleRectsOps needs verts, not rects
// 2) even if mClearRects stored verts, std::vectors will move their contents
Vertex* const verts = (Vertex*) allocator.alloc<Vertex>(vertCount * sizeof(Vertex));
Vertex* const verts = (Vertex*) allocator.create_trivial_array<Vertex>(vertCount);
Vertex* currentVert = verts;
Rect bounds = mClearRects[0];

View File

@@ -290,7 +290,7 @@ void RecordingCanvas::drawRect(float left, float top, float right, float bottom,
void RecordingCanvas::drawSimpleRects(const float* rects, int vertexCount, const SkPaint* paint) {
if (rects == nullptr) return;
Vertex* rectData = (Vertex*) mDisplayList->allocator.alloc<Vertex>(vertexCount * sizeof(Vertex));
Vertex* rectData = (Vertex*) mDisplayList->allocator.create_trivial_array<Vertex>(vertexCount);
Vertex* vertex = rectData;
float left = FLT_MAX;

View File

@@ -44,7 +44,7 @@ namespace uirenderer {
*/
class RoundRectClipState {
public:
/** static void* operator new(size_t size); PURPOSELY OMITTED, allocator only **/
static void* operator new(size_t size) = delete;
static void* operator new(size_t size, LinearAllocator& allocator) {
return allocator.alloc<RoundRectClipState>(size);
}
@@ -65,7 +65,7 @@ public:
class ProjectionPathMask {
public:
/** static void* operator new(size_t size); PURPOSELY OMITTED, allocator only **/
static void* operator new(size_t size) = delete;
static void* operator new(size_t size, LinearAllocator& allocator) {
return allocator.alloc<ProjectionPathMask>(size);
}

View File

@@ -84,6 +84,13 @@ public:
return new (allocImpl(sizeof(T))) T(std::forward<Params>(params)...);
}
template<class T>
T* create_trivial_array(int count) {
static_assert(std::is_trivially_destructible<T>::value,
"Error, called create_trivial_array on a non-trivial type");
return reinterpret_cast<T*>(allocImpl(sizeof(T) * count));
}
/**
* Attempt to deallocate the given buffer, with the LinearAllocator attempting to rewind its
* state if possible.