Added missing type checks

This commit is contained in:
Martin Tůma 2025-01-06 19:48:54 +01:00
parent c12c2b4497
commit 0a4543ddcf

View File

@ -3,6 +3,11 @@
#define TYPE(tag) (tag & 0x07) #define TYPE(tag) (tag & 0x07)
#define FIELD(tag) (tag >> 3) #define FIELD(tag) (tag >> 3)
#define VARINT 0
#define I64 1
#define LEN 2
#define I32 5
struct CTX struct CTX
{ {
CTX(const QByteArray &ba) CTX(const QByteArray &ba)
@ -40,6 +45,8 @@ static bool str(CTX &ctx, QByteArray &val)
{ {
quint64 len; quint64 len;
if (TYPE(ctx.tag) != LEN)
return false;
if (!varint(ctx, len)) if (!varint(ctx, len))
return false; return false;
if (ctx.bp + len > ctx.be) if (ctx.bp + len > ctx.be)
@ -52,6 +59,8 @@ static bool str(CTX &ctx, QByteArray &val)
static bool dbl(CTX &ctx, double &val) static bool dbl(CTX &ctx, double &val)
{ {
if (TYPE(ctx.tag) != I64)
return false;
if (ctx.bp + sizeof(val) > ctx.be) if (ctx.bp + sizeof(val) > ctx.be)
return false; return false;
@ -62,6 +71,8 @@ static bool dbl(CTX &ctx, double &val)
static bool flt(CTX &ctx, float &val) static bool flt(CTX &ctx, float &val)
{ {
if (TYPE(ctx.tag) != I32)
return false;
if (ctx.bp + sizeof(val) > ctx.be) if (ctx.bp + sizeof(val) > ctx.be)
return false; return false;
@ -74,7 +85,7 @@ static bool packed(CTX &ctx, QVector<quint32> &vals)
{ {
quint32 v; quint32 v;
if (TYPE(ctx.tag) == 2) { if (TYPE(ctx.tag) == LEN) {
quint64 len; quint64 len;
if (!varint(ctx, len)) if (!varint(ctx, len))
return false; return false;
@ -87,7 +98,7 @@ static bool packed(CTX &ctx, QVector<quint32> &vals)
vals.append(v); vals.append(v);
} }
return (ctx.bp == ee); return (ctx.bp == ee);
} else if (TYPE(ctx.tag) == 0) { } else if (TYPE(ctx.tag) == VARINT) {
if (!varint(ctx, v)) if (!varint(ctx, v))
return false; return false;
vals.append(v); vals.append(v);
@ -101,16 +112,16 @@ static bool skip(CTX &ctx)
quint64 len = 0; quint64 len = 0;
switch (TYPE(ctx.tag)) { switch (TYPE(ctx.tag)) {
case 0: case VARINT:
return varint(ctx, len); return varint(ctx, len);
case 1: case I64:
len = 8; len = 8;
break; break;
case 2: case LEN:
if (!varint(ctx, len)) if (!varint(ctx, len))
return false; return false;
break; break;
case 5: case I32:
len = 4; len = 4;
break; break;
default: default:
@ -126,6 +137,9 @@ static bool skip(CTX &ctx)
static bool value(CTX &ctx, QVariant &val) static bool value(CTX &ctx, QVariant &val)
{ {
if (TYPE(ctx.tag) != LEN)
return false;
QByteArray ba; QByteArray ba;
quint64 len, num; quint64 len, num;
double dnum; double dnum;
@ -159,21 +173,29 @@ static bool value(CTX &ctx, QVariant &val)
val = QVariant(dnum); val = QVariant(dnum);
break; break;
case 4: case 4:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, num)) if (!varint(ctx, num))
return false; return false;
val = QVariant(static_cast<qint64>(num)); val = QVariant(static_cast<qint64>(num));
break; break;
case 5: case 5:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, num)) if (!varint(ctx, num))
return false; return false;
val = QVariant(num); val = QVariant(num);
break; break;
case 6: case 6:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, num)) if (!varint(ctx, num))
return false; return false;
val = QVariant(zigzag64decode(num)); val = QVariant(zigzag64decode(num));
break; break;
case 7: case 7:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, num)) if (!varint(ctx, num))
return false; return false;
val = QVariant(num ? true : false); val = QVariant(num ? true : false);
@ -189,6 +211,9 @@ static bool value(CTX &ctx, QVariant &val)
static bool feature(CTX &ctx, Data::Feature &f) static bool feature(CTX &ctx, Data::Feature &f)
{ {
if (TYPE(ctx.tag) != LEN)
return false;
quint64 len; quint64 len;
quint8 e; quint8 e;
if (!varint(ctx, len)) if (!varint(ctx, len))
@ -204,6 +229,8 @@ static bool feature(CTX &ctx, Data::Feature &f)
switch (FIELD(ctx.tag)) { switch (FIELD(ctx.tag)) {
case 1: case 1:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, f.id)) if (!varint(ctx, f.id))
return false; return false;
break; break;
@ -212,6 +239,8 @@ static bool feature(CTX &ctx, Data::Feature &f)
return false; return false;
break; break;
case 3: case 3:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, e)) if (!varint(ctx, e))
return false; return false;
if (e > Data::GeomType::POLYGON) if (e > Data::GeomType::POLYGON)
@ -233,7 +262,10 @@ static bool feature(CTX &ctx, Data::Feature &f)
static bool layer(CTX &ctx, Data::Layer &l) static bool layer(CTX &ctx, Data::Layer &l)
{ {
if (ctx.tag == 0x1a) { if (FIELD(ctx.tag) == 3) {
if (TYPE(ctx.tag) != LEN)
return false;
quint64 len; quint64 len;
if (!varint(ctx, len)) if (!varint(ctx, len))
return false; return false;
@ -267,10 +299,14 @@ static bool layer(CTX &ctx, Data::Layer &l)
return false; return false;
break; break;
case 5: case 5:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, l.extent)) if (!varint(ctx, l.extent))
return false; return false;
break; break;
case 15: case 15:
if (TYPE(ctx.tag) != VARINT)
return false;
if (!varint(ctx, l.version)) if (!varint(ctx, l.version))
return false; return false;
break; break;