I have looked through UseJSDoc.org and Google’s Closure Compiler, and neither documentation describes how to specify array length.
My guess is the compiler only checks for type, not for length, so even if there were syntax to explicitly describe array length, an array of the incorrect length would probably still pass the compiler (no error would be thrown).
The best way to do this is in the human-language description of the parameter and return type:
/**
* Duplicates a 4-length array into itself.
* e.g. `[2, 3, 5, 8] => [2, 2, 3, 3, 5, 5, 8, 8]`
* @param {Array<number>} arr the array to duplicate (exactly 4 entries)
* @returns {Array<number>} the result (an array of length 8)
*/
function dupe(arr) {
...
}
FYI, you can use Array.<number>
, or Array<number>
, or even number[]
inside the @type
declaration.
If this feature is important to you (I’d certainly use it!), you can submit an issue.