Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(typescript): Align isolatedDeclaration implementation with tsc #9715

Merged
merged 49 commits into from
Dec 2, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
d583101
port: fix(fast_check/dts): remove initializers in class methods/ctors…
CPunisher Nov 4, 2024
8551a4e
port: fix(fast_check/dts): better handling of computed properties #522
CPunisher Nov 4, 2024
db1b136
port: feat: analyze commonjs files #540
CPunisher Nov 4, 2024
8f7bdda
fix overloads
CPunisher Nov 5, 2024
60370af
impl
CPunisher Nov 5, 2024
f8dd99c
check binding
CPunisher Nov 5, 2024
4d0ab66
ts snapshot tests
CPunisher Nov 5, 2024
dcc3162
Split transformations
CPunisher Nov 13, 2024
a0c4ea4
Fix rebase conflict
CPunisher Nov 13, 2024
34726be
Fix
CPunisher Nov 13, 2024
5486c8b
is_declare
CPunisher Nov 13, 2024
e70157b
finish function
CPunisher Nov 14, 2024
5d41a43
finish class
CPunisher Nov 15, 2024
61f003a
collect_getter_or_setter_annotations
CPunisher Nov 15, 2024
ccd4e44
var decl
CPunisher Nov 15, 2024
d19679a
type inferer
CPunisher Nov 16, 2024
696d55f
deno test, fix dts_function_test
CPunisher Nov 16, 2024
a34cb0c
reset fixtures
CPunisher Nov 16, 2024
d97b1ab
pass deno tests
CPunisher Nov 16, 2024
d8e60d5
fix ts module block
CPunisher Nov 17, 2024
08764b7
fix arrow-function-return-type
CPunisher Nov 17, 2024
aa23875
enum
CPunisher Nov 18, 2024
e2d3221
fix as-const
CPunisher Nov 18, 2024
eda081f
fix async function
CPunisher Nov 18, 2024
e7e6613
fix class
CPunisher Nov 18, 2024
466609b
fix eliminate-imports
CPunisher Nov 18, 2024
43c83e0
fix empty-export
CPunisher Nov 18, 2024
35403f5
fix expando-function
CPunisher Nov 22, 2024
1b969c5
fix export-default
CPunisher Nov 22, 2024
84090fe
fix function-*
CPunisher Nov 22, 2024
5eea8d8
fix module-declaration-with-export
CPunisher Nov 22, 2024
e044ce1
fix non-exported-binding-elements
CPunisher Nov 22, 2024
9c54c78
fix ts-export-assignment
CPunisher Nov 22, 2024
d78421a
fix set-get-accessor
CPunisher Nov 22, 2024
a759710
strip internal
CPunisher Nov 22, 2024
8f720f8
add example
CPunisher Nov 22, 2024
a6db37c
refactor
CPunisher Nov 22, 2024
d402015
use fx hash
CPunisher Nov 22, 2024
7ae548b
type usage graph
CPunisher Nov 23, 2024
bf181bb
add benchmark
CPunisher Nov 23, 2024
bf3c9b6
remove usage analysis for script
CPunisher Nov 23, 2024
3d6694c
update license
CPunisher Nov 23, 2024
bbc9a58
update tests and enable comments
CPunisher Nov 24, 2024
a885a27
remove decl that is not ident
CPunisher Nov 24, 2024
e4b34dd
remove enum and ts import equals
CPunisher Nov 24, 2024
6bafe04
fix binding-ref and ts-property
CPunisher Nov 24, 2024
8df2bd8
Revert manual tokio runtime
CPunisher Nov 28, 2024
eb88853
change iter_with_large_drop to iter
CPunisher Nov 28, 2024
858d762
Create tiny-snakes-train.md
kdy1 Dec 2, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
strip internal
  • Loading branch information
CPunisher committed Nov 23, 2024
commit a75971085cd3016330c737fc331690cca3238e07
2 changes: 1 addition & 1 deletion crates/swc/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -979,7 +979,7 @@ impl Compiler {
let trailing = std::rc::Rc::new(RefCell::new(trailing.clone()));

let comments = SingleThreadedComments::from_leading_and_trailing(leading, trailing);
let mut checker = FastDts::new(fm.name.clone());
let mut checker = FastDts::new(fm.name.clone(), Default::default());
let mut program = program.clone();

if let Some((base, resolver)) = config.resolver {
Expand Down
17 changes: 16 additions & 1 deletion crates/swc_typescript/src/fast_dts/class.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,9 @@ impl FastDts {
for mut member in body {
match &mut member {
ClassMember::Constructor(constructor) => {
if self.has_internal_annotation(constructor.span_lo()) {
continue;
}
if !(constructor.is_optional) && constructor.body.is_none() {
is_function_overloads = true;
} else if is_function_overloads {
Expand Down Expand Up @@ -79,6 +82,9 @@ impl FastDts {
class.body.push(member);
}
ClassMember::Method(method) => {
if self.has_internal_annotation(method.span_lo()) {
continue;
}
if !(method.is_abstract || method.is_optional) && method.function.body.is_none()
{
is_function_overloads = true;
Expand Down Expand Up @@ -209,6 +215,9 @@ impl FastDts {
class.body.push(member);
}
ClassMember::ClassProp(prop) => {
if self.has_internal_annotation(prop.span_lo()) {
continue;
}
if self.report_property_key(&prop.key) {
continue;
}
Expand All @@ -219,10 +228,16 @@ impl FastDts {
ClassMember::PrivateMethod(_) | ClassMember::PrivateProp(_) => {
has_private_key = true;
}
ClassMember::TsIndexSignature(_) => {
ClassMember::TsIndexSignature(ts_index_signature) => {
if self.has_internal_annotation(ts_index_signature.span_lo()) {
continue;
}
class.body.push(member);
}
ClassMember::AutoAccessor(auto_accessor) => {
if self.has_internal_annotation(auto_accessor.span_lo()) {
continue;
}
let Key::Public(prop_name) = &auto_accessor.key else {
has_private_key = true;
continue;
Expand Down
39 changes: 25 additions & 14 deletions crates/swc_typescript/src/fast_dts/decl.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,12 @@ use swc_common::Spanned;
use swc_ecma_ast::{
Decl, DefaultDecl, Expr, Lit, Pat, TsNamespaceBody, VarDeclKind, VarDeclarator,
};
use swc_ecma_visit::VisitMutWith;

use super::{
type_ann,
util::{any_type_ann, PatExt},
visitors::internal_annotation::InternalAnnotationTransformer,
FastDts,
};

Expand All @@ -18,7 +20,7 @@ impl FastDts {
return;
}

if check_binding && !self.analyzer.used_ids().contains(&class_decl.ident.to_id()) {
if check_binding && !self.used_ids.contains(&class_decl.ident.to_id()) {
return;
}

Expand All @@ -30,7 +32,7 @@ impl FastDts {
return;
}

if check_binding && !self.analyzer.used_ids().contains(&fn_decl.ident.to_id()) {
if check_binding && !self.used_ids.contains(&fn_decl.ident.to_id()) {
return;
}

Expand All @@ -45,9 +47,10 @@ impl FastDts {
var.declare = is_declare;
for decl in var.decls.iter_mut() {
if check_binding
&& decl.name.as_ident().map_or(false, |ident| {
!self.analyzer.used_ids().contains(&ident.to_id())
})
&& decl
.name
.as_ident()
.map_or(false, |ident| !self.used_ids.contains(&ident.to_id()))
{
return;
}
Expand All @@ -57,9 +60,10 @@ impl FastDts {
Decl::Using(using) => {
for decl in using.decls.iter_mut() {
if check_binding
&& decl.name.as_ident().map_or(false, |ident| {
!self.analyzer.used_ids().contains(&ident.to_id())
})
&& decl
.name
.as_ident()
.map_or(false, |ident| !self.used_ids.contains(&ident.to_id()))
{
return;
}
Expand All @@ -68,7 +72,7 @@ impl FastDts {
}
Decl::TsEnum(ts_enum) => {
ts_enum.declare = is_declare;
if check_binding && !self.analyzer.used_ids().contains(&ts_enum.id.to_id()) {
if check_binding && !self.used_ids.contains(&ts_enum.id.to_id()) {
return;
}
self.transform_enum(ts_enum.as_mut());
Expand All @@ -81,9 +85,10 @@ impl FastDts {
if !ts_module.global
&& !ts_module.id.is_str()
&& check_binding
&& ts_module.id.as_ident().map_or(false, |ident| {
!self.analyzer.used_ids().contains(&ident.to_id())
})
&& ts_module
.id
.as_ident()
.map_or(false, |ident| !self.used_ids.contains(&ident.to_id()))
{
return;
}
Expand All @@ -96,7 +101,13 @@ impl FastDts {
);
}
}
Decl::TsInterface(_) | Decl::TsTypeAlias(_) => {}
Decl::TsInterface(_) | Decl::TsTypeAlias(_) => {
if let Some(internal_annotations) = self.internal_annotations.as_ref() {
decl.visit_mut_children_with(&mut InternalAnnotationTransformer::new(
internal_annotations,
))
}
}
}
}

Expand All @@ -113,7 +124,7 @@ impl FastDts {

if matches!(pat, Pat::Array(_) | Pat::Object(_)) {
pat.bound_names(&mut |ident| {
if !check_binding || self.analyzer.used_ids().contains(&ident.to_id()) {
if !check_binding || self.used_ids.contains(&ident.to_id()) {
self.binding_element_export(ident.span);
}
});
Expand Down
Loading