[subset] update COLRv1 table struct definitions

This commit is contained in:
Qunxin Liu 2021-08-03 16:31:42 -07:00 committed by Behdad Esfahbod
parent 792ca307b0
commit d2e986fead
2 changed files with 358 additions and 168 deletions

View File

@ -163,15 +163,25 @@ struct BaseGlyphRecord
template <typename T> template <typename T>
struct Variable struct Variable
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const
{ value.closurev1 (c); }
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
if (!value.subset (c)) return_trace (false);
return_trace (c->serializer->embed (varIndexBase));
}
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
{ {
TRACE_SANITIZE (this); TRACE_SANITIZE (this);
return_trace (c->check_struct (this)); return_trace (c->check_struct (this) && value.sanitize (c));
} }
protected: protected:
T value; T value;
VarIdx varIdx; VarIdx varIndexBase;
public: public:
DEFINE_SIZE_STATIC (4 + T::static_size); DEFINE_SIZE_STATIC (4 + T::static_size);
}; };
@ -179,10 +189,19 @@ struct Variable
template <typename T> template <typename T>
struct NoVariable struct NoVariable
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const
{ value.closurev1 (c); }
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
return_trace (value.subset (c));
}
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
{ {
TRACE_SANITIZE (this); TRACE_SANITIZE (this);
return_trace (c->check_struct (this)); return_trace (c->check_struct (this) && value.sanitize (c));
} }
T value; T value;
@ -192,9 +211,11 @@ struct NoVariable
// Color structures // Color structures
template <template<typename> class Var> struct ColorStop
struct ColorIndex
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const
{ c->add_palette_index (paletteIndex); }
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
TRACE_SUBSET (this); TRACE_SUBSET (this);
@ -210,32 +231,11 @@ struct ColorIndex
return_trace (c->check_struct (this)); return_trace (c->check_struct (this));
} }
F2DOT14 stopOffset;
HBUINT16 paletteIndex; HBUINT16 paletteIndex;
Var<F2DOT14> alpha; F2DOT14 alpha;
public: public:
DEFINE_SIZE_STATIC (2 + Var<F2DOT14>::static_size); DEFINE_SIZE_STATIC (2 + 2 * F2DOT14::static_size);
};
template <template<typename> class Var>
struct ColorStop
{
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
if (unlikely (!c->serializer->embed (stopOffset))) return_trace (false);
return_trace (color.subset (c));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this));
}
Var<F2DOT14> stopOffset;
ColorIndex<Var> color;
public:
DEFINE_SIZE_STATIC (Var<F2DOT14>::static_size + ColorIndex<Var>::static_size);
}; };
struct Extend : HBUINT8 struct Extend : HBUINT8
@ -252,6 +252,12 @@ struct Extend : HBUINT8
template <template<typename> class Var> template <template<typename> class Var>
struct ColorLine struct ColorLine
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const
{
for (const auto &stop : stops.iter ())
stop.closurev1 (c);
}
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
TRACE_SUBSET (this); TRACE_SUBSET (this);
@ -277,7 +283,7 @@ struct ColorLine
} }
Extend extend; Extend extend;
Array16Of<ColorStop<Var>> stops; Array16Of<Var<ColorStop>> stops;
public: public:
DEFINE_SIZE_ARRAY_SIZED (3, stops); DEFINE_SIZE_ARRAY_SIZED (3, stops);
}; };
@ -331,7 +337,6 @@ struct CompositeMode : HBUINT8
DEFINE_SIZE_STATIC (1); DEFINE_SIZE_STATIC (1);
}; };
template <template<typename> class Var>
struct Affine2x3 struct Affine2x3
{ {
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
@ -340,14 +345,14 @@ struct Affine2x3
return_trace (c->check_struct (this)); return_trace (c->check_struct (this));
} }
Var<HBFixed> xx; HBFixed xx;
Var<HBFixed> yx; HBFixed yx;
Var<HBFixed> xy; HBFixed xy;
Var<HBFixed> yy; HBFixed yy;
Var<HBFixed> dx; HBFixed dx;
Var<HBFixed> dy; HBFixed dy;
public: public:
DEFINE_SIZE_STATIC (6 * Var<HBFixed>::static_size); DEFINE_SIZE_STATIC (6 * HBFixed::static_size);
}; };
struct PaintColrLayers struct PaintColrLayers
@ -373,22 +378,23 @@ struct PaintColrLayers
HBUINT8 format; /* format = 1 */ HBUINT8 format; /* format = 1 */
HBUINT8 numLayers; HBUINT8 numLayers;
HBUINT32 firstLayerIndex; /* index into COLRv1::layersV1 */ HBUINT32 firstLayerIndex; /* index into COLRv1::layerList */
public: public:
DEFINE_SIZE_STATIC (6); DEFINE_SIZE_STATIC (6);
}; };
template <template<typename> class Var>
struct PaintSolid struct PaintSolid
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const void closurev1 (hb_colrv1_closure_context_t* c) const
{ c->add_palette_index (color.paletteIndex); } { c->add_palette_index (paletteIndex); }
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
TRACE_SUBSET (this); TRACE_SUBSET (this);
if (unlikely (!c->serializer->embed (format))) return_trace (false); auto *out = c->serializer->embed (*this);
return_trace (color.subset (c)); if (unlikely (!out)) return_trace (false);
return_trace (c->serializer->check_assign (out->paletteIndex, c->plan->colr_palettes->get (paletteIndex),
HB_SERIALIZE_ERROR_INT_OVERFLOW));
} }
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
@ -398,19 +404,17 @@ struct PaintSolid
} }
HBUINT8 format; /* format = 2(noVar) or 3(Var)*/ HBUINT8 format; /* format = 2(noVar) or 3(Var)*/
ColorIndex<Var> color; HBUINT16 paletteIndex;
F2DOT14 alpha;
public: public:
DEFINE_SIZE_STATIC (1 + ColorIndex<Var>::static_size); DEFINE_SIZE_STATIC (3 + F2DOT14::static_size);
}; };
template <template<typename> class Var> template <template<typename> class Var>
struct PaintLinearGradient struct PaintLinearGradient
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const void closurev1 (hb_colrv1_closure_context_t* c) const
{ { (this+colorLine).closurev1 (c); }
for (const auto &stop : (this+colorLine).stops.iter ())
c->add_palette_index (stop.color.paletteIndex);
}
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
@ -430,19 +434,22 @@ struct PaintLinearGradient
HBUINT8 format; /* format = 4(noVar) or 5 (Var) */ HBUINT8 format; /* format = 4(noVar) or 5 (Var) */
Offset24To<ColorLine<Var>> colorLine; /* Offset (from beginning of PaintLinearGradient Offset24To<ColorLine<Var>> colorLine; /* Offset (from beginning of PaintLinearGradient
* table) to ColorLine subtable. */ * table) to ColorLine subtable. */
Var<FWORD> x0; FWORD x0;
Var<FWORD> y0; FWORD y0;
Var<FWORD> x1; FWORD x1;
Var<FWORD> y1; FWORD y1;
Var<FWORD> x2; FWORD x2;
Var<FWORD> y2; FWORD y2;
public: public:
DEFINE_SIZE_STATIC (4 + 6 * Var<FWORD>::static_size); DEFINE_SIZE_STATIC (4 + 6 * FWORD::static_size);
}; };
template <template<typename> class Var> template <template<typename> class Var>
struct PaintRadialGradient struct PaintRadialGradient
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+colorLine).closurev1 (c); }
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
TRACE_SUBSET (this); TRACE_SUBSET (this);
@ -452,12 +459,6 @@ struct PaintRadialGradient
return_trace (out->colorLine.serialize_subset (c, colorLine, this)); return_trace (out->colorLine.serialize_subset (c, colorLine, this));
} }
void closurev1 (hb_colrv1_closure_context_t* c) const
{
for (const auto &stop : (this+colorLine).stops.iter ())
c->add_palette_index (stop.color.paletteIndex);
}
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
{ {
TRACE_SANITIZE (this); TRACE_SANITIZE (this);
@ -467,19 +468,22 @@ struct PaintRadialGradient
HBUINT8 format; /* format = 6(noVar) or 7 (Var) */ HBUINT8 format; /* format = 6(noVar) or 7 (Var) */
Offset24To<ColorLine<Var>> colorLine; /* Offset (from beginning of PaintRadialGradient Offset24To<ColorLine<Var>> colorLine; /* Offset (from beginning of PaintRadialGradient
* table) to ColorLine subtable. */ * table) to ColorLine subtable. */
Var<FWORD> x0; FWORD x0;
Var<FWORD> y0; FWORD y0;
Var<UFWORD> radius0; UFWORD radius0;
Var<FWORD> x1; FWORD x1;
Var<FWORD> y1; FWORD y1;
Var<UFWORD> radius1; UFWORD radius1;
public: public:
DEFINE_SIZE_STATIC (4 + 6 * Var<FWORD>::static_size); DEFINE_SIZE_STATIC (4 + 6 * FWORD::static_size);
}; };
template <template<typename> class Var> template <template<typename> class Var>
struct PaintSweepGradient struct PaintSweepGradient
{ {
void closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+colorLine).closurev1 (c); }
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
TRACE_SUBSET (this); TRACE_SUBSET (this);
@ -489,12 +493,6 @@ struct PaintSweepGradient
return_trace (out->colorLine.serialize_subset (c, colorLine, this)); return_trace (out->colorLine.serialize_subset (c, colorLine, this));
} }
void closurev1 (hb_colrv1_closure_context_t* c) const
{
for (const auto &stop : (this+colorLine).stops.iter ())
c->add_palette_index (stop.color.paletteIndex);
}
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
{ {
TRACE_SANITIZE (this); TRACE_SANITIZE (this);
@ -504,12 +502,12 @@ struct PaintSweepGradient
HBUINT8 format; /* format = 8(noVar) or 9 (Var) */ HBUINT8 format; /* format = 8(noVar) or 9 (Var) */
Offset24To<ColorLine<Var>> colorLine; /* Offset (from beginning of PaintSweepGradient Offset24To<ColorLine<Var>> colorLine; /* Offset (from beginning of PaintSweepGradient
* table) to ColorLine subtable. */ * table) to ColorLine subtable. */
Var<FWORD> centerX; FWORD centerX;
Var<FWORD> centerY; FWORD centerY;
Var<HBFixed> startAngle; F2DOT14 startAngle;
Var<HBFixed> endAngle; F2DOT14 endAngle;
public: public:
DEFINE_SIZE_STATIC (2 * Var<FWORD>::static_size + 2 * Var<HBFixed>::static_size); DEFINE_SIZE_STATIC (4 + 2 * FWORD::static_size + 2 * F2DOT14::static_size);
}; };
struct Paint; struct Paint;
@ -592,12 +590,11 @@ struct PaintTransform
HBUINT8 format; /* format = 12(noVar) or 13 (Var) */ HBUINT8 format; /* format = 12(noVar) or 13 (Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintTransform table) to Paint subtable. */ Offset24To<Paint> src; /* Offset (from beginning of PaintTransform table) to Paint subtable. */
Affine2x3<Var> transform; Var<Affine2x3> transform;
public: public:
DEFINE_SIZE_STATIC (4 + Affine2x3<Var>::static_size); DEFINE_SIZE_STATIC (4 + Var<Affine2x3>::static_size);
}; };
template <template<typename> class Var>
struct PaintTranslate struct PaintTranslate
{ {
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const; HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
@ -619,14 +616,13 @@ struct PaintTranslate
HBUINT8 format; /* format = 14(noVar) or 15 (Var) */ HBUINT8 format; /* format = 14(noVar) or 15 (Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintTranslate table) to Paint subtable. */ Offset24To<Paint> src; /* Offset (from beginning of PaintTranslate table) to Paint subtable. */
Var<HBFixed> dx; FWORD dx;
Var<HBFixed> dy; FWORD dy;
public: public:
DEFINE_SIZE_STATIC (4 + Var<HBFixed>::static_size); DEFINE_SIZE_STATIC (4 + 2 * FWORD::static_size);
}; };
template <template<typename> class Var> struct PaintScale
struct PaintRotate
{ {
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const; HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
@ -646,16 +642,14 @@ struct PaintRotate
} }
HBUINT8 format; /* format = 16 (noVar) or 17(Var) */ HBUINT8 format; /* format = 16 (noVar) or 17(Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintRotate table) to Paint subtable. */ Offset24To<Paint> src; /* Offset (from beginning of PaintScale table) to Paint subtable. */
Var<HBFixed> angle; F2DOT14 scaleX;
Var<HBFixed> centerX; F2DOT14 scaleY;
Var<HBFixed> centerY;
public: public:
DEFINE_SIZE_STATIC (4 + 3 * Var<HBFixed>::static_size); DEFINE_SIZE_STATIC (4 + 2 * F2DOT14::static_size);
}; };
template <template<typename> class Var> struct PaintScaleAroundCenter
struct PaintSkew
{ {
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const; HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
@ -675,13 +669,177 @@ struct PaintSkew
} }
HBUINT8 format; /* format = 18 (noVar) or 19(Var) */ HBUINT8 format; /* format = 18 (noVar) or 19(Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintSkew table) to Paint subtable. */ Offset24To<Paint> src; /* Offset (from beginning of PaintScaleAroundCenter table) to Paint subtable. */
Var<HBFixed> xSkewAngle; F2DOT14 scaleX;
Var<HBFixed> ySkewAngle; F2DOT14 scaleY;
Var<HBFixed> centerX; FWORD centerX;
Var<HBFixed> centerY; FWORD centerY;
public: public:
DEFINE_SIZE_STATIC (4 + 4 * Var<HBFixed>::static_size); DEFINE_SIZE_STATIC (4 + 2 * F2DOT14::static_size + 2 * FWORD::static_size);
};
struct PaintScaleUniform
{
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
auto *out = c->serializer->embed (this);
if (unlikely (!out)) return_trace (false);
return_trace (out->src.serialize_subset (c, src, this));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) && src.sanitize (c, this));
}
HBUINT8 format; /* format = 20 (noVar) or 21(Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintScaleUniform table) to Paint subtable. */
F2DOT14 scale;
public:
DEFINE_SIZE_STATIC (4 + F2DOT14::static_size);
};
struct PaintScaleUniformAroundCenter
{
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
auto *out = c->serializer->embed (this);
if (unlikely (!out)) return_trace (false);
return_trace (out->src.serialize_subset (c, src, this));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) && src.sanitize (c, this));
}
HBUINT8 format; /* format = 22 (noVar) or 23(Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintScaleUniformAroundCenter table) to Paint subtable. */
F2DOT14 scale;
FWORD centerX;
FWORD centerY;
public:
DEFINE_SIZE_STATIC (4 + F2DOT14::static_size + 2 * FWORD::static_size);
};
struct PaintRotate
{
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
auto *out = c->serializer->embed (this);
if (unlikely (!out)) return_trace (false);
return_trace (out->src.serialize_subset (c, src, this));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) && src.sanitize (c, this));
}
HBUINT8 format; /* format = 24 (noVar) or 25(Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintRotate table) to Paint subtable. */
F2DOT14 angle;
public:
DEFINE_SIZE_STATIC (4 + F2DOT14::static_size);
};
struct PaintRotateAroundCenter
{
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
auto *out = c->serializer->embed (this);
if (unlikely (!out)) return_trace (false);
return_trace (out->src.serialize_subset (c, src, this));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) && src.sanitize (c, this));
}
HBUINT8 format; /* format = 26 (noVar) or 27(Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintRotateAroundCenter table) to Paint subtable. */
F2DOT14 angle;
FWORD centerX;
FWORD centerY;
public:
DEFINE_SIZE_STATIC (4 + F2DOT14::static_size + 2 * FWORD::static_size);
};
struct PaintSkew
{
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
auto *out = c->serializer->embed (this);
if (unlikely (!out)) return_trace (false);
return_trace (out->src.serialize_subset (c, src, this));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) && src.sanitize (c, this));
}
HBUINT8 format; /* format = 28(noVar) or 29 (Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintSkew table) to Paint subtable. */
F2DOT14 xSkewAngle;
F2DOT14 ySkewAngle;
public:
DEFINE_SIZE_STATIC (4 + 2 * F2DOT14::static_size);
};
struct PaintSkewAroundCenter
{
HB_INTERNAL void closurev1 (hb_colrv1_closure_context_t* c) const;
bool subset (hb_subset_context_t *c) const
{
TRACE_SUBSET (this);
auto *out = c->serializer->embed (this);
if (unlikely (!out)) return_trace (false);
return_trace (out->src.serialize_subset (c, src, this));
}
bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) && src.sanitize (c, this));
}
HBUINT8 format; /* format = 30(noVar) or 31 (Var) */
Offset24To<Paint> src; /* Offset (from beginning of PaintSkewAroundCenter table) to Paint subtable. */
F2DOT14 xSkewAngle;
F2DOT14 ySkewAngle;
FWORD centerX;
FWORD centerY;
public:
DEFINE_SIZE_STATIC (4 + 2 * F2DOT14::static_size + 2 * FWORD::static_size);
}; };
struct PaintComposite struct PaintComposite
@ -706,7 +864,7 @@ struct PaintComposite
backdrop.sanitize (c, this)); backdrop.sanitize (c, this));
} }
HBUINT8 format; /* format = 20 */ HBUINT8 format; /* format = 32 */
Offset24To<Paint> src; /* Offset (from beginning of PaintComposite table) to source Paint subtable. */ Offset24To<Paint> src; /* Offset (from beginning of PaintComposite table) to source Paint subtable. */
CompositeMode mode; /* If mode is unrecognized use COMPOSITE_CLEAR */ CompositeMode mode; /* If mode is unrecognized use COMPOSITE_CLEAR */
Offset24To<Paint> backdrop; /* Offset (from beginning of PaintComposite table) to backdrop Paint subtable. */ Offset24To<Paint> backdrop; /* Offset (from beginning of PaintComposite table) to backdrop Paint subtable. */
@ -742,6 +900,18 @@ struct Paint
case 18: return_trace (c->dispatch (u.paintformat18, hb_forward<Ts> (ds)...)); case 18: return_trace (c->dispatch (u.paintformat18, hb_forward<Ts> (ds)...));
case 19: return_trace (c->dispatch (u.paintformat19, hb_forward<Ts> (ds)...)); case 19: return_trace (c->dispatch (u.paintformat19, hb_forward<Ts> (ds)...));
case 20: return_trace (c->dispatch (u.paintformat20, hb_forward<Ts> (ds)...)); case 20: return_trace (c->dispatch (u.paintformat20, hb_forward<Ts> (ds)...));
case 21: return_trace (c->dispatch (u.paintformat21, hb_forward<Ts> (ds)...));
case 22: return_trace (c->dispatch (u.paintformat22, hb_forward<Ts> (ds)...));
case 23: return_trace (c->dispatch (u.paintformat23, hb_forward<Ts> (ds)...));
case 24: return_trace (c->dispatch (u.paintformat24, hb_forward<Ts> (ds)...));
case 25: return_trace (c->dispatch (u.paintformat25, hb_forward<Ts> (ds)...));
case 26: return_trace (c->dispatch (u.paintformat26, hb_forward<Ts> (ds)...));
case 27: return_trace (c->dispatch (u.paintformat27, hb_forward<Ts> (ds)...));
case 28: return_trace (c->dispatch (u.paintformat28, hb_forward<Ts> (ds)...));
case 29: return_trace (c->dispatch (u.paintformat29, hb_forward<Ts> (ds)...));
case 30: return_trace (c->dispatch (u.paintformat30, hb_forward<Ts> (ds)...));
case 31: return_trace (c->dispatch (u.paintformat31, hb_forward<Ts> (ds)...));
case 32: return_trace (c->dispatch (u.paintformat32, hb_forward<Ts> (ds)...));
default:return_trace (c->default_return_value ()); default:return_trace (c->default_return_value ());
} }
} }
@ -750,29 +920,41 @@ struct Paint
union { union {
HBUINT8 format; HBUINT8 format;
PaintColrLayers paintformat1; PaintColrLayers paintformat1;
PaintSolid<NoVariable> paintformat2; PaintSolid paintformat2;
PaintSolid<Variable> paintformat3; Variable<PaintSolid> paintformat3;
PaintLinearGradient<NoVariable> paintformat4; PaintLinearGradient<NoVariable> paintformat4;
PaintLinearGradient<Variable> paintformat5; Variable<PaintLinearGradient<Variable>> paintformat5;
PaintRadialGradient<NoVariable> paintformat6; PaintRadialGradient<NoVariable> paintformat6;
PaintRadialGradient<Variable> paintformat7; Variable<PaintRadialGradient<Variable>> paintformat7;
PaintSweepGradient<NoVariable> paintformat8; PaintSweepGradient<NoVariable> paintformat8;
PaintSweepGradient<Variable> paintformat9; Variable<PaintSweepGradient<Variable>> paintformat9;
PaintGlyph paintformat10; PaintGlyph paintformat10;
PaintColrGlyph paintformat11; PaintColrGlyph paintformat11;
PaintTransform<NoVariable> paintformat12; PaintTransform<NoVariable> paintformat12;
PaintTransform<Variable> paintformat13; PaintTransform<Variable> paintformat13;
PaintTranslate<NoVariable> paintformat14; PaintTranslate paintformat14;
PaintTranslate<Variable> paintformat15; Variable<PaintTranslate> paintformat15;
PaintRotate<NoVariable> paintformat16; PaintScale paintformat16;
PaintRotate<Variable> paintformat17; Variable<PaintScale> paintformat17;
PaintSkew<NoVariable> paintformat18; PaintScaleAroundCenter paintformat18;
PaintSkew<Variable> paintformat19; Variable<PaintScaleAroundCenter> paintformat19;
PaintComposite paintformat20; PaintScaleUniform paintformat20;
Variable<PaintScaleUniform> paintformat21;
PaintScaleUniformAroundCenter paintformat22;
Variable<PaintScaleUniformAroundCenter> paintformat23;
PaintRotate paintformat24;
Variable<PaintRotate> paintformat25;
PaintRotateAroundCenter paintformat26;
Variable<PaintRotateAroundCenter> paintformat27;
PaintSkew paintformat28;
Variable<PaintSkew> paintformat29;
PaintSkewAroundCenter paintformat30;
Variable<PaintSkewAroundCenter> paintformat31;
PaintComposite paintformat32;
} u; } u;
}; };
struct BaseGlyphV1Record struct BaseGlyphPaintRecord
{ {
int cmp (hb_codepoint_t g) const int cmp (hb_codepoint_t g) const
{ return g < glyphId ? -1 : g > glyphId ? 1 : 0; } { return g < glyphId ? -1 : g > glyphId ? 1 : 0; }
@ -798,13 +980,13 @@ struct BaseGlyphV1Record
public: public:
HBGlyphID16 glyphId; /* Glyph ID of reference glyph */ HBGlyphID16 glyphId; /* Glyph ID of reference glyph */
Offset32To<Paint> paint; /* Offset (from beginning of BaseGlyphV1Record array) to Paint, Offset32To<Paint> paint; /* Offset (from beginning of BaseGlyphPaintRecord array) to Paint,
* Typically PaintColrLayers */ * Typically PaintColrLayers */
public: public:
DEFINE_SIZE_STATIC (6); DEFINE_SIZE_STATIC (6);
}; };
struct BaseGlyphV1List : SortedArray32Of<BaseGlyphV1Record> struct BaseGlyphList : SortedArray32Of<BaseGlyphPaintRecord>
{ {
bool subset (hb_subset_context_t *c) const bool subset (hb_subset_context_t *c) const
{ {
@ -828,11 +1010,11 @@ struct BaseGlyphV1List : SortedArray32Of<BaseGlyphV1Record>
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
{ {
TRACE_SANITIZE (this); TRACE_SANITIZE (this);
return_trace (SortedArray32Of<BaseGlyphV1Record>::sanitize (c, this)); return_trace (SortedArray32Of<BaseGlyphPaintRecord>::sanitize (c, this));
} }
}; };
struct LayerV1List : Array32OfOffset32To<Paint> struct LayerList : Array32OfOffset32To<Paint>
{ {
const Paint& get_paint (unsigned i) const const Paint& get_paint (unsigned i) const
{ return this+(*this)[i]; } { return this+(*this)[i]; }
@ -952,24 +1134,24 @@ struct COLR
hb_set_t visited_glyphs; hb_set_t visited_glyphs;
hb_colrv1_closure_context_t c (this, &visited_glyphs, layer_indices, palette_indices); hb_colrv1_closure_context_t c (this, &visited_glyphs, layer_indices, palette_indices);
const BaseGlyphV1List &baseglyphV1_records = this+baseGlyphsV1List; const BaseGlyphList &baseglyph_paintrecords = this+baseGlyphList;
for (const BaseGlyphV1Record &baseglyphV1record: baseglyphV1_records.iter ()) for (const BaseGlyphPaintRecord &baseglyph_paintrecord: baseglyph_paintrecords.iter ())
{ {
unsigned gid = baseglyphV1record.glyphId; unsigned gid = baseglyph_paintrecord.glyphId;
if (!glyphset->has (gid)) continue; if (!glyphset->has (gid)) continue;
const Paint &paint = &baseglyphV1_records+baseglyphV1record.paint; const Paint &paint = &baseglyph_paintrecords+baseglyph_paintrecord.paint;
paint.dispatch (&c); paint.dispatch (&c);
} }
hb_set_union (glyphset, &visited_glyphs); hb_set_union (glyphset, &visited_glyphs);
} }
const LayerV1List& get_layerV1List () const const LayerList& get_layerList () const
{ return (this+layersV1); } { return (this+layerList); }
const BaseGlyphV1List& get_baseglyphV1List () const const BaseGlyphList& get_baseglyphList () const
{ return (this+baseGlyphsV1List); } { return (this+baseGlyphList); }
bool sanitize (hb_sanitize_context_t *c) const bool sanitize (hb_sanitize_context_t *c) const
{ {
@ -979,8 +1161,8 @@ struct COLR
(this+layersZ).sanitize (c, numLayers) && (this+layersZ).sanitize (c, numLayers) &&
(version == 0 || (version == 0 ||
(COLRV1_ENABLE_SUBSETTING && version == 1 && (COLRV1_ENABLE_SUBSETTING && version == 1 &&
baseGlyphsV1List.sanitize (c, this) && baseGlyphList.sanitize (c, this) &&
layersV1.sanitize (c, this) && layerList.sanitize (c, this) &&
varStore.sanitize (c, this)))); varStore.sanitize (c, this))));
} }
@ -1033,9 +1215,9 @@ struct COLR
return record; return record;
} }
const BaseGlyphV1Record* get_base_glyphV1_record (hb_codepoint_t gid) const const BaseGlyphPaintRecord* get_base_glyph_paintrecord (hb_codepoint_t gid) const
{ {
const BaseGlyphV1Record* record = &(this+baseGlyphsV1List).bsearch ((unsigned) gid); const BaseGlyphPaintRecord* record = &(this+baseGlyphList).bsearch ((unsigned) gid);
if ((record && (hb_codepoint_t) record->glyphId != gid)) if ((record && (hb_codepoint_t) record->glyphId != gid))
record = nullptr; record = nullptr;
return record; return record;
@ -1106,7 +1288,7 @@ struct COLR
if (version == 0) return_trace (ret); if (version == 0) return_trace (ret);
auto snap = c->serializer->snapshot (); auto snap = c->serializer->snapshot ();
if (!c->serializer->allocate_size<void> (3 * HBUINT32::static_size)) return_trace (false); if (!c->serializer->allocate_size<void> (3 * HBUINT32::static_size)) return_trace (false);
if (!colr_prime->baseGlyphsV1List.serialize_subset (c, baseGlyphsV1List, this)) if (!colr_prime->baseGlyphList.serialize_subset (c, baseGlyphList, this))
{ {
if (c->serializer->in_error ()) return_trace (false); if (c->serializer->in_error ()) return_trace (false);
//no more COLRv1 glyphs: downgrade to version 0 //no more COLRv1 glyphs: downgrade to version 0
@ -1115,7 +1297,7 @@ struct COLR
return_trace (true); return_trace (true);
} }
if (!colr_prime->layersV1.serialize_subset (c, layersV1, this)) return_trace (false); if (!colr_prime->layerList.serialize_subset (c, layerList, this)) return_trace (false);
colr_prime->varStore = 0; colr_prime->varStore = 0;
//TODO: subset varStore once it's implemented in fonttools //TODO: subset varStore once it's implemented in fonttools
@ -1131,8 +1313,9 @@ struct COLR
layersZ; /* Offset to Layer Records. */ layersZ; /* Offset to Layer Records. */
HBUINT16 numLayers; /* Number of Layer Records. */ HBUINT16 numLayers; /* Number of Layer Records. */
// Version-1 additions // Version-1 additions
Offset32To<BaseGlyphV1List> baseGlyphsV1List; Offset32To<BaseGlyphList> baseGlyphList;
Offset32To<LayerV1List> layersV1; Offset32To<LayerList> layerList;
//Offset32<DeltaSetIndexMap> varIdxMap; // Offset to DeltaSetIndexMap table (may be NULL)
Offset32To<VariationStore> varStore; Offset32To<VariationStore> varStore;
public: public:
DEFINE_SIZE_MIN (14); DEFINE_SIZE_MIN (14);

View File

@ -40,7 +40,7 @@ namespace OT {
HB_INTERNAL void PaintColrLayers::closurev1 (hb_colrv1_closure_context_t* c) const HB_INTERNAL void PaintColrLayers::closurev1 (hb_colrv1_closure_context_t* c) const
{ {
c->add_layer_indices (firstLayerIndex, numLayers); c->add_layer_indices (firstLayerIndex, numLayers);
const LayerV1List &paint_offset_lists = c->get_colr_table ()->get_layerV1List (); const LayerList &paint_offset_lists = c->get_colr_table ()->get_layerList ();
for (unsigned i = firstLayerIndex; i < firstLayerIndex + numLayers; i++) for (unsigned i = firstLayerIndex; i < firstLayerIndex + numLayers; i++)
{ {
const Paint &paint = hb_addressof (paint_offset_lists) + paint_offset_lists[i]; const Paint &paint = hb_addressof (paint_offset_lists) + paint_offset_lists[i];
@ -57,37 +57,44 @@ HB_INTERNAL void PaintGlyph::closurev1 (hb_colrv1_closure_context_t* c) const
HB_INTERNAL void PaintColrGlyph::closurev1 (hb_colrv1_closure_context_t* c) const HB_INTERNAL void PaintColrGlyph::closurev1 (hb_colrv1_closure_context_t* c) const
{ {
const COLR *colr_table = c->get_colr_table (); const COLR *colr_table = c->get_colr_table ();
const BaseGlyphV1Record* baseglyphV1_record = colr_table->get_base_glyphV1_record (gid); const BaseGlyphPaintRecord* baseglyph_paintrecord = colr_table->get_base_glyph_paintrecord (gid);
if (!baseglyphV1_record) return; if (!baseglyph_paintrecord) return;
c->add_glyph (gid); c->add_glyph (gid);
const BaseGlyphV1List &baseglyphV1_list = colr_table->get_baseglyphV1List (); const BaseGlyphList &baseglyph_list = colr_table->get_baseglyphList ();
(&baseglyphV1_list+baseglyphV1_record->paint).dispatch (c); (&baseglyph_list+baseglyph_paintrecord->paint).dispatch (c);
} }
template <template<typename> class Var> template <template<typename> class Var>
HB_INTERNAL void PaintTransform<Var>::closurev1 (hb_colrv1_closure_context_t* c) const HB_INTERNAL void PaintTransform<Var>::closurev1 (hb_colrv1_closure_context_t* c) const
{ { (this+src).dispatch (c); }
(this+src).dispatch (c);
}
template <template<typename> class Var> HB_INTERNAL void PaintTranslate::closurev1 (hb_colrv1_closure_context_t* c) const
HB_INTERNAL void PaintTranslate<Var>::closurev1 (hb_colrv1_closure_context_t* c) const { (this+src).dispatch (c); }
{
(this+src).dispatch (c);
}
template <template<typename> class Var> HB_INTERNAL void PaintScale::closurev1 (hb_colrv1_closure_context_t* c) const
HB_INTERNAL void PaintRotate<Var>::closurev1 (hb_colrv1_closure_context_t* c) const { (this+src).dispatch (c); }
{
(this+src).dispatch (c);
}
template <template<typename> class Var> HB_INTERNAL void PaintScaleAroundCenter::closurev1 (hb_colrv1_closure_context_t* c) const
HB_INTERNAL void PaintSkew<Var>::closurev1 (hb_colrv1_closure_context_t* c) const { (this+src).dispatch (c); }
{
(this+src).dispatch (c); HB_INTERNAL void PaintScaleUniform::closurev1 (hb_colrv1_closure_context_t* c) const
} { (this+src).dispatch (c); }
HB_INTERNAL void PaintScaleUniformAroundCenter::closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+src).dispatch (c); }
HB_INTERNAL void PaintRotate::closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+src).dispatch (c); }
HB_INTERNAL void PaintRotateAroundCenter::closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+src).dispatch (c); }
HB_INTERNAL void PaintSkew::closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+src).dispatch (c); }
HB_INTERNAL void PaintSkewAroundCenter::closurev1 (hb_colrv1_closure_context_t* c) const
{ (this+src).dispatch (c); }
HB_INTERNAL void PaintComposite::closurev1 (hb_colrv1_closure_context_t* c) const HB_INTERNAL void PaintComposite::closurev1 (hb_colrv1_closure_context_t* c) const
{ {