mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2025-01-13 19:31:28 +01:00
got updates for nanosvg from original project
Signed-off-by: SergeySlice <sergey.slice@gmail.com>
This commit is contained in:
parent
dc17de7af3
commit
0035ed3c06
@ -181,12 +181,12 @@ static int nsvg__isdigit(char c)
|
|||||||
{
|
{
|
||||||
return c >= '0' && c <= '9';
|
return c >= '0' && c <= '9';
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
static int nsvg__isnum(char c)
|
static int nsvg__isnum(char c)
|
||||||
{
|
{
|
||||||
return nsvg__strchr("0123456789+-.eE", c) != 0; //SIC!
|
return nsvg__strchr("0123456789+-.eE", c) != 0; //SIC!
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
static NSVG_INLINE float nsvg__minf(float a, float b) { return a < b ? a : b; }
|
static NSVG_INLINE float nsvg__minf(float a, float b) { return a < b ? a : b; }
|
||||||
static NSVG_INLINE float nsvg__maxf(float a, float b) { return a > b ? a : b; }
|
static NSVG_INLINE float nsvg__maxf(float a, float b) { return a > b ? a : b; }
|
||||||
|
|
||||||
@ -704,9 +704,11 @@ static void nsvg__lineTo(NSVGparser* p, float x, float y)
|
|||||||
|
|
||||||
static void nsvg__cubicBezTo(NSVGparser* p, float cpx1, float cpy1, float cpx2, float cpy2, float x, float y)
|
static void nsvg__cubicBezTo(NSVGparser* p, float cpx1, float cpy1, float cpx2, float cpy2, float x, float y)
|
||||||
{
|
{
|
||||||
|
if (p->npts > 0) {
|
||||||
nsvg__addPoint(p, cpx1, cpy1);
|
nsvg__addPoint(p, cpx1, cpy1);
|
||||||
nsvg__addPoint(p, cpx2, cpy2);
|
nsvg__addPoint(p, cpx2, cpy2);
|
||||||
nsvg__addPoint(p, x, y);
|
nsvg__addPoint(p, x, y);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static NSVGattrib* nsvg__getAttr(NSVGparser* p)
|
static NSVGattrib* nsvg__getAttr(NSVGparser* p)
|
||||||
@ -796,6 +798,9 @@ static float nsvg__convertToPixelsForGradient(NSVGparser* p, char units, NSVGcoo
|
|||||||
static NSVGgradientData* nsvg__findGradientData(NSVGparser* p, const char* id)
|
static NSVGgradientData* nsvg__findGradientData(NSVGparser* p, const char* id)
|
||||||
{
|
{
|
||||||
NSVGgradientData* grad = p->gradients;
|
NSVGgradientData* grad = p->gradients;
|
||||||
|
if (id == NULL || *id == '\0')
|
||||||
|
return NULL;
|
||||||
|
|
||||||
while (grad) {
|
while (grad) {
|
||||||
if (strcmp(grad->id, id) == 0)
|
if (strcmp(grad->id, id) == 0)
|
||||||
return grad;
|
return grad;
|
||||||
@ -824,7 +829,7 @@ static NSVGgradient* nsvg__createGradient(NSVGparser* p, NSVGshape* shape, NSVGg
|
|||||||
NSVGgradient* grad;
|
NSVGgradient* grad;
|
||||||
float ox, oy, sw, sh, sl;
|
float ox, oy, sw, sh, sl;
|
||||||
int nstops = 0;
|
int nstops = 0;
|
||||||
|
int refIter = 0;
|
||||||
if (!link) {
|
if (!link) {
|
||||||
*paintType = NSVG_PAINT_NONE;
|
*paintType = NSVG_PAINT_NONE;
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -836,6 +841,7 @@ static NSVGgradient* nsvg__createGradient(NSVGparser* p, NSVGshape* shape, NSVGg
|
|||||||
nstops = data->nstops;
|
nstops = data->nstops;
|
||||||
ref = nsvg__findGradientData(p, data->ref);
|
ref = nsvg__findGradientData(p, data->ref);
|
||||||
while (ref != NULL) {
|
while (ref != NULL) {
|
||||||
|
NSVGgradientData* nextRef = NULL;
|
||||||
if (stops == NULL && ref->stops != NULL) { //take stops only once at first occuerence
|
if (stops == NULL && ref->stops != NULL) { //take stops only once at first occuerence
|
||||||
stops = ref->stops;
|
stops = ref->stops;
|
||||||
nstops = ref->nstops;
|
nstops = ref->nstops;
|
||||||
@ -843,7 +849,11 @@ static NSVGgradient* nsvg__createGradient(NSVGparser* p, NSVGshape* shape, NSVGg
|
|||||||
//left referenced, right is current,
|
//left referenced, right is current,
|
||||||
// matrix are reversed
|
// matrix are reversed
|
||||||
nsvg__xformPremultiply(data->xform, ref->xform);
|
nsvg__xformPremultiply(data->xform, ref->xform);
|
||||||
ref = nsvg__findGradientData(p, ref->ref); //recursive refs?
|
nextRef = nsvg__findGradientData(p, ref->ref); //recursive refs?
|
||||||
|
if (nextRef == ref) break; // prevent infinite loops on malformed data
|
||||||
|
ref = nextRef;
|
||||||
|
refIter++;
|
||||||
|
if (refIter > 32) break; // prevent infinite loops on malformed data
|
||||||
}
|
}
|
||||||
if (stops == NULL) return NULL;
|
if (stops == NULL) return NULL;
|
||||||
// DumpFloat2("gradient final xform:", data->xform, 6);
|
// DumpFloat2("gradient final xform:", data->xform, 6);
|
||||||
@ -895,8 +905,8 @@ static NSVGgradient* nsvg__createGradient(NSVGparser* p, NSVGshape* shape, NSVGg
|
|||||||
gradForm[0] = r; gradForm[1] = 0;
|
gradForm[0] = r; gradForm[1] = 0;
|
||||||
gradForm[2] = 0; gradForm[3] = r;
|
gradForm[2] = 0; gradForm[3] = r;
|
||||||
gradForm[4] = cx; gradForm[5] = cy;
|
gradForm[4] = cx; gradForm[5] = cy;
|
||||||
grad->fx = fx / r; //bad idea
|
grad->fx = (fx - cx) / r;
|
||||||
grad->fy = fy / r;
|
grad->fy = (fy - cy) / r;
|
||||||
}
|
}
|
||||||
|
|
||||||
// nsvg__xformInverse(grad->xform, gradForm);
|
// nsvg__xformInverse(grad->xform, gradForm);
|
||||||
@ -1110,6 +1120,9 @@ static void nsvg__addPath(NSVGparser* p, char closed)
|
|||||||
|
|
||||||
if (closed)
|
if (closed)
|
||||||
nsvg__lineTo(p, p->pts[0], p->pts[1]);
|
nsvg__lineTo(p, p->pts[0], p->pts[1]);
|
||||||
|
// Expect 1 + N*3 points (N = number of cubic bezier segments).
|
||||||
|
if ((p->npts % 3) != 1)
|
||||||
|
return;
|
||||||
|
|
||||||
path = (NSVGpath*)AllocateZeroPool(sizeof(NSVGpath));
|
path = (NSVGpath*)AllocateZeroPool(sizeof(NSVGpath));
|
||||||
if (path == NULL) {
|
if (path == NULL) {
|
||||||
@ -1198,7 +1211,7 @@ static double nsvg__atof(const char* s)
|
|||||||
|
|
||||||
// Parse optional exponent
|
// Parse optional exponent
|
||||||
if (*cur == 'e' || *cur == 'E') {
|
if (*cur == 'e' || *cur == 'E') {
|
||||||
int expPart = 0;
|
long expPart = 0;
|
||||||
cur++; // skip 'E'
|
cur++; // skip 'E'
|
||||||
expPart = strtol(cur, &end, 10); // Parse digit sequence with sign
|
expPart = strtol(cur, &end, 10); // Parse digit sequence with sign
|
||||||
if (cur != end) {
|
if (cur != end) {
|
||||||
@ -1242,8 +1255,8 @@ static const char* nsvg__parseNumber(const char* s, char* it, const int size)
|
|||||||
s++;
|
s++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// exponent
|
// exponent but not units ex|em
|
||||||
if (*s == 'e' || *s == 'E') {
|
if ((*s == 'e' || *s == 'E') && (s[1] != 'm' && s[1] != 'x')) {
|
||||||
if (i < last) it[i++] = *s;
|
if (i < last) it[i++] = *s;
|
||||||
s++;
|
s++;
|
||||||
if (*s == '-' || *s == '+') {
|
if (*s == '-' || *s == '+') {
|
||||||
@ -1260,6 +1273,20 @@ static const char* nsvg__parseNumber(const char* s, char* it, const int size)
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char* nsvg__getNextPathItemWhenArcFlag(const char* s, char* it)
|
||||||
|
{
|
||||||
|
it[0] = '\0';
|
||||||
|
while (*s && (nsvg__isspace(*s) || *s == ',')) s++;
|
||||||
|
if (!*s) return s;
|
||||||
|
if (*s == '0' || *s == '1') {
|
||||||
|
it[0] = *s++;
|
||||||
|
it[1] = '\0';
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static const char* nsvg__getNextPathItem(const char* s, char* it)
|
static const char* nsvg__getNextPathItem(const char* s, char* it)
|
||||||
{
|
{
|
||||||
it[0] = '\0';
|
it[0] = '\0';
|
||||||
@ -1310,8 +1337,8 @@ static unsigned int nsvg__parseColorHex(const char* str)
|
|||||||
|
|
||||||
static unsigned int nsvg__parseColorRGB(const char* str)
|
static unsigned int nsvg__parseColorRGB(const char* str)
|
||||||
{
|
{
|
||||||
int r = -1, g = -1, b = -1;
|
int r = -1, g = -1, b = -1, a = 0;
|
||||||
float fr, fg, fb;
|
float fr, fg, fb, fa;
|
||||||
char *s1 = NULL;
|
char *s1 = NULL;
|
||||||
AsciiStrToFloat(str+4, &s1, &fr);
|
AsciiStrToFloat(str+4, &s1, &fr);
|
||||||
if (*s1 == '%') {
|
if (*s1 == '%') {
|
||||||
@ -1338,10 +1365,21 @@ static unsigned int nsvg__parseColorRGB(const char* str)
|
|||||||
return NSVG_RGB(0,0,0);
|
return NSVG_RGB(0,0,0);
|
||||||
}
|
}
|
||||||
AsciiStrToFloat(str, &s1, &fb);
|
AsciiStrToFloat(str, &s1, &fb);
|
||||||
if (*s1 == '%') {
|
if (*s1++ == '%') {
|
||||||
b = (int)(fb * 2.55f);
|
b = (int)(fb * 2.55f);
|
||||||
|
str = s1 + 1;
|
||||||
} else {
|
} else {
|
||||||
b = (int)fb;
|
b = (int)fb;
|
||||||
|
str = s1;
|
||||||
|
}
|
||||||
|
if (*s1 == ',') { //there can be no spaces?!
|
||||||
|
AsciiStrToFloat(str, &s1, &fa);
|
||||||
|
if (*s1 == '%') {
|
||||||
|
a = (int)(fa * 2.55f);
|
||||||
|
} else {
|
||||||
|
a = (int)fa;
|
||||||
|
}
|
||||||
|
return NSVG_RGBA(r,g,b,a);
|
||||||
}
|
}
|
||||||
return NSVG_RGB(r,g,b);
|
return NSVG_RGB(r,g,b);
|
||||||
}
|
}
|
||||||
@ -1542,6 +1580,21 @@ static unsigned int nsvg__parseColorName(const char* str)
|
|||||||
return NSVG_RGB(128, 128, 128); //if not found then Grey50%
|
return NSVG_RGB(128, 128, 128); //if not found then Grey50%
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
static unsigned int nsvg__parseColorRGBA(const char* str)
|
||||||
|
{
|
||||||
|
int r = -1, g = -1, b = -1;
|
||||||
|
float a = -1;
|
||||||
|
char s1[32]="", s2[32]="", s3[32]="";
|
||||||
|
sscanf(str + 5, "%d%[%%, \t]%d%[%%, \t]%d%[%%, \t]%f", &r, s1, &g, s2, &b, s3, &a);
|
||||||
|
if (strchr(s1, '%')) {
|
||||||
|
return NSVG_RGBA((r*255)/100,(g*255)/100,(b*255)/100,(a*255)/100);
|
||||||
|
} else {
|
||||||
|
return NSVG_RGBA(r,g,b,(a*255));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
static unsigned int nsvg__parseColor(const char* str)
|
static unsigned int nsvg__parseColor(const char* str)
|
||||||
{
|
{
|
||||||
size_t len = 0;
|
size_t len = 0;
|
||||||
@ -1551,6 +1604,9 @@ static unsigned int nsvg__parseColor(const char* str)
|
|||||||
return nsvg__parseColorHex(str);
|
return nsvg__parseColorHex(str);
|
||||||
else if (len >= 4 && str[0] == 'r' && str[1] == 'g' && str[2] == 'b' && str[3] == '(')
|
else if (len >= 4 && str[0] == 'r' && str[1] == 'g' && str[2] == 'b' && str[3] == '(')
|
||||||
return nsvg__parseColorRGB(str);
|
return nsvg__parseColorRGB(str);
|
||||||
|
else if (len >= 5 && str[0] == 'r' && str[1] == 'g' && str[2] == 'b' && str[3] == 'a' && str[4] == '(')
|
||||||
|
return nsvg__parseColorRGB(str);
|
||||||
|
|
||||||
return nsvg__parseColorName(str);
|
return nsvg__parseColorName(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1599,6 +1655,15 @@ static int nsvg__parseUnits(const char* units)
|
|||||||
return NSVG_UNITS_USER;
|
return NSVG_UNITS_USER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int nsvg__isCoordinate(const char* s)
|
||||||
|
{
|
||||||
|
// optional sign
|
||||||
|
if (*s == '-' || *s == '+')
|
||||||
|
s++;
|
||||||
|
// must have at least one digit, or start by a dot
|
||||||
|
return (nsvg__isdigit(*s) || *s == '.');
|
||||||
|
}
|
||||||
|
|
||||||
static NSVGcoordinate nsvg__parseCoordinateRaw(const char* str)
|
static NSVGcoordinate nsvg__parseCoordinateRaw(const char* str)
|
||||||
{
|
{
|
||||||
NSVGcoordinate coord = {0, NSVG_UNITS_USER};
|
NSVGcoordinate coord = {0, NSVG_UNITS_USER};
|
||||||
@ -1745,28 +1810,33 @@ static int nsvg__parseRotate(float* xform, const char* str)
|
|||||||
static void nsvg__parseTransform(float* xform, const char* str)
|
static void nsvg__parseTransform(float* xform, const char* str)
|
||||||
{
|
{
|
||||||
float t[6];
|
float t[6];
|
||||||
// INT64 i, j;
|
int len;
|
||||||
// float v;
|
|
||||||
nsvg__xformIdentity(xform);
|
nsvg__xformIdentity(xform);
|
||||||
|
|
||||||
while (*str)
|
while (*str)
|
||||||
{
|
{
|
||||||
if (strncmp(str, "matrix", 6) == 0)
|
if (strncmp(str, "matrix", 6) == 0)
|
||||||
str += nsvg__parseMatrix(t, str);
|
len = nsvg__parseMatrix(t, str);
|
||||||
else if (strncmp(str, "translate", 9) == 0)
|
else if (strncmp(str, "translate", 9) == 0)
|
||||||
str += nsvg__parseTranslate(t, str);
|
len = nsvg__parseTranslate(t, str);
|
||||||
else if (strncmp(str, "scale", 5) == 0)
|
else if (strncmp(str, "scale", 5) == 0)
|
||||||
str += nsvg__parseScale(t, str);
|
len =nsvg__parseScale(t, str);
|
||||||
else if (strncmp(str, "rotate", 6) == 0)
|
else if (strncmp(str, "rotate", 6) == 0)
|
||||||
str += nsvg__parseRotate(t, str);
|
len = nsvg__parseRotate(t, str);
|
||||||
else if (strncmp(str, "skewX", 5) == 0)
|
else if (strncmp(str, "skewX", 5) == 0)
|
||||||
str += nsvg__parseSkewX(t, str);
|
len = nsvg__parseSkewX(t, str);
|
||||||
else if (strncmp(str, "skewY", 5) == 0)
|
else if (strncmp(str, "skewY", 5) == 0)
|
||||||
str += nsvg__parseSkewY(t, str);
|
len = nsvg__parseSkewY(t, str);
|
||||||
else{
|
else{
|
||||||
++str;
|
++str;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (len != 0) {
|
||||||
|
str += len;
|
||||||
|
} else {
|
||||||
|
++str;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
nsvg__xformPremultiply(xform, t);
|
nsvg__xformPremultiply(xform, t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1805,7 +1875,7 @@ static char nsvg__parseLineJoin(const char* str)
|
|||||||
else if (strcmp(str, "bevel") == 0)
|
else if (strcmp(str, "bevel") == 0)
|
||||||
return NSVG_JOIN_BEVEL;
|
return NSVG_JOIN_BEVEL;
|
||||||
// TODO: handle inherit.
|
// TODO: handle inherit.
|
||||||
return NSVG_CAP_BUTT;
|
return NSVG_JOIN_MITER;
|
||||||
}
|
}
|
||||||
|
|
||||||
static char nsvg__parseFillRule(const char* str)
|
static char nsvg__parseFillRule(const char* str)
|
||||||
@ -1945,6 +2015,13 @@ static int nsvg__parseAttr(NSVGparser* p, const char* name, char* value)
|
|||||||
} else {
|
} else {
|
||||||
attr->hasFill = 1;
|
attr->hasFill = 1;
|
||||||
attr->fillColor = nsvg__parseColor(value);
|
attr->fillColor = nsvg__parseColor(value);
|
||||||
|
// if the fillColor has an alpha value then use it to
|
||||||
|
// set the fillOpacity
|
||||||
|
if (attr->fillColor & 0xFF000000) {
|
||||||
|
attr->fillOpacity = ((attr->fillColor >> 24) & 0xFF) / 255.0;
|
||||||
|
// remove the alpha value from the color
|
||||||
|
attr->fillColor &= 0x00FFFFFF;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (strcmp(name, "opacity") == 0) {
|
} else if (strcmp(name, "opacity") == 0) {
|
||||||
float opacity = nsvg__parseOpacity(value);
|
float opacity = nsvg__parseOpacity(value);
|
||||||
@ -1967,6 +2044,13 @@ static int nsvg__parseAttr(NSVGparser* p, const char* name, char* value)
|
|||||||
} else {
|
} else {
|
||||||
attr->hasStroke = 1;
|
attr->hasStroke = 1;
|
||||||
attr->strokeColor = nsvg__parseColor(value);
|
attr->strokeColor = nsvg__parseColor(value);
|
||||||
|
// if the strokeColor has an alpha value then use it to
|
||||||
|
// set the strokeOpacity
|
||||||
|
if (attr->strokeColor & 0xFF000000) {
|
||||||
|
attr->strokeOpacity = ((attr->strokeColor >> 24) & 0xFF) / 255.0;
|
||||||
|
// remove the alpha value from the color
|
||||||
|
attr->strokeColor &= 0x00FFFFFF;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (strcmp(name, "stroke-width") == 0) {
|
} else if (strcmp(name, "stroke-width") == 0) {
|
||||||
attr->strokeWidth = nsvg__parseCoordinate(p, value, 0.0f, nsvg__actualLength(p));
|
attr->strokeWidth = nsvg__parseCoordinate(p, value, 0.0f, nsvg__actualLength(p));
|
||||||
@ -2167,8 +2251,11 @@ static int nsvg__getArgsPerElement(char cmd)
|
|||||||
case 'a':
|
case 'a':
|
||||||
case 'A':
|
case 'A':
|
||||||
return 7;
|
return 7;
|
||||||
}
|
case 'z':
|
||||||
|
case 'Z':
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void nsvg__pathMoveTo(NSVGparser* p, float* cpx, float* cpy, float* args, int rel)
|
static void nsvg__pathMoveTo(NSVGparser* p, float* cpx, float* cpy, float* args, int rel)
|
||||||
@ -2465,6 +2552,7 @@ static void nsvg__parsePath(NSVGparser* p, char** attr)
|
|||||||
float args[30];
|
float args[30];
|
||||||
int nargs;
|
int nargs;
|
||||||
int rargs = 0;
|
int rargs = 0;
|
||||||
|
char initPoint;
|
||||||
float cpx, cpy, cpx2, cpy2;
|
float cpx, cpy, cpx2, cpy2;
|
||||||
// const char* tmp[4];
|
// const char* tmp[4];
|
||||||
char closedFlag;
|
char closedFlag;
|
||||||
@ -2483,12 +2571,18 @@ static void nsvg__parsePath(NSVGparser* p, char** attr)
|
|||||||
nsvg__resetPath(p);
|
nsvg__resetPath(p);
|
||||||
cpx = 0; cpy = 0;
|
cpx = 0; cpy = 0;
|
||||||
cpx2 = 0; cpy2 = 0;
|
cpx2 = 0; cpy2 = 0;
|
||||||
|
initPoint = 0;
|
||||||
closedFlag = 0;
|
closedFlag = 0;
|
||||||
nargs = 0;
|
nargs = 0;
|
||||||
while (*s) {
|
while (*s) {
|
||||||
|
item[0] = '\0';
|
||||||
|
if ((cmd == 'A' || cmd == 'a') && (nargs == 3 || nargs == 4))
|
||||||
|
s = nsvg__getNextPathItemWhenArcFlag(s, item);
|
||||||
|
if (!*item)
|
||||||
s = nsvg__getNextPathItem(s, item);
|
s = nsvg__getNextPathItem(s, item);
|
||||||
|
|
||||||
if (!*item) break;
|
if (!*item) break;
|
||||||
if (nsvg__isnum(item[0])) {
|
if (cmd != '\0' && nsvg__isCoordinate(item)) {
|
||||||
if (nargs < 30) {
|
if (nargs < 30) {
|
||||||
float x = (float)nsvg__atof(item);
|
float x = (float)nsvg__atof(item);
|
||||||
args[nargs++] = x;
|
args[nargs++] = x;
|
||||||
@ -2503,6 +2597,7 @@ static void nsvg__parsePath(NSVGparser* p, char** attr)
|
|||||||
cmd = (cmd == 'm') ? 'l' : 'L';
|
cmd = (cmd == 'm') ? 'l' : 'L';
|
||||||
rargs = nsvg__getArgsPerElement(cmd);
|
rargs = nsvg__getArgsPerElement(cmd);
|
||||||
cpx2 = cpx; cpy2 = cpy;
|
cpx2 = cpx; cpy2 = cpy;
|
||||||
|
initPoint = 1;
|
||||||
break;
|
break;
|
||||||
case 'l':
|
case 'l':
|
||||||
case 'L':
|
case 'L':
|
||||||
@ -2553,7 +2648,7 @@ static void nsvg__parsePath(NSVGparser* p, char** attr)
|
|||||||
} else {
|
} else {
|
||||||
|
|
||||||
cmd = item[0];
|
cmd = item[0];
|
||||||
rargs = nsvg__getArgsPerElement(cmd);
|
// rargs = nsvg__getArgsPerElement(cmd);
|
||||||
if (cmd == 'M' || cmd == 'm') {
|
if (cmd == 'M' || cmd == 'm') {
|
||||||
if (p->npts > 0)
|
if (p->npts > 0)
|
||||||
nsvg__addPath(p, closedFlag);
|
nsvg__addPath(p, closedFlag);
|
||||||
@ -2561,7 +2656,11 @@ static void nsvg__parsePath(NSVGparser* p, char** attr)
|
|||||||
nsvg__resetPath(p);
|
nsvg__resetPath(p);
|
||||||
closedFlag = 0;
|
closedFlag = 0;
|
||||||
nargs = 0;
|
nargs = 0;
|
||||||
} else if (cmd == 'Z' || cmd == 'z') {
|
} else if (initPoint == 0) {
|
||||||
|
// Do not allow other commands until initial point has been set (moveTo called once).
|
||||||
|
cmd = '\0';
|
||||||
|
}
|
||||||
|
if (cmd == 'Z' || cmd == 'z') {
|
||||||
closedFlag = 1;
|
closedFlag = 1;
|
||||||
// Commit path.
|
// Commit path.
|
||||||
// DBG("commit path, npts=%d\n", p->npts);
|
// DBG("commit path, npts=%d\n", p->npts);
|
||||||
@ -2578,6 +2677,12 @@ static void nsvg__parsePath(NSVGparser* p, char** attr)
|
|||||||
closedFlag = 0;
|
closedFlag = 0;
|
||||||
nargs = 0;
|
nargs = 0;
|
||||||
}
|
}
|
||||||
|
rargs = nsvg__getArgsPerElement(cmd);
|
||||||
|
if (rargs == -1) {
|
||||||
|
// Command not recognized
|
||||||
|
cmd = '\0';
|
||||||
|
rargs = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Commit path.
|
// Commit path.
|
||||||
|
Loading…
Reference in New Issue
Block a user