jsdoc2tsd
Warning: Highly Experimental
This library's goal is to be able to take as input a jsdoc annotated source JavaScript
file (or many files) and output a single TypeScript Declaration File (.d.ts).
It is distributed as a JSDoc3 template. Running jsdoc with this as the template should
result in a TypeScript Definition File.
Gotchas
Validation
This library provides almost no validation beyong what jsdoc provides. Meaning if you
have invalid jsodc comments, this will likely output an invalid TypeScript Definition File.
On the brightside, that means you will find invalid jsdoc pretty quickly.
Additionally there are things that jsdoc things are fine, that TypeScript does not.
One example would be a member variable marked with @constant
. While that is valid
jsdoc, it is not valid TS:
class MyClass {
const member: number;
}
So there a few cases like this where the jsdoc is massaged into valid TS.
module:...
This syntax is used to link to another module's docs. If you use it
to describe the code, it will be ignored.
For example, this JavaScript:
const Loader = require('resource-loader');
function MyClass() {
Loader.call(this);
}
MyClass.prototype = Object.create(Loader.prototype);
Will generate this declaration:
class MyClass {
}
Instead you can include their jsdoc commented source or write your own jsdocs to
describe Loader
and then just use @extends Loader
.
Method/Member Overrides
Any method or member that has the same name as one in the parent of a child class
will be ignored.
For example, this JavaScript:
class Parent {
constructor() {
this.someprop = true;
}
}
class Child extends Parent {
constructor() {
this.someprop = false;
}
}
Will generate this declaration:
class Parent {
someprop: boolean;
}
class Child extends Parent {
}
Unsupported Tags
Tags that describe the code, but support is not implemented are:
Additionally, tags that are just metadata and don't actually describe
the code are ignored. These are:
All other tags should work...