Chromium Code Reviews| Index: include/core/SkImageFilter.h |
| diff --git a/include/core/SkImageFilter.h b/include/core/SkImageFilter.h |
| index d4930c4975935801a26b2e03fd59da3cdb3b62f8..55b9d9f033a895b5f473b32458ed4edc6027abb1 100644 |
| --- a/include/core/SkImageFilter.h |
| +++ b/include/core/SkImageFilter.h |
| @@ -205,13 +205,23 @@ protected: |
| Common() {} |
| ~Common(); |
| + /** |
| + * Attempt to unflatten the cropRect and the expected number of input filters. |
| + * If any number of input filters is valid, pass -1. |
| + * If this fails (i.e. corrupt buffer or contents) then return false and common will |
| + * be left uninitialized. |
| + * If this returns true, then inputCount() is the number of found input filters, each |
| + * of which may be NULL or a valid imagefilter. |
| + */ |
| bool unflatten(SkReadBuffer&, int expectedInputs = -1); |
| - CropRect cropRect() const { return fCropRect; } |
| + const CropRect& cropRect() const { return fCropRect; } |
| int inputCount() const { return fInputs.count(); } |
| SkImageFilter** inputs() const { return fInputs.get(); } |
| uint32_t uniqueID() const { return fUniqueID; } |
| + SkImageFilter* inputAt(int index) const { return fInputs[index]; } |
| + |
| // If the caller wants a copy of the inputs, call this and it will transfer ownership |
| // of the unflattened input filters to the caller. This is just a short-cut for copying |
| // the inputs, calling ref() on each, and then waiting for Common's destructor to call |
| @@ -240,7 +250,7 @@ protected: |
| */ |
| explicit SkImageFilter(int inputCount, SkReadBuffer& rb); |
| - virtual void flatten(SkWriteBuffer& wb) const SK_OVERRIDE; |
| + virtual void flatten(SkWriteBuffer&) const SK_OVERRIDE; |
| /** |
| * This is the virtual which should be overridden by the derived class |
| @@ -320,4 +330,17 @@ private: |
| uint32_t fUniqueID; // Globally unique |
| }; |
| +/** |
| + * Helper to unflatten the common data, and return NULL if we fail. |
| + * |
| + * Declares a local variable 'common', and expects a SkReadBuffer named 'buffer' |
| + */ |
| +#define SK_IMAGEFILTER_UNFLATTEN_COMMON(expectedCount) \ |
|
Stephen White
2014/08/18 18:17:26
This macro is too much magic, IMHO: putting a vari
reed1
2014/08/18 22:39:16
A downside of copy/pasting 4 lines everywhere is t
|
| + Common common; \ |
| + do { \ |
| + if (!common.unflatten(buffer, expectedCount)) { \ |
| + return NULL; \ |
| + } \ |
| + } while (0) |
| + |
| #endif |