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

Make tuple and custom array declared as interface compatible #413

Open
wants to merge 41 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
370071b
feat: implement interface array case
devgony Jan 14, 2023
ce4cf98
fix: filter array by `type_of_ts_entity_name`
devgony Jan 14, 2023
fc48981
temp-1
devgony Feb 1, 2023
71cefdd
fix: implement handling interface at `assign/mod.rs`
devgony Feb 1, 2023
0399886
Merge branch 'arityAndOrderCompatibility-n' into arityAndOrderCompati…
devgony Feb 1, 2023
96f4567
fix: remove previous implement
devgony Feb 1, 2023
f27ad7e
fix: remove imports
devgony Feb 1, 2023
43f4aec
chore: remove redundant diff
devgony Feb 1, 2023
3194496
Merge remote-tracking branch 'upstream/main' into arityAndOrderCompat…
devgony Feb 1, 2023
20f4513
fix: compare types of lhs and rhs
devgony Feb 6, 2023
bd11c05
fix: zip and iterate each lkind and rkind
devgony Feb 7, 2023
259c374
fix: early return `assign_with_opts`
devgony Feb 7, 2023
5928792
chore: remove unused import
devgony Feb 7, 2023
2e880cb
fix: remove unused params
devgony Feb 7, 2023
135e2b3
fix: remove wrong spell
devgony Feb 7, 2023
e40402d
Merge remote-tracking branch 'upstream/main' into arityAndOrderCompat…
devgony Mar 23, 2023
bba28d3
fix: thanks clippy
devgony Mar 23, 2023
939a9c0
Merge remote-tracking branch 'upstream/main' into arityAndOrderCompat…
devgony May 19, 2023
7e87f8e
style: cargo fmt
devgony May 19, 2023
78011c1
style: thanks clippy
devgony May 19, 2023
b794a61
Merge remote-tracking branch 'upstream/main' into arityAndOrderCompat…
devgony Jun 3, 2023
9d463e3
Merge branch 'main' into arityAndOrderCompatibility
devgony Jun 3, 2023
4976748
test: add a case that should pass
devgony Jun 3, 2023
3d3fcca
fix: replace the order of lhs and rhs
devgony Jun 3, 2023
e85466f
Merge remote-tracking branch 'origin/arityAndOrderCompatibility' into…
devgony Jun 3, 2023
e4a786b
feat: correct errors.json
devgony Jun 3, 2023
fb8d765
refactor: remove redundant line, reduce clone
devgony Jun 3, 2023
0a08ed7
fix: renamt lhss to lsh_types
devgony Jun 4, 2023
bdf5da0
fix: remove unresolved test cases
devgony Jun 6, 2023
5759dc2
chore: run check.sh
devgony Jun 6, 2023
0da1d65
fix: correct error line number
devgony Jun 6, 2023
594c1e1
Merge remote-tracking branch 'upstream/main' into arityAndOrderCompat…
devgony Dec 29, 2023
4a839ca
fix: recover official tsc conformance test suite
devgony Dec 29, 2023
6ba341b
fix: remove error on line 39
devgony Dec 29, 2023
3df5f8b
fix: amend matched_error to 17
devgony Dec 29, 2023
b8551db
fix: remove formatting
devgony Dec 29, 2023
3ea7e93
fix: recover solved issue
devgony Jan 25, 2024
5f8c1df
feat: handle line16
devgony Jan 25, 2024
97256d8
feat: handle line17, 19
devgony Jan 25, 2024
66ecbd5
test: add arityAndOrderCompatibility02 case
devgony Jan 25, 2024
ed10347
chore: add test log
devgony Jan 25, 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
1 change: 1 addition & 0 deletions crates/stc_ts_file_analyzer/src/analyzer/assign/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -535,6 +535,7 @@ impl Analyzer<'_, '_> {
op: TsTypeOperatorOp::KeyOf,
..
})
| Type::Interface(..)
| Type::Tpl(..) => {
let ty = self
.normalize(
Expand Down
39 changes: 34 additions & 5 deletions crates/stc_ts_file_analyzer/src/analyzer/types/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,10 @@ use stc_ts_generics::ExpandGenericOpts;
use stc_ts_type_ops::{tuple_normalization::TupleNormalizer, Fix};
use stc_ts_types::{
name::Name, Accessor, Array, Class, ClassDef, ClassMember, ClassMetadata, ComputedKey, Conditional, ConditionalMetadata,
ConstructorSignature, EnumVariant, FnParam, Id, IdCtx, IndexSignature, IndexedAccessType, Instance, InstanceMetadata, Intersection,
IntrinsicKind, Key, KeywordType, KeywordTypeMetadata, LitType, LitTypeMetadata, MethodSignature, Operator, PropertySignature,
QueryExpr, QueryType, Ref, StringMapping, ThisType, ThisTypeMetadata, TplElem, TplType, Type, TypeElement, TypeLit, TypeLitMetadata,
TypeParam, TypeParamInstantiation, Union,
ConstructorSignature, EnumVariant, FnParam, Id, IdCtx, IndexSignature, IndexedAccessType, Instance, InstanceMetadata, Interface,
InterfaceMetadata, Intersection, IntrinsicKind, Key, KeywordType, KeywordTypeMetadata, LitType, LitTypeMetadata, MethodSignature,
Operator, PropertySignature, QueryExpr, QueryType, Ref, StringMapping, ThisType, ThisTypeMetadata, TplElem, TplType, Type, TypeElement,
TypeLit, TypeLitMetadata, TypeParam, TypeParamInstantiation, Union,
};
use stc_ts_utils::run;
use stc_utils::{
Expand Down Expand Up @@ -108,7 +108,6 @@ impl Analyzer<'_, '_> {
match ty.normalize() {
Type::Lit(..)
| Type::TypeLit(..)
| Type::Interface(..)
| Type::Class(..)
| Type::ClassDef(..)
| Type::Tuple(..)
Expand All @@ -117,6 +116,36 @@ impl Analyzer<'_, '_> {
| Type::EnumVariant(..)
| Type::Param(_)
| Type::Module(_) => return Ok(ty),
Type::Interface(Interface {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this approach is wrong

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you mean we should add more condition here to decrease the range of match arm?
Or It is totally wrong location to implement?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I meant the latter

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you give any tips like where to start first?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think some match expressions should be added to

span,
name,
type_params,
extends,
body,
metadata: InterfaceMetadata { common },
tracker,
}) => {
for extend in extends {
let types = extend.to_owned().type_args.into_iter().flat_map(|cur| cur.params);
let union_type = Type::new_union(*span, types);
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It almost solved nest_assignment errors but not RegExpExecArray yet.
Could you give me any hint where to get RegExpExecArray type to return Array?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

RegExpExecArray is declared as

interface RegExpExecArray extends Array<string> {
    index: number;
    input: string;
}

So you need to check the type arguments of Array

if let box RExpr::Ident(ident) = &extend.expr {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should check for Type::Array after using self.type_of_ts_entity_name

let RIdent {
node_id,
span,
sym,
optional,
} = ident;
if sym == &js_word!("Array") {
return Ok(Cow::Owned(Type::Array(Array {
span: *span,
elem_type: box union_type,
metadata: Default::default(),
tracker: Default::default(),
})));
};
};
}
}
_ => {}
}

Expand Down