Commit a6c06002 authored by Kent Hansen's avatar Kent Hansen Committed by Qt by Nokia
Browse files

lupdate: Allow trailing commas in QtScript/JS object literals


As per ECMA-262 5th edition, section 11.1.5, trailing commas should
be allowed in object literals. E.g.

{ foo: 10, }

shouldn't cause a syntax error; the comma should simply be ignored.

Task-number: QTBUG-22970
Change-Id: I3e730ad3001760475e5e40bb4a28a05b0baf5c7e
Sanity-Review: Qt Sanity Bot <qt_sanity_bot@ovi.com>
Reviewed-by: default avatarRoberto Raggi <roberto.raggi@nokia.com>
Reviewed-by: default avatarOswald Buddenhagen <oswald.buddenhagen@nokia.com>
parent 9f751bfc
dev 5.10 5.11 5.12 5.12.1 5.12.10 5.12.11 5.12.12 5.12.2 5.12.3 5.12.4 5.12.5 5.12.6 5.12.7 5.12.8 5.12.9 5.13 5.13.0 5.13.1 5.13.2 5.14 5.14.0 5.14.1 5.14.2 5.15 5.15.0 5.15.1 5.15.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 5.9.8 6.0 6.0.0 6.1 6.1.0 6.1.1 6.1.2 6.1.3 6.2 6.2.0 6.2.1 6.2.2 old/5.0 old/5.1 old/5.2 wip/cmake wip/winrt v5.15.0-alpha1 v5.14.1 v5.14.0 v5.14.0-rc2 v5.14.0-rc1 v5.14.0-beta3 v5.14.0-beta2 v5.14.0-beta1 v5.14.0-alpha1 v5.13.2 v5.13.1 v5.13.0 v5.13.0-rc3 v5.13.0-rc2 v5.13.0-rc1 v5.13.0-beta4 v5.13.0-beta3 v5.13.0-beta2 v5.13.0-beta1 v5.13.0-alpha1 v5.12.7 v5.12.6 v5.12.5 v5.12.4 v5.12.3 v5.12.2 v5.12.1 v5.12.0 v5.12.0-rc2 v5.12.0-rc1 v5.12.0-beta4 v5.12.0-beta3 v5.12.0-beta2 v5.12.0-beta1 v5.12.0-alpha1 v5.11.3 v5.11.2 v5.11.1 v5.11.0 v5.11.0-rc2 v5.11.0-rc1 v5.11.0-beta4 v5.11.0-beta3 v5.11.0-beta2 v5.11.0-beta1 v5.11.0-alpha1 v5.10.1 v5.10.0 v5.10.0-rc3 v5.10.0-rc2 v5.10.0-rc1 v5.10.0-beta4 v5.10.0-beta3 v5.10.0-beta2 v5.10.0-beta1 v5.10.0-alpha1 v5.9.9 v5.9.8 v5.9.7 v5.9.6 v5.9.5 v5.9.4 v5.9.3 v5.9.2 v5.9.1 v5.9.0 v5.9.0-rc2 v5.9.0-rc1 v5.9.0-beta4 v5.9.0-beta3 v5.9.0-beta2 v5.9.0-beta1 v5.9.0-alpha1 v5.8.0 v5.8.0-rc1 v5.8.0-beta1 v5.8.0-alpha1 v5.7.1 v5.7.0 v5.7.0-rc1 v5.7.0-beta1 v5.7.0-alpha1 v5.6.3 v5.6.2 v5.6.1 v5.6.1-1 v5.6.0 v5.6.0-rc1 v5.6.0-beta1 v5.6.0-alpha1 v5.5.1 v5.5.0 v5.5.0-rc1 v5.5.0-beta1 v5.5.0-alpha1 v5.4.2 v5.4.1 v5.4.0 v5.4.0-rc1 v5.4.0-beta1 v5.4.0-alpha1 v5.3.2 v5.3.1 v5.3.0 v5.3.0-rc1 v5.3.0-beta1 v5.3.0-alpha1 v5.2.1 v5.2.0 v5.2.0-rc1 v5.2.0-beta1 v5.2.0-alpha1 v5.1.1 v5.1.0 v5.1.0-rc2 v5.1.0-rc1 v5.1.0-beta1 v5.1.0-alpha1 v5.0.2 v5.0.1 v5.0.0 v5.0.0-rc2 v5.0.0-rc1 v5.0.0-beta2 v5.0.0-beta1 qt-v5.0.0-alpha1
No related merge requests found
Showing with 672 additions and 512 deletions
This diff is collapsed.
......@@ -1641,6 +1641,7 @@ PrimaryExpression: T_LBRACKET ElisionOpt T_RBRACKET ;
PrimaryExpression: T_LBRACKET ElementList T_RBRACKET ;
PrimaryExpression: T_LBRACKET ElementList T_COMMA ElisionOpt T_RBRACKET ;
PrimaryExpression: T_LBRACE PropertyNameAndValueListOpt T_RBRACE ;
PrimaryExpression: T_LBRACE PropertyNameAndValueList T_COMMA T_RBRACE ;
PrimaryExpression: T_LPAREN Expression T_RPAREN ;
ElementList: ElisionOpt AssignmentExpression ;
ElementList: ElementList T_COMMA ElisionOpt AssignmentExpression ;
......
({ foo: 123, }) // Trailing comma shouldn't cause syntax error and bailout
({ foo: qsTr("one") })
({ foo: qsTr("two"), })
({ foo: qsTranslate("FooContext", "one") })
({ foo: qsTranslate("FooContext", "two"), })
({ foo: qsTrId("qtn_foo_bar") })
({ foo: qsTrId("qtn_bar_baz"), })
({ foo: { bar: 123, }, baz: qsTr("three"), })
({ foo: { bar: 123, }, baz: qsTranslate("FooContext", "three"), })
({
firstGuy: {
age: 50,
//: First guy first name
firstName: qsTr("Frits"),
//: First guy middle name
middleName: qsTranslate("BarContext", "Joe"),
//% "First guy last name"
lastName: qsTrId("qtn_first_guy_last_name"),
weight: 100, // Uh-oh, trailing comma!
},
secondGuy: {
age: 70,
//: Second guy first name
firstName: qsTr("Bob"),
//: Second guy middle name
middleName: qsTranslate("BarContext", "Steve"),
//% "Second guy last name"
lastName: qsTrId("qtn_second_guy_last_name"),
weight: 120, // Uh-oh, trailing comma!
},
})
SOURCES += main.js
TRANSLATIONS = project.ts
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE TS>
<TS version="2.0">
<context>
<name></name>
<message id="qtn_foo_bar">
<location filename="main.js" line="11"/>
<source></source>
<translation type="unfinished"></translation>
</message>
<message id="qtn_bar_baz">
<location filename="main.js" line="13"/>
<source></source>
<translation type="unfinished"></translation>
</message>
<message id="qtn_first_guy_last_name">
<location filename="main.js" line="27"/>
<source>First guy last name</source>
<translation type="unfinished"></translation>
</message>
<message id="qtn_second_guy_last_name">
<location filename="main.js" line="37"/>
<source>Second guy last name</source>
<translation type="unfinished"></translation>
</message>
</context>
<context>
<name>BarContext</name>
<message>
<location filename="main.js" line="25"/>
<source>Joe</source>
<extracomment>First guy middle name</extracomment>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="35"/>
<source>Steve</source>
<extracomment>Second guy middle name</extracomment>
<translation type="unfinished"></translation>
</message>
</context>
<context>
<name>FooContext</name>
<message>
<location filename="main.js" line="7"/>
<source>one</source>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="9"/>
<source>two</source>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="17"/>
<source>three</source>
<translation type="unfinished"></translation>
</message>
</context>
<context>
<name>main</name>
<message>
<location filename="main.js" line="3"/>
<source>one</source>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="5"/>
<source>two</source>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="15"/>
<source>three</source>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="23"/>
<source>Frits</source>
<extracomment>First guy first name</extracomment>
<translation type="unfinished"></translation>
</message>
<message>
<location filename="main.js" line="33"/>
<source>Bob</source>
<extracomment>Second guy first name</extracomment>
<translation type="unfinished"></translation>
</message>
</context>
</TS>
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment