Allow trailing comma in arrays if dropped null placeholders are not allowed

This commit is contained in:
Jacob Bundgaard 2019-10-17 16:03:31 +02:00 committed by Christopher Dunn
parent 01db7b7430
commit 554d961625
4 changed files with 19 additions and 14 deletions

View File

@ -503,15 +503,16 @@ bool Reader::readArray(Token& token) {
Value init(arrayValue);
currentValue().swapPayload(init);
currentValue().setOffsetStart(token.start_ - begin_);
int index = 0;
for (;;) {
skipSpaces();
if (current_ != end_ && *current_ == ']') // empty array
if (current_ != end_ && *current_ == ']' && (index == 0 || (features_.allowTrailingCommas_ && !features_.allowDroppedNullPlaceholders_))) // empty array or trailing comma
{
Token endArray;
readToken(endArray);
return true;
}
int index = 0;
for (;;) {
Value& value = currentValue()[index++];
nodes_.push(&value);
bool ok = readValue();
@ -1493,15 +1494,15 @@ bool OurReader::readArray(Token& token) {
Value init(arrayValue);
currentValue().swapPayload(init);
currentValue().setOffsetStart(token.start_ - begin_);
int index = 0;
for (;;) {
skipSpaces();
if (current_ != end_ && *current_ == ']') // empty array
if (current_ != end_ && *current_ == ']' && (index == 0 || (features_.allowTrailingCommas_ && !features_.allowDroppedNullPlaceholders_))) // empty array or trailing comma
{
Token endArray;
readToken(endArray);
return true;
}
int index = 0;
for (;;) {
Value& value = currentValue()[index++];
nodes_.push(&value);
bool ok = readValue();

View File

@ -0,0 +1 @@
[1,,]

View File

@ -0,0 +1,2 @@
.=[]
.[0]=1

View File

@ -0,0 +1 @@
[1,]