-
Notifications
You must be signed in to change notification settings - Fork 12.8k
Support @extends
tag for ES5-style classes
#36369
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
Comments
I think (having recently looked at it) |
@extends
tag for ES5-style classes
I have this exact use case. Anyone done any digging as to how difficult this would be to support? I have no experience with TypeScript internals. |
#13206 is the main issue tracking inheritance for ES5 constructor functions. @jpoehnelt Full support is not hard, but would be tricky since it messes with the core class/ |
I have this use case as well - I have a constructor function Foo (that can't be turned into |
+1 please fix this |
TypeScript Version: 3.7.5 and 3.8.0-dev.20200123
Search Terms: extends not attached to a class
I'm currently evaluating if TypeScript can be used to type-check old closure compiler projects which use JSDoc annotations for typing and to generate *.d.ts files for it so the old projects can be easily used within new typescript projects. But unfortunately the
@extends
annotation is not working as expected. I would understand if TypeScript simply didn't support it (Then this would be a feature request) but the error message error TS8022: JSDoc '@extends' is not attached to a class thrown by the compiler suggests that there is some support for but it doesn't work as expected.Please note that the real class inheritance code which actually extends class
Sub
fromBase
is omitted in the code example below because it is irrelevant to the compiler.Code
Expected behavior:
Typescript should recognize type
Sub
to be a class which extends classBase
.Actual behavior:
Compilation fails with this error:
The text was updated successfully, but these errors were encountered: