Skip to content

Commit

Permalink
fix(swc): Fix various bugs. (#1632)
Browse files Browse the repository at this point in the history
swc_ecma_transforms_typescript:
 - Fix import analyzer. (denoland/deno#10462)
  • Loading branch information
kdy1 authored May 3, 2021
1 parent d1415f9 commit d10671b
Show file tree
Hide file tree
Showing 13 changed files with 57 additions and 33 deletions.
6 changes: 3 additions & 3 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ edition = "2018"
license = "Apache-2.0/MIT"
name = "swc"
repository = "https://github.com/swc-project/swc.git"
version = "0.15.4"
version = "0.16.0"

[lib]
name = "swc"
Expand All @@ -33,8 +33,8 @@ swc_ecma_ast = {version = "0.43.1", path = "./ecmascript/ast"}
swc_ecma_codegen = {version = "0.52.3", path = "./ecmascript/codegen"}
swc_ecma_ext_transforms = {version = "0.12.2", path = "./ecmascript/ext-transforms"}
swc_ecma_parser = {version = "0.54.3", path = "./ecmascript/parser"}
swc_ecma_preset_env = {version = "0.15.3", path = "./ecmascript/preset_env"}
swc_ecma_transforms = {version = "0.45.3", path = "./ecmascript/transforms", features = [
swc_ecma_preset_env = {version = "0.16.0", path = "./ecmascript/preset_env"}
swc_ecma_transforms = {version = "0.46.0", path = "./ecmascript/transforms", features = [
"compat",
"module",
"optimization",
Expand Down
6 changes: 3 additions & 3 deletions bundler/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ include = ["Cargo.toml", "build.rs", "src/**/*.rs", "src/**/*.js"]
license = "Apache-2.0/MIT"
name = "swc_bundler"
repository = "https://github.com/swc-project/swc.git"
version = "0.32.8"
version = "0.33.0"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[features]
Expand All @@ -36,7 +36,7 @@ swc_common = {version = "0.10.16", path = "../common"}
swc_ecma_ast = {version = "0.43.1", path = "../ecmascript/ast"}
swc_ecma_codegen = {version = "0.52.3", path = "../ecmascript/codegen"}
swc_ecma_parser = {version = "0.54.3", path = "../ecmascript/parser"}
swc_ecma_transforms = {version = "0.45.3", path = "../ecmascript/transforms", features = ["optimization"]}
swc_ecma_transforms = {version = "0.46.0", path = "../ecmascript/transforms", features = ["optimization"]}
swc_ecma_utils = {version = "0.34.1", path = "../ecmascript/utils"}
swc_ecma_visit = {version = "0.29.1", path = "../ecmascript/visit"}

Expand All @@ -45,7 +45,7 @@ hex = "0.4"
ntest = "0.7.2"
reqwest = {version = "0.10.8", features = ["blocking"]}
sha-1 = "0.9"
swc_ecma_transforms = {version = "0.45.3", path = "../ecmascript/transforms", features = ["react", "typescript"]}
swc_ecma_transforms = {version = "0.46.0", path = "../ecmascript/transforms", features = ["react", "typescript"]}
tempfile = "3.1.0"
testing = {version = "0.10.5", path = "../testing"}
url = "2.1.1"
Expand Down
4 changes: 2 additions & 2 deletions ecmascript/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ edition = "2018"
license = "Apache-2.0/MIT"
name = "swc_ecmascript"
repository = "https://github.com/swc-project/swc.git"
version = "0.31.4"
version = "0.32.0"

[package.metadata.docs.rs]
all-features = true
Expand All @@ -31,7 +31,7 @@ swc_ecma_ast = {version = "0.43.1", path = "./ast"}
swc_ecma_codegen = {version = "0.52.3", path = "./codegen", optional = true}
swc_ecma_dep_graph = {version = "0.22.2", path = "./dep-graph", optional = true}
swc_ecma_parser = {version = "0.54.3", path = "./parser", optional = true}
swc_ecma_transforms = {version = "0.45.3", path = "./transforms", optional = true}
swc_ecma_transforms = {version = "0.46.0", path = "./transforms", optional = true}
swc_ecma_utils = {version = "0.34.1", path = "./utils", optional = true}
swc_ecma_visit = {version = "0.29.1", path = "./visit", optional = true}

Expand Down
4 changes: 2 additions & 2 deletions ecmascript/preset_env/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ documentation = "https://rustdoc.swc.rs/swc_ecma_preset_env/"
edition = "2018"
license = "Apache-2.0/MIT"
name = "swc_ecma_preset_env"
version = "0.15.4"
version = "0.16.0"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand All @@ -22,7 +22,7 @@ string_enum = {version = "0.3.1", path = "../../macros/string_enum"}
swc_atoms = {version = "0.2", path = "../../atoms"}
swc_common = {version = "0.10.16", path = "../../common"}
swc_ecma_ast = {version = "0.43.1", path = "../ast"}
swc_ecma_transforms = {version = "0.45.3", path = "../transforms", features = ["compat", "proposal"]}
swc_ecma_transforms = {version = "0.46.0", path = "../transforms", features = ["compat", "proposal"]}
swc_ecma_utils = {version = "0.34.1", path = "../utils"}
swc_ecma_visit = {version = "0.29.1", path = "../visit"}
walkdir = "2"
Expand Down
6 changes: 3 additions & 3 deletions ecmascript/transforms/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -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.45.3"
version = "0.46.0"

[package.metadata.docs.rs]
all-features = true
Expand All @@ -28,10 +28,10 @@ swc_ecma_parser = {version = "0.54.3", path = "../parser"}
swc_ecma_transforms_base = {version = "0.12.6", path = "./base"}
swc_ecma_transforms_compat = {version = "0.13.3", path = "./compat", optional = true}
swc_ecma_transforms_module = {version = "0.13.3", path = "./module", optional = true}
swc_ecma_transforms_optimization = {version = "0.15.5", path = "./optimization", optional = true}
swc_ecma_transforms_optimization = {version = "0.16.0", path = "./optimization", optional = true}
swc_ecma_transforms_proposal = {version = "0.13.3", path = "./proposal", optional = true}
swc_ecma_transforms_react = {version = "0.14.3", path = "./react", optional = true}
swc_ecma_transforms_typescript = {version = "0.14.4", path = "./typescript", optional = true}
swc_ecma_transforms_typescript = {version = "0.15.0", path = "./typescript", optional = true}
swc_ecma_utils = {version = "0.34.1", path = "../utils"}
swc_ecma_visit = {version = "0.29.1", path = "../visit"}
unicode-xid = "0.2"
Expand Down
4 changes: 2 additions & 2 deletions ecmascript/transforms/optimization/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ edition = "2018"
license = "Apache-2.0/MIT"
name = "swc_ecma_transforms_optimization"
repository = "https://github.com/swc-project/swc.git"
version = "0.15.6"
version = "0.16.0"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
Expand All @@ -31,5 +31,5 @@ swc_ecma_transforms_module = {version = "0.13.3", path = "../module"}
swc_ecma_transforms_proposal = {version = "0.13.3", path = "../proposal"}
swc_ecma_transforms_react = {version = "0.14.3", path = "../react"}
swc_ecma_transforms_testing = {version = "0.12.3", path = "../testing"}
swc_ecma_transforms_typescript = {version = "0.14.4", path = "../typescript"}
swc_ecma_transforms_typescript = {version = "0.15.0", path = "../typescript"}
testing = {version = "0.10.5", path = "../../../testing"}
2 changes: 1 addition & 1 deletion ecmascript/transforms/typescript/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ edition = "2018"
license = "Apache-2.0/MIT"
name = "swc_ecma_transforms_typescript"
repository = "https://github.com/swc-project/swc.git"
version = "0.14.4"
version = "0.15.0"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
Expand Down
11 changes: 11 additions & 0 deletions ecmascript/transforms/typescript/src/strip.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1133,6 +1133,17 @@ impl Visit for Strip {
n.value.visit_with(n, self);
}

fn visit_prop_name(&mut self, n: &PropName, _: &dyn Node) {
match n {
PropName::Computed(e) => e.visit_with(n, self),
_ => {}
}
}

fn visit_assign_prop(&mut self, n: &AssignProp, _: &dyn Node) {
n.value.visit_with(n, self);
}

fn visit_ident(&mut self, n: &Ident, _: &dyn Node) {
let is_type_only_export = self.is_type_only_export;
let entry = self
Expand Down
14 changes: 14 additions & 0 deletions ecmascript/transforms/typescript/tests/strip.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3962,3 +3962,17 @@ to!(
module.exports = 'something';
"
);

to!(
deno_10462,
"
import { foo } from './temp2.ts';
const _: foo = null;
console.log({ foo: 1 });
",
"
const _ = null;
console.log({ foo: 1 });
"
);
7 changes: 4 additions & 3 deletions native/babel-ast/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
[package]
name = "swc_babel_ast"
description = "Babel AST node definitions"
version = "0.1.0"
authors = ["Daniel Woznicki <daniel.woznicki@gmail.com>"]
description = "Babel AST node definitions"
edition = "2018"
license = "MIT"
name = "swc_babel_ast"
publish = false
version = "0.1.0"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
9 changes: 5 additions & 4 deletions native/babel-compat/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -4,23 +4,24 @@ description = "Compatibility layer between babel and swc"
edition = "2018"
license = "MIT"
name = "swc_babel_compat"
publish = false
version = "0.1.0"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
anyhow = "1"
ahash = "0.7.0"
anyhow = "1"
serde = {version = "1", features = ["derive"]}
serde_json = "1.0.62"
swc = {path = "../.."}
swc_atoms = {version = "0.2.5", path = "../../atoms"}
swc_babel_ast = {path = "../babel-ast"}
swc_babel_visit = {path = "../babel-visit"}
swc_common = {version = "0.10.9", path = "../../common", features = ["tty-emitter", "sourcemap"]}
swc_ecma_ast = {version = "0.43", path = "../../ecmascript/ast"}
swc_ecma_parser = {version= "0.54.2", path = "../../ecmascript/parser"}
swc_ecma_parser = {version = "0.54.2", path = "../../ecmascript/parser"}
swc_ecma_visit = {version = "0.29.1", path = "../../ecmascript/visit"}
swc_babel_ast = {path = "../babel-ast"}
swc_babel_visit = {path = "../babel-visit"}

[dev-dependencies]
pretty_assertions = "0.7.1"
Expand Down
8 changes: 2 additions & 6 deletions native/babel-compat/src/typescript.rs
Original file line number Diff line number Diff line change
Expand Up @@ -209,12 +209,8 @@ impl Babelify for TsTypeElement {
TsTypeElement::TsPropertySignature(t) => TSTypeElement::PropSignature(t.babelify(ctx)),
TsTypeElement::TsMethodSignature(t) => TSTypeElement::MethodSignature(t.babelify(ctx)),
TsTypeElement::TsIndexSignature(t) => TSTypeElement::IndexSignature(t.babelify(ctx)),
TsTypeElement::TsGetterSignature(_) => panic!("unimplemented"), /* TODO(dwoznicki):
* babel does not
* have this node */
TsTypeElement::TsSetterSignature(_) => panic!("unimplemented"), /* TODO(dwoznicki):
* babel does not
* have this node */
TsTypeElement::TsGetterSignature(_) => panic!("unimplemented"),
TsTypeElement::TsSetterSignature(_) => panic!("unimplemented"),
}
}
}
Expand Down
9 changes: 5 additions & 4 deletions native/babel-visit/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
[package]
name = "swc_babel_visit"
description = "Visitor implementation for babel nodes"
version = "0.1.0"
authors = ["Daniel Woznicki <daniel.woznicki@gmail.com>"]
description = "Visitor implementation for babel nodes"
edition = "2018"
license = "MIT"
name = "swc_babel_visit"
publish = false
version = "0.1.0"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
serde = {version = "1", features = ["derive"]}
serde_json = "1.0.62"
swc_visit = {version = "0.2.3", path = "../../visit"}
swc_babel_ast = {path = "../babel-ast"}
swc_visit = {version = "0.2.3", path = "../../visit"}

0 comments on commit d10671b

Please sign in to comment.