diff --git a/lib/webidl2.js b/lib/webidl2.js index 93edfe3b..1474a532 100644 --- a/lib/webidl2.js +++ b/lib/webidl2.js @@ -262,13 +262,13 @@ function union_type(typeName) { all_ws(); if (!consume(OTHER, "(")) return; - const ret = { sequence: false, generic: null, nullable: false, union: true, idlType: [] }; - const fst = type_with_extended_attributes(typeName) || error("Union type with no content"); + const ret = { type: typeName || null, sequence: false, generic: null, nullable: false, union: true, idlType: [] }; + const fst = type_with_extended_attributes() || error("Union type with no content"); ret.idlType.push(fst); while (true) { all_ws(); if (!consume(ID, "or")) break; - const typ = type_with_extended_attributes(typeName) || error("No type after 'or' in union type"); + const typ = type_with_extended_attributes() || error("No type after 'or' in union type"); ret.idlType.push(typ); } if (!consume(OTHER, ")")) error("Unterminated union type"); diff --git a/test/syntax/json/extended-attributes.json b/test/syntax/json/extended-attributes.json index 15b9d9a3..b64e9613 100644 --- a/test/syntax/json/extended-attributes.json +++ b/test/syntax/json/extended-attributes.json @@ -182,13 +182,14 @@ "inherit": false, "readonly": false, "idlType": { + "type": "attribute-type", "sequence": false, "generic": null, "nullable": false, "union": true, "idlType": [ { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -196,7 +197,7 @@ "idlType": "long" }, { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, diff --git a/test/syntax/json/record.json b/test/syntax/json/record.json index 73dab8b9..e0433743 100644 --- a/test/syntax/json/record.json +++ b/test/syntax/json/record.json @@ -85,6 +85,7 @@ "idlType": "DOMString" }, { + "type": null, "sequence": false, "generic": null, "nullable": true, diff --git a/test/syntax/json/typedef-union.json b/test/syntax/json/typedef-union.json index f4c86922..e9c6f67d 100644 --- a/test/syntax/json/typedef-union.json +++ b/test/syntax/json/typedef-union.json @@ -2,6 +2,7 @@ { "type": "typedef", "idlType": { + "type": null, "sequence": false, "generic": null, "nullable": false, diff --git a/test/syntax/json/uniontype.json b/test/syntax/json/uniontype.json index bb173f2c..87735c7f 100644 --- a/test/syntax/json/uniontype.json +++ b/test/syntax/json/uniontype.json @@ -11,13 +11,14 @@ "inherit": false, "readonly": false, "idlType": { + "type": "attribute-type", "sequence": false, "generic": null, "nullable": false, "union": true, "idlType": [ { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -25,13 +26,14 @@ "idlType": "float" }, { + "type": null, "sequence": false, "generic": null, "nullable": false, "union": true, "idlType": [ { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -39,7 +41,7 @@ "idlType": "Date" }, { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -49,13 +51,14 @@ ] }, { + "type": null, "sequence": false, "generic": null, "nullable": true, "union": true, "idlType": [ { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -63,7 +66,7 @@ "idlType": "Node" }, { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -84,13 +87,14 @@ "inherit": false, "readonly": false, "idlType": { + "type": "attribute-type", "sequence": false, "generic": null, "nullable": false, "union": true, "idlType": [ { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false, @@ -106,7 +110,7 @@ ] }, { - "type": "attribute-type", + "type": null, "sequence": false, "generic": null, "nullable": false,