Chromium Code Reviews| Index: src/pipe/SkPipeFormat.h |
| diff --git a/src/pipe/SkPipeFormat.h b/src/pipe/SkPipeFormat.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..680b2faac1e30a9f762160b44460e4b3a7ce5570 |
| --- /dev/null |
| +++ b/src/pipe/SkPipeFormat.h |
| @@ -0,0 +1,180 @@ |
| +/* |
| + * Copyright 2016 Google Inc. |
| + * |
| + * Use of this source code is governed by a BSD-style license that can be |
| + * found in the LICENSE file. |
| + */ |
| + |
| +#ifndef SkPipeFormat_DEFINED |
| +#define SkPipeFormat_DEFINED |
| + |
| +#include "SkTypes.h" |
| + |
| +#define kDefinePicture_ExtPipeVerb SkSetFourByteTag('s', 'k', 'p', 'i') |
| +#define kDefineImage_ExtPipeVerb SkSetFourByteTag('s', 'k', 'i', 'm') |
| + |
| +enum class SkPipeVerb { |
|
mtklein
2016/08/26 18:43:23
may want to : uint8_t this to make it explicit?
reed1
2016/08/27 14:14:55
Done.
|
| + kSave, // extra == 0 |
| + kSaveLayer, |
| + kRestore, // extra == 0 |
| + kConcat, // extra == SkMatrix::MaskType |
| + |
| + kClipRect, // extra == (SkRegion::Op << 1) | isAntiAlias:1 |
| + kClipRRect, // extra == (SkRegion::Op << 1) | isAntiAlias:1 |
| + kClipPath, // extra == (SkRegion::Op << 1) | isAntiAlias:1 |
| + kClipRegion, // extra == (SkRegion::Op << 1) |
| + |
| + kDrawDRRect, |
| + kDrawText, // extra == byteLength:24 else next 32 |
| + kDrawPosText, // extra == byteLength:24 else next 32 |
| + kDrawPosTextH, // extra == byteLength:24 else next 32 |
| + kDrawTextOnPath, |
| + kDrawTextBlob, |
| + kDrawTextRSXform, // extra == (byteLength:23 << 1) else next 32 | has_cull_rect:1 |
| + kDrawPatch, |
| + kDrawPaint, // extra == 0 |
| + kDrawPoints, // extra == PointMode |
| + kDrawRect, // extra == 0 |
| + kDrawPath, // extra == 0 |
| + kDrawOval, // extra == 0 |
| + kDrawRRect, // extra == 0 |
| + |
| + kDrawImage, // extra == has_paint:1 |
| + kDrawImageRect, // extra == (has_src_rect:1 << 1) | has_paint:1 |
| + kDrawImageNine, // extra == has_paint:1 |
| + |
| + kDrawVertices, |
| + |
| + kDrawPicture, // extra == picture_index |
| + kDrawAnnotation, // extra == (key_len_plus_1:23 << 1) else next 32 | has_data:1 |
| + |
| + kDefineImage, // extra == image_index |
| + kDefinePicture, // extra == forget:1 | end:1 | 0:2 | picture_index |
| + kDefineTypeface, |
| + kDefineFactory, // extra == factory_index (followed by padded getTypeName string) |
| +}; |
| + |
| +enum PaintUsage { |
| + kText_PaintUsage = 1 << 0, |
| + kTextBlob_PaintUsage = 1 << 1, |
| + kGeometry_PaintUsage = 1 << 2, |
| + kImage_PaintUsage = 1 << 3, |
| + kSaveLayer_PaintUsage = 1 << 4, |
| + kDrawPaint_PaintUsage = 1 << 5, |
| + kVertices_PaintUsage = 1 << 6, |
| + kUnknown_PaintUsage = 0xFF, |
| +}; |
| + |
| +// must sum to <= 32 |
| +enum BitsPerField { |
| + kFlags_BPF = 16, |
| + kFilter_BPF = 2, |
| + kStyle_BPF = 2, |
| + kCaps_BPF = 2, |
| + kJoins_BPF = 2, |
| + kHint_BPF = 2, |
| + kAlign_BPF = 2, |
| + kEncoding_BPF = 2, |
| +}; |
| + |
| +enum { |
| + kTextSize_NonDef = 1 << 0, |
| + kTextScaleX_NonDef = 1 << 1, |
| + kTextSkewX_NonDef = 1 << 2, |
| + kStrokeWidth_NonDef = 1 << 3, |
| + kStrokeMiter_NonDef = 1 << 4, |
| + kColor_NonDef = 1 << 5, |
| + kTypeface_NonDef = 1 << 6, |
| + kPathEffect_NonDef = 1 << 7, |
| + kShader_NonDef = 1 << 8, |
| + kXfermode_NonDef = 1 << 9, |
| + kMaskFilter_NonDef = 1 << 10, |
| + kColorFilter_NonDef = 1 << 11, |
| + kRasterizer_NonDef = 1 << 12, |
| + kImageFilter_NonDef = 1 << 13, |
| +}; |
| + |
| +enum { |
| + kFlags_SaveLayerMask = 0xFF, |
| + kHasBounds_SaveLayerMask = 1 << 8, |
| + kHasPaint_SaveLayerMask = 1 << 9, |
| + kHasBackdrop_SaveLayerMask = 1 << 10, |
| +}; |
| + |
| +enum { |
| + kDefineObjectBits = 20, |
| + kIndex_DefineObjectMask = ((1 << kDefineObjectBits) - 1), |
| + kForget_DefineObjectMask = 1 << 23, |
| + kUser_DefineObjectMask = 0x7 << kDefineObjectBits, |
| + // (Forget:1 | User:3 | Index:20) must fit in extra:24 |
| +}; |
| + |
| +enum { |
| + kHasMatrix_DrawPictureExtra = 1 << 21, |
| + kHasPaint_DrawPictureExtra = 1 << 22, |
| +}; |
| + |
| +enum { |
| + kEnd_DefinePictureMask = 1 << 22, |
| +}; |
| + |
| +enum { |
| + kIndex_DefineFactoryExtraBits = 10, |
| + kNameLength_DefineFactoryExtraBits = 14, // includes trailing 0 |
| + kNameLength_DefineFactoryExtraMask = (1 << kNameLength_DefineFactoryExtraBits) - 1, |
| +}; |
| + |
| +enum { |
| + kModeEnum_DrawPatchExtraMask = 0xFF, |
| + kExplicitXfer_DrawPatchExtraValue = 0xFF, |
| + kHasColors_DrawPatchExtraMask = 0x100, |
| + kHasTexture_DrawPatchExtraMask = 0x200, |
| +}; |
| + |
| +enum { |
| + // if we store a zero for VCount, then read an int after the packedverb for the vcount |
| + kVCount_DrawVerticesMask = (1 << 11) - 1, |
| + |
| + kVMode_DrawVerticesShift = 11, |
| + kVMode_DrawVerticesMask = 3 << kVMode_DrawVerticesShift, |
| + |
| + kXMode_DrawVerticesShift = 13, |
| + kXMode_DrawVerticesMask = 0xFF << kXMode_DrawVerticesShift, |
| + |
| + kHasTex_DrawVerticesMask = 1 << 21, |
| + kHasColors_DrawVerticesMask = 1 << 22, |
| + kHasIndices_DrawVerticesMask = 1 << 23, |
| +}; |
| + |
| +enum { |
| + kTextLength_DrawTextOnPathMask = (1 << 16) - 1, |
| + kMatrixType_DrawTextOnPathShift = 16, |
| + kMatrixType_DrawTextOnPathMask = 0xF << kMatrixType_DrawTextOnPathShift, |
| +}; |
| + |
| +/////////////////////////////////////////////////////////////////////////////////////////////////// |
| + |
| +static inline bool fits_in(int value, int bits) { |
| + return value >= 0 && value < (1 << bits); |
| +} |
| + |
| +static inline void ASSERT_FITS_IN(int value, int bits) { |
| + SkASSERT(fits_in(value, bits)); |
| +} |
| + |
| +static inline uint32_t pack_verb(SkPipeVerb verb, unsigned extra = 0) { |
| + //SkDebugf("pack [%d] %d\n", verb, extra); |
| + ASSERT_FITS_IN((unsigned)verb, 8); |
| + ASSERT_FITS_IN(extra, 24); |
| + return ((uint32_t)verb << 24) | extra; |
| +} |
| + |
| +static inline SkPipeVerb unpack_verb(uint32_t data) { |
| + return (SkPipeVerb)(data >> 24); |
| +} |
| + |
| +static inline unsigned unpack_verb_extra(uint32_t data) { |
| + return data & 0xFFFFFF; |
| +} |
| + |
| +#endif |