From 9cf163e6732de5dce5b1d3b4ff7cbe19ba3a094b Mon Sep 17 00:00:00 2001 From: Tao Bao Date: Wed, 7 Nov 2018 10:15:50 -0800 Subject: minui: GRSurface manages data with std::unique_ptr. Test: Run recovery_unit_test on marlin. Test: `Run graphics test` on taimen. Change-Id: I34bd862049900b0030f2840a92a7fa3e02fa2c10 --- minui/include/minui/minui.h | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'minui/include') diff --git a/minui/include/minui/minui.h b/minui/include/minui/minui.h index 0b499e621..3231248a0 100644 --- a/minui/include/minui/minui.h +++ b/minui/include/minui/minui.h @@ -17,6 +17,7 @@ #pragma once #include +#include #include #include @@ -32,7 +33,7 @@ class GRSurface { public: - virtual ~GRSurface(); + virtual ~GRSurface() = default; // Creates and returns a GRSurface instance that's sufficient for storing an image of the given // size. The starting address of the surface data is aligned to SURFACE_DATA_ALIGNMENT. Returns @@ -44,7 +45,7 @@ class GRSurface { std::unique_ptr Clone() const; virtual uint8_t* data() { - return data_; + return data_.get(); } const uint8_t* data() const { @@ -61,7 +62,14 @@ class GRSurface { : width(width), height(height), row_bytes(row_bytes), pixel_bytes(pixel_bytes) {} private: - uint8_t* data_{ nullptr }; + // The deleter for data_, whose data is allocated via aligned_alloc(3). + struct DataDeleter { + void operator()(uint8_t* data) { + free(data); + } + }; + + std::unique_ptr data_; size_t data_size_; DISALLOW_COPY_AND_ASSIGN(GRSurface); -- cgit v1.2.3