mirror of
https://github.com/swc-project/swc.git
synced 2024-11-30 07:03:50 +03:00
Import assertion / json modules (#1100)
swc_atoms: - Add "assert". swc_ecma_ast - Add a field to an import declaration. swc_ecma_parser: - Parse assertions in import statements. - Parse assertions in top-level dynamic imports. - Parse assertions in non-top-level dynamic imports. swc_ecma_transforms: - Fix compilation.
This commit is contained in:
parent
7e8ff1d342
commit
688d16f228
@ -7,7 +7,7 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_atoms"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.2.2"
|
||||
version = "0.2.3"
|
||||
|
||||
[dependencies]
|
||||
string_cache = "0.8"
|
||||
|
@ -577,6 +577,7 @@ any
|
||||
apply
|
||||
arguments
|
||||
as
|
||||
assert
|
||||
asserts
|
||||
async
|
||||
await
|
||||
|
@ -6,7 +6,7 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_bundler"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.7.4"
|
||||
version = "0.8.0"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
[features]
|
||||
@ -27,12 +27,12 @@ relative-path = "1.2"
|
||||
retain_mut = "=0.1.1"
|
||||
swc_atoms = {version = "0.2", path = "../atoms"}
|
||||
swc_common = {version = "0.10.0", path = "../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ecmascript/ast"}
|
||||
swc_ecma_codegen = {version = "0.35.0", path = "../ecmascript/codegen"}
|
||||
swc_ecma_parser = {version = "0.37.0", path = "../ecmascript/parser"}
|
||||
swc_ecma_transforms = {version = "0.23.1", path = "../ecmascript/transforms"}
|
||||
swc_ecma_utils = {version = "0.21.0", path = "../ecmascript/utils"}
|
||||
swc_ecma_visit = {version = "0.17.0", path = "../ecmascript/visit"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ecmascript/ast"}
|
||||
swc_ecma_codegen = {version = "0.36.0", path = "../ecmascript/codegen"}
|
||||
swc_ecma_parser = {version = "0.38.0", path = "../ecmascript/parser"}
|
||||
swc_ecma_transforms = {version = "0.24.0", path = "../ecmascript/transforms"}
|
||||
swc_ecma_utils = {version = "0.22.0", path = "../ecmascript/utils"}
|
||||
swc_ecma_visit = {version = "0.18.0", path = "../ecmascript/visit"}
|
||||
|
||||
[dev-dependencies]
|
||||
testing = {version = "0.10.0", path = "../testing"}
|
||||
|
@ -455,6 +455,7 @@ where
|
||||
specifiers: vec![],
|
||||
src: src.clone(),
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
};
|
||||
|
||||
if self.top_level {
|
||||
@ -553,6 +554,7 @@ where
|
||||
.collect(),
|
||||
src,
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
};
|
||||
|
||||
// if self.top_level {
|
||||
|
@ -277,6 +277,7 @@ where
|
||||
specifiers: vec![],
|
||||
src,
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
},
|
||||
true,
|
||||
false,
|
||||
|
@ -6,7 +6,7 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecmascript"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.7.11"
|
||||
version = "0.8.0"
|
||||
|
||||
[features]
|
||||
codegen = ["swc_ecma_codegen"]
|
||||
@ -20,12 +20,12 @@ const-modules = ["swc_ecma_transforms", "swc_ecma_transforms/const-modules"]
|
||||
react = ["swc_ecma_transforms", "swc_ecma_transforms/react"]
|
||||
|
||||
[dependencies]
|
||||
swc_ecma_ast = {version = "0.31.0", path = "./ast"}
|
||||
swc_ecma_codegen = {version = "0.35.2", path = "./codegen", optional = true}
|
||||
swc_ecma_dep_graph = {version = "0.3.0", path = "./dep-graph", optional = true}
|
||||
swc_ecma_parser = {version = "0.37.2", path = "./parser", optional = true}
|
||||
swc_ecma_transforms = {version = "0.23.15", path = "./transforms", optional = true}
|
||||
swc_ecma_utils = {version = "0.21.0", path = "./utils", optional = true}
|
||||
swc_ecma_visit = {version = "0.17.2", path = "./visit", optional = true}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "./ast"}
|
||||
swc_ecma_codegen = {version = "0.36.0", path = "./codegen", optional = true}
|
||||
swc_ecma_dep_graph = {version = "0.4.0", path = "./dep-graph", optional = true}
|
||||
swc_ecma_parser = {version = "0.38.0", path = "./parser", optional = true}
|
||||
swc_ecma_transforms = {version = "0.24.0", path = "./transforms", optional = true}
|
||||
swc_ecma_utils = {version = "0.22.0", path = "./utils", optional = true}
|
||||
swc_ecma_visit = {version = "0.18.0", path = "./visit", optional = true}
|
||||
|
||||
[dev-dependencies]
|
||||
|
@ -6,7 +6,7 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecma_ast"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.31.0"
|
||||
version = "0.32.0"
|
||||
|
||||
[dependencies]
|
||||
enum_kind = {version = "0.2", path = "../../macros/enum_kind"}
|
||||
|
@ -4,6 +4,7 @@ use crate::{
|
||||
ident::Ident,
|
||||
lit::Str,
|
||||
typescript::{TsExportAssignment, TsImportEqualsDecl, TsInterfaceDecl, TsNamespaceExportDecl},
|
||||
ObjectLit,
|
||||
};
|
||||
use is_macro::Is;
|
||||
use swc_common::{ast_node, Span};
|
||||
@ -70,6 +71,9 @@ pub struct ImportDecl {
|
||||
|
||||
#[serde(rename = "typeOnly")]
|
||||
pub type_only: bool,
|
||||
|
||||
#[serde(default)]
|
||||
pub asserts: Option<ObjectLit>,
|
||||
}
|
||||
|
||||
/// `export * from 'mod'`
|
||||
|
@ -7,7 +7,7 @@ include = ["Cargo.toml", "src/**/*.rs"]
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecma_codegen"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.35.3"
|
||||
version = "0.36.0"
|
||||
|
||||
[dependencies]
|
||||
bitflags = "1"
|
||||
@ -15,10 +15,10 @@ num-bigint = {version = "0.2", features = ["serde"]}
|
||||
sourcemap = "6"
|
||||
swc_atoms = {version = "0.2", path = "../../atoms"}
|
||||
swc_common = {version = "0.10.0", path = "../../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_ecma_codegen_macros = {version = "0.5", path = "./macros"}
|
||||
|
||||
[dev-dependencies]
|
||||
swc_common = {version = "0.10.0", path = "../../common", features = ["sourcemap"]}
|
||||
swc_ecma_parser = {version = "0.37.0", path = "../parser"}
|
||||
swc_ecma_parser = {version = "0.38.0", path = "../parser"}
|
||||
testing = {version = "0.10.0", path = "../../testing"}
|
||||
|
@ -6,14 +6,14 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecma_dep_graph"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.3.0"
|
||||
version = "0.4.0"
|
||||
|
||||
[dependencies]
|
||||
swc_atoms = {version = "0.2", path = "../../atoms"}
|
||||
swc_common = {version = "0.10.1", path = "../../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_visit = {version = "0.17.0", path = "../visit"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_ecma_visit = {version = "0.18.0", path = "../visit"}
|
||||
|
||||
[dev-dependencies]
|
||||
swc_ecma_parser = {version = "0.37.0", path = "../parser"}
|
||||
swc_ecma_parser = {version = "0.38.0", path = "../parser"}
|
||||
testing = {version = "0.10.0", path = "../../testing"}
|
||||
|
@ -5,7 +5,7 @@ documentation = "https://swc.rs/rustdoc/jsdoc/"
|
||||
edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "jsdoc"
|
||||
version = "0.5.1"
|
||||
version = "0.6.0"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
@ -18,7 +18,7 @@ swc_common = {version = "0.10.0", path = "../../common"}
|
||||
[dev-dependencies]
|
||||
anyhow = "1"
|
||||
dashmap = "3"
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_parser = {version = "0.37.0", path = "../parser"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_ecma_parser = {version = "0.38.0", path = "../parser"}
|
||||
testing = {version = "0.10.0", path = "../../testing"}
|
||||
walkdir = "2"
|
||||
|
@ -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.37.2"
|
||||
version = "0.38.0"
|
||||
|
||||
[features]
|
||||
default = []
|
||||
@ -20,11 +20,11 @@ log = "0.4"
|
||||
num-bigint = "0.2"
|
||||
serde = {version = "1", features = ["derive"]}
|
||||
smallvec = "1"
|
||||
swc_atoms = {version = "0.2", path = "../../atoms"}
|
||||
swc_atoms = {version = "0.2.3", path = "../../atoms"}
|
||||
swc_common = {version = "0.10.0", path = "../../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_ecma_parser_macros = {version = "0.4.1", path = "./macros"}
|
||||
swc_ecma_visit = {version = "0.17.0", path = "../visit"}
|
||||
swc_ecma_visit = {version = "0.18.0", path = "../visit"}
|
||||
unicode-xid = "0.2"
|
||||
|
||||
[dev-dependencies]
|
||||
|
@ -123,6 +123,17 @@ impl Default for Syntax {
|
||||
}
|
||||
|
||||
impl Syntax {
|
||||
pub fn import_assertions(self) -> bool {
|
||||
match self {
|
||||
Syntax::Es(EsConfig {
|
||||
import_assertions, ..
|
||||
})
|
||||
| Syntax::Typescript(TsConfig {
|
||||
import_assertions, ..
|
||||
}) => import_assertions,
|
||||
}
|
||||
}
|
||||
|
||||
/// Should we parse jsx?
|
||||
pub fn jsx(self) -> bool {
|
||||
match self {
|
||||
@ -292,6 +303,10 @@ pub struct TsConfig {
|
||||
|
||||
#[serde(skip, default)]
|
||||
pub no_early_errors: bool,
|
||||
|
||||
/// Stage 3.
|
||||
#[serde(default)]
|
||||
pub import_assertions: bool,
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Copy, Serialize, Deserialize, PartialOrd, Ord, PartialEq, Eq)]
|
||||
@ -382,6 +397,10 @@ pub struct EsConfig {
|
||||
/// Stage 3.
|
||||
#[serde(default)]
|
||||
pub top_level_await: bool,
|
||||
|
||||
/// Stage 3.
|
||||
#[serde(default)]
|
||||
pub import_assertions: bool,
|
||||
}
|
||||
|
||||
/// Syntactic context.
|
||||
|
@ -356,6 +356,9 @@ macro_rules! tok {
|
||||
("type") => {
|
||||
crate::token::Token::Word(crate::token::Word::Ident(swc_atoms::js_word!("type")))
|
||||
};
|
||||
("assert") => {
|
||||
crate::token::Token::Word(crate::token::Word::Ident(swc_atoms::js_word!("assert")))
|
||||
};
|
||||
}
|
||||
|
||||
macro_rules! token_including_semi {
|
||||
|
@ -56,6 +56,7 @@ impl<'a, I: Tokens> Parser<I> {
|
||||
src,
|
||||
specifiers: vec![],
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
}))
|
||||
.map(ModuleItem::from);
|
||||
}
|
||||
@ -106,13 +107,40 @@ impl<'a, I: Tokens> Parser<I> {
|
||||
}
|
||||
}
|
||||
|
||||
let src = self.parse_from_clause_and_semi()?;
|
||||
let src = {
|
||||
expect!("from");
|
||||
let str_start = cur_pos!();
|
||||
let src = match *cur!(true)? {
|
||||
Token::Str { .. } => match bump!() {
|
||||
Token::Str { value, has_escape } => Str {
|
||||
value,
|
||||
has_escape,
|
||||
span: span!(str_start),
|
||||
},
|
||||
_ => unreachable!(),
|
||||
},
|
||||
_ => unexpected!("a string literal"),
|
||||
};
|
||||
src
|
||||
};
|
||||
|
||||
let asserts = if self.input.syntax().import_assertions() && eat!("assert") {
|
||||
match *self.parse_object::<Box<Expr>>()? {
|
||||
Expr::Object(v) => Some(v),
|
||||
_ => unreachable!(),
|
||||
}
|
||||
} else {
|
||||
None
|
||||
};
|
||||
|
||||
expect!(';');
|
||||
|
||||
Ok(ModuleDecl::Import(ImportDecl {
|
||||
span: span!(start),
|
||||
specifiers,
|
||||
src,
|
||||
type_only,
|
||||
asserts,
|
||||
}))
|
||||
.map(ModuleItem::from)
|
||||
}
|
||||
|
@ -44,7 +44,8 @@
|
||||
"value": "react",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "FunctionDeclaration",
|
||||
|
@ -44,7 +44,8 @@
|
||||
"value": "react",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "FunctionDeclaration",
|
||||
|
@ -77,9 +77,8 @@ fn load_tests(tests: &mut Vec<TestDescAndFn>) -> Result<(), io::Error> {
|
||||
Syntax::Typescript(TsConfig {
|
||||
tsx: true,
|
||||
decorators: true,
|
||||
dynamic_import: false,
|
||||
dts: false,
|
||||
no_early_errors: true,
|
||||
..Default::default()
|
||||
}),
|
||||
Default::default(),
|
||||
(&*src).into(),
|
||||
|
@ -229,6 +229,7 @@ where
|
||||
tsx: fname.contains("tsx"),
|
||||
dynamic_import: true,
|
||||
decorators: true,
|
||||
import_assertions: true,
|
||||
no_early_errors,
|
||||
..Default::default()
|
||||
}),
|
||||
|
@ -42,7 +42,8 @@
|
||||
"value": "test",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "ImportDeclaration",
|
||||
@ -82,7 +83,8 @@
|
||||
"value": "test",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
|
@ -44,7 +44,8 @@
|
||||
"value": "react",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "FunctionDeclaration",
|
||||
|
@ -55,7 +55,8 @@
|
||||
"value": "foo",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": true
|
||||
"typeOnly": true,
|
||||
"asserts": null
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
|
@ -44,7 +44,8 @@
|
||||
"value": "foo",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": true
|
||||
"typeOnly": true,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "ImportDeclaration",
|
||||
@ -84,7 +85,8 @@
|
||||
"value": "./a",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
|
@ -45,7 +45,8 @@
|
||||
"value": "foo",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": true
|
||||
"typeOnly": true,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "ImportDeclaration",
|
||||
@ -65,7 +66,8 @@
|
||||
"value": "foo",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": true
|
||||
"typeOnly": true,
|
||||
"asserts": null
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
|
@ -0,0 +1 @@
|
||||
foo(import('./lazy', { assert: { type: "json" } }))
|
@ -0,0 +1,140 @@
|
||||
{
|
||||
"type": "Module",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 51,
|
||||
"ctxt": 0
|
||||
},
|
||||
"body": [
|
||||
{
|
||||
"type": "ExpressionStatement",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 51,
|
||||
"ctxt": 0
|
||||
},
|
||||
"expression": {
|
||||
"type": "CallExpression",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 51,
|
||||
"ctxt": 0
|
||||
},
|
||||
"callee": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 3,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "foo",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"arguments": [
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "CallExpression",
|
||||
"span": {
|
||||
"start": 4,
|
||||
"end": 50,
|
||||
"ctxt": 0
|
||||
},
|
||||
"callee": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 4,
|
||||
"end": 10,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "import",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"arguments": [
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "StringLiteral",
|
||||
"span": {
|
||||
"start": 11,
|
||||
"end": 19,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "./lazy",
|
||||
"hasEscape": false
|
||||
}
|
||||
},
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "ObjectExpression",
|
||||
"span": {
|
||||
"start": 21,
|
||||
"end": 49,
|
||||
"ctxt": 0
|
||||
},
|
||||
"properties": [
|
||||
{
|
||||
"type": "KeyValueProperty",
|
||||
"key": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 23,
|
||||
"end": 29,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "assert",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"value": {
|
||||
"type": "ObjectExpression",
|
||||
"span": {
|
||||
"start": 31,
|
||||
"end": 47,
|
||||
"ctxt": 0
|
||||
},
|
||||
"properties": [
|
||||
{
|
||||
"type": "KeyValueProperty",
|
||||
"key": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 33,
|
||||
"end": 37,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "type",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"value": {
|
||||
"type": "StringLiteral",
|
||||
"span": {
|
||||
"start": 39,
|
||||
"end": 45,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "json",
|
||||
"hasEscape": false
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
],
|
||||
"typeArguments": null
|
||||
}
|
||||
}
|
||||
],
|
||||
"typeArguments": null
|
||||
}
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
}
|
@ -0,0 +1,2 @@
|
||||
import('./lazy', { assert: { type: "json" } })
|
||||
.then((lazy) => console.log(lazy))
|
@ -0,0 +1,230 @@
|
||||
{
|
||||
"type": "Module",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 85,
|
||||
"ctxt": 0
|
||||
},
|
||||
"body": [
|
||||
{
|
||||
"type": "ExpressionStatement",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 85,
|
||||
"ctxt": 0
|
||||
},
|
||||
"expression": {
|
||||
"type": "CallExpression",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 85,
|
||||
"ctxt": 0
|
||||
},
|
||||
"callee": {
|
||||
"type": "MemberExpression",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 56,
|
||||
"ctxt": 0
|
||||
},
|
||||
"object": {
|
||||
"type": "CallExpression",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 46,
|
||||
"ctxt": 0
|
||||
},
|
||||
"callee": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 6,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "import",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"arguments": [
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "StringLiteral",
|
||||
"span": {
|
||||
"start": 7,
|
||||
"end": 15,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "./lazy",
|
||||
"hasEscape": false
|
||||
}
|
||||
},
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "ObjectExpression",
|
||||
"span": {
|
||||
"start": 17,
|
||||
"end": 45,
|
||||
"ctxt": 0
|
||||
},
|
||||
"properties": [
|
||||
{
|
||||
"type": "KeyValueProperty",
|
||||
"key": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 19,
|
||||
"end": 25,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "assert",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"value": {
|
||||
"type": "ObjectExpression",
|
||||
"span": {
|
||||
"start": 27,
|
||||
"end": 43,
|
||||
"ctxt": 0
|
||||
},
|
||||
"properties": [
|
||||
{
|
||||
"type": "KeyValueProperty",
|
||||
"key": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 29,
|
||||
"end": 33,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "type",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"value": {
|
||||
"type": "StringLiteral",
|
||||
"span": {
|
||||
"start": 35,
|
||||
"end": 41,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "json",
|
||||
"hasEscape": false
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
],
|
||||
"typeArguments": null
|
||||
},
|
||||
"property": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 52,
|
||||
"end": 56,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "then",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"computed": false
|
||||
},
|
||||
"arguments": [
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "ArrowFunctionExpression",
|
||||
"span": {
|
||||
"start": 57,
|
||||
"end": 84,
|
||||
"ctxt": 0
|
||||
},
|
||||
"params": [
|
||||
{
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 58,
|
||||
"end": 62,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "lazy",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
}
|
||||
],
|
||||
"body": {
|
||||
"type": "CallExpression",
|
||||
"span": {
|
||||
"start": 67,
|
||||
"end": 84,
|
||||
"ctxt": 0
|
||||
},
|
||||
"callee": {
|
||||
"type": "MemberExpression",
|
||||
"span": {
|
||||
"start": 67,
|
||||
"end": 78,
|
||||
"ctxt": 0
|
||||
},
|
||||
"object": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 67,
|
||||
"end": 74,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "console",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"property": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 75,
|
||||
"end": 78,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "log",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"computed": false
|
||||
},
|
||||
"arguments": [
|
||||
{
|
||||
"spread": null,
|
||||
"expression": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 79,
|
||||
"end": 83,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "lazy",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
}
|
||||
}
|
||||
],
|
||||
"typeArguments": null
|
||||
},
|
||||
"async": false,
|
||||
"generator": false,
|
||||
"typeParameters": null,
|
||||
"returnType": null
|
||||
}
|
||||
}
|
||||
],
|
||||
"typeArguments": null
|
||||
}
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
}
|
@ -0,0 +1 @@
|
||||
import json from "./foo.json" assert { type: "json" };
|
@ -0,0 +1,85 @@
|
||||
{
|
||||
"type": "Module",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 54,
|
||||
"ctxt": 0
|
||||
},
|
||||
"body": [
|
||||
{
|
||||
"type": "ImportDeclaration",
|
||||
"span": {
|
||||
"start": 0,
|
||||
"end": 54,
|
||||
"ctxt": 0
|
||||
},
|
||||
"specifiers": [
|
||||
{
|
||||
"type": "ImportDefaultSpecifier",
|
||||
"span": {
|
||||
"start": 7,
|
||||
"end": 11,
|
||||
"ctxt": 0
|
||||
},
|
||||
"local": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 7,
|
||||
"end": 11,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "json",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
}
|
||||
}
|
||||
],
|
||||
"source": {
|
||||
"type": "StringLiteral",
|
||||
"span": {
|
||||
"start": 17,
|
||||
"end": 29,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "./foo.json",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false,
|
||||
"asserts": {
|
||||
"type": "ObjectExpression",
|
||||
"span": {
|
||||
"start": 37,
|
||||
"end": 53,
|
||||
"ctxt": 0
|
||||
},
|
||||
"properties": [
|
||||
{
|
||||
"type": "KeyValueProperty",
|
||||
"key": {
|
||||
"type": "Identifier",
|
||||
"span": {
|
||||
"start": 39,
|
||||
"end": 43,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "type",
|
||||
"typeAnnotation": null,
|
||||
"optional": false
|
||||
},
|
||||
"value": {
|
||||
"type": "StringLiteral",
|
||||
"span": {
|
||||
"start": 45,
|
||||
"end": 51,
|
||||
"ctxt": 0
|
||||
},
|
||||
"value": "json",
|
||||
"hasEscape": false
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
],
|
||||
"interpreter": null
|
||||
}
|
@ -71,7 +71,8 @@
|
||||
"value": "a",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
}
|
||||
]
|
||||
}
|
||||
|
@ -45,7 +45,8 @@
|
||||
"value": "../../deps.ts",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "ImportDeclaration",
|
||||
@ -85,7 +86,8 @@
|
||||
"value": "../../members.ts",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "ImportDeclaration",
|
||||
@ -126,7 +128,8 @@
|
||||
"value": "../../../mod.ts",
|
||||
"hasEscape": false
|
||||
},
|
||||
"typeOnly": false
|
||||
"typeOnly": false,
|
||||
"asserts": null
|
||||
},
|
||||
{
|
||||
"type": "ExpressionStatement",
|
||||
|
@ -286,6 +286,7 @@ impl Fold for Polyfills {
|
||||
has_escape: false,
|
||||
},
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
}))
|
||||
}),
|
||||
);
|
||||
@ -302,6 +303,7 @@ impl Fold for Polyfills {
|
||||
has_escape: false,
|
||||
},
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
}))
|
||||
}),
|
||||
);
|
||||
|
@ -6,7 +6,7 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecma_transforms"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.23.16"
|
||||
version = "0.24.0"
|
||||
|
||||
[features]
|
||||
const-modules = ["dashmap"]
|
||||
@ -21,7 +21,7 @@ either = "1.5"
|
||||
fxhash = "0.2"
|
||||
indexmap = "1"
|
||||
is-macro = "0.1"
|
||||
jsdoc = {version = "0.5.0", path = "../jsdoc"}
|
||||
jsdoc = {version = "0.6.0", path = "../jsdoc"}
|
||||
log = "0.4.8"
|
||||
once_cell = "1"
|
||||
ordered-float = "1.0.1"
|
||||
@ -34,17 +34,17 @@ serde_json = "1"
|
||||
smallvec = "1"
|
||||
swc_atoms = {version = "0.2.0", path = "../../atoms"}
|
||||
swc_common = {version = "0.10.0", path = "../../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_parser = {version = "0.37.0", path = "../parser"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_ecma_parser = {version = "0.38.0", path = "../parser"}
|
||||
swc_ecma_transforms_macros = {version = "0.1.1", path = "./macros"}
|
||||
swc_ecma_utils = {version = "0.21.0", path = "../utils"}
|
||||
swc_ecma_visit = {version = "0.17.0", path = "../visit"}
|
||||
swc_ecma_utils = {version = "0.22.0", path = "../utils"}
|
||||
swc_ecma_visit = {version = "0.18.0", path = "../visit"}
|
||||
unicode-xid = "0.2"
|
||||
|
||||
[dev-dependencies]
|
||||
pretty_assertions = "0.6"
|
||||
sourcemap = "6"
|
||||
swc_ecma_codegen = {version = "0.35.0", path = "../codegen"}
|
||||
swc_ecma_codegen = {version = "0.36.0", path = "../codegen"}
|
||||
tempfile = "3"
|
||||
testing = {version = "0.10.0", path = "../../testing"}
|
||||
walkdir = "2"
|
||||
|
@ -246,6 +246,7 @@ impl InjectHelpers {
|
||||
})],
|
||||
src: quote_str!("@swc/helpers"),
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
}))]
|
||||
} else {
|
||||
vec![]
|
||||
|
@ -1,4 +1,5 @@
|
||||
pub use self::{decorators::decorators, export::export};
|
||||
pub use self::{decorators::decorators, export::export, import_assertions::import_assertions};
|
||||
|
||||
pub mod decorators;
|
||||
mod export;
|
||||
mod import_assertions;
|
||||
|
@ -50,6 +50,7 @@ impl Fold for ExportDefaultFrom {
|
||||
.clone()
|
||||
.expect("`export default from` requires source"),
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
})));
|
||||
extra_stmts.push(ModuleItem::ModuleDecl(ModuleDecl::ExportNamed(
|
||||
NamedExport {
|
||||
@ -82,6 +83,7 @@ impl Fold for ExportDefaultFrom {
|
||||
.clone()
|
||||
.expect("`export default from` requires source"),
|
||||
type_only: false,
|
||||
asserts: None,
|
||||
})));
|
||||
extra_stmts.push(ModuleItem::ModuleDecl(ModuleDecl::ExportNamed(
|
||||
NamedExport {
|
||||
|
15
ecmascript/transforms/src/proposals/import_assertions.rs
Normal file
15
ecmascript/transforms/src/proposals/import_assertions.rs
Normal file
@ -0,0 +1,15 @@
|
||||
use swc_ecma_ast::ImportDecl;
|
||||
use swc_ecma_visit::{as_folder, noop_visit_mut_type, Fold, VisitMut};
|
||||
|
||||
pub fn import_assertions() -> impl Fold {
|
||||
as_folder(ImportAssertions)
|
||||
}
|
||||
struct ImportAssertions;
|
||||
|
||||
impl VisitMut for ImportAssertions {
|
||||
noop_visit_mut_type!();
|
||||
|
||||
fn visit_mut_import_decl(&mut self, n: &mut ImportDecl) {
|
||||
n.asserts = None;
|
||||
}
|
||||
}
|
@ -150,6 +150,7 @@ fn correctness_tests(tests: &mut Vec<TestDescAndFn>) -> Result<(), io::Error> {
|
||||
dynamic_import: true,
|
||||
dts: false,
|
||||
no_early_errors: false,
|
||||
import_assertions: true,
|
||||
}),
|
||||
(&*src).into(),
|
||||
None,
|
||||
|
@ -6,7 +6,7 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecma_utils"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.21.0"
|
||||
version = "0.22.0"
|
||||
|
||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||
|
||||
@ -15,8 +15,8 @@ once_cell = "1"
|
||||
scoped-tls = "1"
|
||||
swc_atoms = {version = "0.2.0", path = "../../atoms"}
|
||||
swc_common = {version = "0.10.0", path = "../../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_visit = {version = "0.17.0", path = "../visit"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_ecma_visit = {version = "0.18.0", path = "../visit"}
|
||||
unicode-xid = "0.2"
|
||||
|
||||
[dev-dependencies]
|
||||
|
@ -6,11 +6,11 @@ edition = "2018"
|
||||
license = "Apache-2.0/MIT"
|
||||
name = "swc_ecma_visit"
|
||||
repository = "https://github.com/swc-project/swc.git"
|
||||
version = "0.17.2"
|
||||
version = "0.18.0"
|
||||
|
||||
[dependencies]
|
||||
num-bigint = {version = "0.2", features = ["serde"]}
|
||||
swc_atoms = {version = "0.2", path = "../../atoms"}
|
||||
swc_common = {version = "0.10.0", path = "../../common"}
|
||||
swc_ecma_ast = {version = "0.31.0", path = "../ast"}
|
||||
swc_ecma_ast = {version = "0.32.0", path = "../ast"}
|
||||
swc_visit = {version = "0.2.0", path = "../../visit"}
|
||||
|
@ -926,6 +926,7 @@ define!({
|
||||
pub specifiers: Vec<ImportSpecifier>,
|
||||
pub src: Str,
|
||||
pub type_only: bool,
|
||||
pub asserts: Option<ObjectLit>,
|
||||
}
|
||||
pub struct ExportAll {
|
||||
pub span: Span,
|
||||
|
@ -5,7 +5,8 @@ use swc_atoms::JsWord;
|
||||
use swc_common::{chain, comments::Comments, errors::Handler, Mark, SourceMap};
|
||||
use swc_ecma_parser::Syntax;
|
||||
use swc_ecma_transforms::{
|
||||
compat, const_modules, fixer, helpers, hygiene, modules, pass::Optional, typescript,
|
||||
compat, const_modules, fixer, helpers, hygiene, modules, pass::Optional,
|
||||
proposals::import_assertions, typescript,
|
||||
};
|
||||
|
||||
/// Builder is used to create a high performance `Compiler`.
|
||||
@ -129,11 +130,13 @@ impl<'a, 'b, P: swc_ecma_visit::Fold> PassBuilder<'a, 'b, P> {
|
||||
// compat
|
||||
let compat_pass = if let Some(env) = self.env {
|
||||
Either::Left(chain!(
|
||||
import_assertions(),
|
||||
Optional::new(typescript::strip(), syntax.typescript()),
|
||||
swc_ecma_preset_env::preset_env(self.global_mark, env)
|
||||
))
|
||||
} else {
|
||||
Either::Right(chain!(
|
||||
import_assertions(),
|
||||
Optional::new(
|
||||
compat::es2020::nullish_coalescing(),
|
||||
self.target < JscTarget::Es2020
|
||||
|
Loading…
Reference in New Issue
Block a user