This commit is contained in:
Wouter van Oortmerssen 2016-05-23 10:59:47 -07:00
commit c41a0453c1
3 changed files with 41 additions and 7 deletions

View File

@ -136,6 +136,9 @@ endif()
if(FLATBUFFERS_BUILD_FLATC) if(FLATBUFFERS_BUILD_FLATC)
add_executable(flatc ${FlatBuffers_Compiler_SRCS}) add_executable(flatc ${FlatBuffers_Compiler_SRCS})
if(NOT FLATBUFFERS_FLATC_EXECUTABLE)
set(FLATBUFFERS_FLATC_EXECUTABLE $<TARGET_FILE:flatc>)
endif()
endif() endif()
if(FLATBUFFERS_BUILD_FLATHASH) if(FLATBUFFERS_BUILD_FLATHASH)

View File

@ -69,13 +69,16 @@ inline CheckedError NoError() { return CheckedError(false); }
// Ensure that integer values we parse fit inside the declared integer type. // Ensure that integer values we parse fit inside the declared integer type.
CheckedError Parser::CheckBitsFit(int64_t val, size_t bits) { CheckedError Parser::CheckBitsFit(int64_t val, size_t bits) {
// Left-shifting a 64-bit value by 64 bits or more is undefined
// behavior (C99 6.5.7), so check *before* we shift.
if (bits < 64) {
// Bits we allow to be used. // Bits we allow to be used.
auto mask = static_cast<int64_t>((1ull << bits) - 1); auto mask = static_cast<int64_t>((1ull << bits) - 1);
if (bits < 64 && if ((val & ~mask) != 0 && // Positive or unsigned.
(val & ~mask) != 0 && // Positive or unsigned.
(val | mask) != -1) // Negative. (val | mask) != -1) // Negative.
return Error("constant does not fit in a " + NumToString(bits) + return Error("constant does not fit in a " + NumToString(bits) +
"-bit field"); "-bit field");
}
return NoError(); return NoError();
} }

View File

@ -819,6 +819,33 @@ void EnumStringsTest() {
"{ F:[ \"E.C\", \"E.A E.B E.C\" ] }"), true); "{ F:[ \"E.C\", \"E.A E.B E.C\" ] }"), true);
} }
void IntegerOutOfRangeTest() {
TestError("table T { F:byte; } root_type T; { F:256 }",
"constant does not fit");
TestError("table T { F:byte; } root_type T; { F:-257 }",
"constant does not fit");
TestError("table T { F:ubyte; } root_type T; { F:256 }",
"constant does not fit");
TestError("table T { F:ubyte; } root_type T; { F:-257 }",
"constant does not fit");
TestError("table T { F:short; } root_type T; { F:65536 }",
"constant does not fit");
TestError("table T { F:short; } root_type T; { F:-65537 }",
"constant does not fit");
TestError("table T { F:ushort; } root_type T; { F:65536 }",
"constant does not fit");
TestError("table T { F:ushort; } root_type T; { F:-65537 }",
"constant does not fit");
TestError("table T { F:int; } root_type T; { F:4294967296 }",
"constant does not fit");
TestError("table T { F:int; } root_type T; { F:-4294967297 }",
"constant does not fit");
TestError("table T { F:uint; } root_type T; { F:4294967296 }",
"constant does not fit");
TestError("table T { F:uint; } root_type T; { F:-4294967297 }",
"constant does not fit");
}
void UnicodeTest() { void UnicodeTest() {
flatbuffers::Parser parser; flatbuffers::Parser parser;
TEST_EQ(parser.Parse("table T { F:string; }" TEST_EQ(parser.Parse("table T { F:string; }"
@ -878,6 +905,7 @@ int main(int /*argc*/, const char * /*argv*/[]) {
ErrorTest(); ErrorTest();
ScientificTest(); ScientificTest();
EnumStringsTest(); EnumStringsTest();
IntegerOutOfRangeTest();
UnicodeTest(); UnicodeTest();
UnknownFieldsTest(); UnknownFieldsTest();