mirror of
https://github.com/photonstorm/phaser
synced 2024-11-30 16:39:34 +00:00
60 lines
1.6 KiB
JavaScript
60 lines
1.6 KiB
JavaScript
/**
|
|
* Transform @property tags to @member tags if it looks like @property was incorrectly used.
|
|
* - That is, there is only one property and it has the same name as the member.
|
|
* The result is less-redundancy and better type exposure in the JSDoc output.
|
|
*
|
|
* If the member type is not assigned then the property type is used.
|
|
*
|
|
* A meld of the description are used; appending the property description if appropriate.
|
|
*
|
|
* This approach works for most cases in Phaser because JSDoc automatically determines the name if not specified in @name, @method, @member or @field.
|
|
*/
|
|
|
|
var path = require('path');
|
|
|
|
function looksLikeItMightContain (haystack, needle) {
|
|
|
|
haystack = haystack || '';
|
|
needle = needle || '';
|
|
|
|
haystack = haystack.replace(/[^a-z]/gi, '').toLowerCase();
|
|
needle = needle.replace(/[^a-z]/gi, '').toLowerCase();
|
|
|
|
return haystack.indexOf(needle) > -1;
|
|
|
|
}
|
|
|
|
exports.handlers = {};
|
|
exports.handlers.newDoclet = function (e) {
|
|
|
|
var doclet = e.doclet;
|
|
var props = e.doclet.properties;
|
|
|
|
if (doclet.kind === 'member' &&
|
|
props && props.length === 1 &&
|
|
props[0].name === doclet.name)
|
|
{
|
|
// "Duplicate"
|
|
var prop = props[0];
|
|
|
|
if (!doclet.type)
|
|
{
|
|
doclet.type = prop.type;
|
|
}
|
|
|
|
if (!doclet.description)
|
|
{
|
|
doclet.description = prop.description;
|
|
}
|
|
else if (prop.description &&
|
|
!looksLikeItMightContain(doclet.description, prop.description))
|
|
{
|
|
// Tack it on..
|
|
doclet.description += " " + prop.description;
|
|
}
|
|
|
|
// And no more prop
|
|
e.doclet.properties = undefined;
|
|
}
|
|
|
|
};
|