Skip to content

this type should return instance type when overridden #2904

Open
@mattjohnsonpint

Description

@mattjohnsonpint

Bug description

Found via StackOverflow: https://stackoverflow.com/q/79232050/634824

TypeScript allows the this keyword to be used as a type.

AssemblyScript seems to recognize this syntax and compiles fine:

class X {
  doSomething(): this {
      return this;
  }
}

However, in AssemblyScript, it always is treated as the class where this is used - which is not necessarily the type of the instance when the object is extended.

class Y extends X {
  doSomethingElse(): string {
      return "You made it!";
  }
}

Steps to reproduce

With the above code,

console.log(new Y().doSomething().doSomethingElse());

fails to compile. The error is:

ERROR TS2339: Property 'doSomethingElse' does not exist on type 'assembly/index/X'.
    :
 12 │ console.log(new Y().doSomething().doSomethingElse());
    │                                   ~~~~~~~~~~~~~~~
    └─ in assembly/index.ts(12,35)

Essentially, y.doSomething() is returning a type X where it should return a type Y.

TypeScript tooling believes the value should be Y, but AssemblyScript thinks it's X.

Image

Casting the value using <Y> or as Y works, but the point is that one may have full awareness of the original type when making the call.

AssemblyScript version

v0.27.32

Activity

mattjohnsonpint

mattjohnsonpint commented on Feb 3, 2025

@mattjohnsonpint
ContributorAuthor

I think perhaps this may have been overlooked when implementing #1208 for #693.

mattjohnsonpint

mattjohnsonpint commented on Feb 5, 2025

@mattjohnsonpint
ContributorAuthor

I think this gives a clue to the issue:

assemblyscript/src/resolver.ts

Lines 2859 to 2861 in 9a7a6e0

// Instance method prototypes are pre-bound to their concrete class as their parent
if (prototype.is(CommonFlags.Instance)) {
classInstance = assert(prototype.getBoundClassOrInterface());

The function prototype is X.doSomething, so the classInstance is X (not Y).

I think I will try to fix this. PR forthcoming...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Metadata

Metadata

Assignees

No one assigned

    Labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

      Participants

      @mattjohnsonpint

      Issue actions

        `this` type should return instance type when overridden · Issue #2904 · AssemblyScript/assemblyscript