From aded151b8f4bb8f367b9e4b4c9e92e4850728457 Mon Sep 17 00:00:00 2001 From: Pig Fang Date: Tue, 13 Oct 2020 15:44:05 +0800 Subject: [PATCH] [typescript] 4.1 mapped type 'as' clause (#1151) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: 강동윤 --- ecmascript/Cargo.toml | 2 +- ecmascript/ast/src/typescript.rs | 2 + ecmascript/parser/Cargo.toml | 2 +- ecmascript/parser/src/parser/typescript.rs | 6 + .../es2019/from-entries/input.ts.json | 1 + .../tests/typescript/types/mapped/input.ts | 1 + .../typescript/types/mapped/input.ts.json | 103 +++++++++++++++++- ecmascript/visit/src/lib.rs | 1 + 8 files changed, 115 insertions(+), 3 deletions(-) diff --git a/ecmascript/Cargo.toml b/ecmascript/Cargo.toml index 669717c8935..215113bc86e 100644 --- a/ecmascript/Cargo.toml +++ b/ecmascript/Cargo.toml @@ -6,7 +6,7 @@ edition = "2018" license = "Apache-2.0/MIT" name = "swc_ecmascript" repository = "https://github.com/swc-project/swc.git" -version = "0.9.3" +version = "0.9.4" [features] codegen = ["swc_ecma_codegen"] diff --git a/ecmascript/ast/src/typescript.rs b/ecmascript/ast/src/typescript.rs index 88041c41bb1..a94be43c316 100644 --- a/ecmascript/ast/src/typescript.rs +++ b/ecmascript/ast/src/typescript.rs @@ -660,6 +660,8 @@ pub struct TsMappedType { #[serde(default)] pub readonly: Option, pub type_param: TsTypeParam, + #[serde(default, rename = "nameType")] + pub name_type: Option>, #[serde(default)] pub optional: Option, #[serde(default, rename = "typeAnnotation")] diff --git a/ecmascript/parser/Cargo.toml b/ecmascript/parser/Cargo.toml index 2359d01466c..7096cae3e08 100644 --- a/ecmascript/parser/Cargo.toml +++ b/ecmascript/parser/Cargo.toml @@ -7,7 +7,7 @@ include = ["Cargo.toml", "src/**/*.rs", "examples/**/*.rs"] license = "Apache-2.0/MIT" name = "swc_ecma_parser" repository = "https://github.com/swc-project/swc.git" -version = "0.38.0" +version = "0.38.1" [features] default = [] diff --git a/ecmascript/parser/src/parser/typescript.rs b/ecmascript/parser/src/parser/typescript.rs index 0373c0df927..2c8e14ae111 100644 --- a/ecmascript/parser/src/parser/typescript.rs +++ b/ecmascript/parser/src/parser/typescript.rs @@ -1405,6 +1405,11 @@ impl Parser { expect!('['); let type_param = self.parse_ts_mapped_type_param()?; + let name_type = if eat!("as") { + Some(self.parse_ts_type()?) + } else { + None + }; expect!(']'); let mut optional = None; @@ -1429,6 +1434,7 @@ impl Parser { readonly, optional, type_param, + name_type, type_ann, }) } diff --git a/ecmascript/parser/tests/typescript/es2019/from-entries/input.ts.json b/ecmascript/parser/tests/typescript/es2019/from-entries/input.ts.json index 69ac26ac02c..99548b53e0d 100644 --- a/ecmascript/parser/tests/typescript/es2019/from-entries/input.ts.json +++ b/ecmascript/parser/tests/typescript/es2019/from-entries/input.ts.json @@ -237,6 +237,7 @@ }, "default": null }, + "nameType": null, "optional": null, "typeAnnotation": { "type": "TsTypeReference", diff --git a/ecmascript/parser/tests/typescript/types/mapped/input.ts b/ecmascript/parser/tests/typescript/types/mapped/input.ts index d07cdba17f9..e5cbf5e4a3c 100644 --- a/ecmascript/parser/tests/typescript/types/mapped/input.ts +++ b/ecmascript/parser/tests/typescript/types/mapped/input.ts @@ -2,3 +2,4 @@ let map: { [P in string]: number; }; let map: { readonly [P in string]?: number; }; let map: { +readonly [P in string]+?: number; }; let map: { -readonly [P in string]-?: number }; +let map: { [P in string as string]: number }; diff --git a/ecmascript/parser/tests/typescript/types/mapped/input.ts.json b/ecmascript/parser/tests/typescript/types/mapped/input.ts.json index d74ea8815a3..21a586be4a1 100644 --- a/ecmascript/parser/tests/typescript/types/mapped/input.ts.json +++ b/ecmascript/parser/tests/typescript/types/mapped/input.ts.json @@ -2,7 +2,7 @@ "type": "Module", "span": { "start": 0, - "end": 180, + "end": 226, "ctxt": 0 }, "body": [ @@ -75,6 +75,7 @@ }, "default": null }, + "nameType": null, "optional": null, "typeAnnotation": { "type": "TsKeywordType", @@ -163,6 +164,7 @@ }, "default": null }, + "nameType": null, "optional": true, "typeAnnotation": { "type": "TsKeywordType", @@ -251,6 +253,7 @@ }, "default": null }, + "nameType": null, "optional": "+", "typeAnnotation": { "type": "TsKeywordType", @@ -339,6 +342,7 @@ }, "default": null }, + "nameType": null, "optional": "-", "typeAnnotation": { "type": "TsKeywordType", @@ -357,6 +361,103 @@ "definite": false } ] + }, + { + "type": "VariableDeclaration", + "span": { + "start": 181, + "end": 226, + "ctxt": 0 + }, + "kind": "let", + "declare": false, + "declarations": [ + { + "type": "VariableDeclarator", + "span": { + "start": 185, + "end": 225, + "ctxt": 0 + }, + "id": { + "type": "Identifier", + "span": { + "start": 185, + "end": 188, + "ctxt": 0 + }, + "value": "map", + "typeAnnotation": { + "type": "TsTypeAnnotation", + "span": { + "start": 188, + "end": 225, + "ctxt": 0 + }, + "typeAnnotation": { + "type": "TsMappedType", + "span": { + "start": 190, + "end": 225, + "ctxt": 0 + }, + "readonly": null, + "typeParam": { + "type": "TsTypeParameter", + "span": { + "start": 193, + "end": 204, + "ctxt": 0 + }, + "name": { + "type": "Identifier", + "span": { + "start": 193, + "end": 194, + "ctxt": 0 + }, + "value": "P", + "typeAnnotation": null, + "optional": false + }, + "constraint": { + "type": "TsKeywordType", + "span": { + "start": 198, + "end": 204, + "ctxt": 0 + }, + "kind": "string" + }, + "default": null + }, + "nameType": { + "type": "TsKeywordType", + "span": { + "start": 208, + "end": 214, + "ctxt": 0 + }, + "kind": "string" + }, + "optional": null, + "typeAnnotation": { + "type": "TsKeywordType", + "span": { + "start": 217, + "end": 223, + "ctxt": 0 + }, + "kind": "number" + } + } + }, + "optional": false + }, + "init": null, + "definite": false + } + ] } ], "interpreter": null diff --git a/ecmascript/visit/src/lib.rs b/ecmascript/visit/src/lib.rs index e23ef4dc30e..865924af1c8 100644 --- a/ecmascript/visit/src/lib.rs +++ b/ecmascript/visit/src/lib.rs @@ -1525,6 +1525,7 @@ define!({ pub span: Span, pub readonly: Option, pub type_param: TsTypeParam, + pub name_type: Option>, pub optional: Option, pub type_ann: Option>, }