[subset] update COLRv1 table struct definitions
This commit is contained in:
parent
792ca307b0
commit
d2e986fead
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue