mirror of
https://github.com/jsdoc/jsdoc.git
synced 2025-12-08 19:46:11 +00:00
support the modifies tag (JSDoc and Closure Compiler) (#605)
This commit is contained in:
parent
b56162489d
commit
2f99af8fbb
@ -436,6 +436,12 @@ var DOCLET_SCHEMA = exports.DOCLET_SCHEMA = {
|
|||||||
type: STRING
|
type: STRING
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
modifies: {
|
||||||
|
type: ARRAY,
|
||||||
|
optional: true,
|
||||||
|
uniqueItems: true,
|
||||||
|
items: PARAM_SCHEMA
|
||||||
|
},
|
||||||
// probably a trailing substring of the path
|
// probably a trailing substring of the path
|
||||||
name: {
|
name: {
|
||||||
type: STRING
|
type: STRING
|
||||||
|
|||||||
@ -605,6 +605,13 @@ var baseTags = exports.baseTags = {
|
|||||||
setDocletNameToValue(doclet, tag);
|
setDocletNameToValue(doclet, tag);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
modifies: {
|
||||||
|
canHaveType: true,
|
||||||
|
onTagged: function(doclet, tag) {
|
||||||
|
doclet.modifies = doclet.modifies || [];
|
||||||
|
doclet.modifies.push(tag.value);
|
||||||
|
}
|
||||||
|
},
|
||||||
module: {
|
module: {
|
||||||
canHaveType: true,
|
canHaveType: true,
|
||||||
isNamespace: true,
|
isNamespace: true,
|
||||||
@ -910,6 +917,7 @@ exports.closureTags = {
|
|||||||
}),
|
}),
|
||||||
lends: cloneTagDef(baseTags.lends),
|
lends: cloneTagDef(baseTags.lends),
|
||||||
license: cloneTagDef(baseTags.license),
|
license: cloneTagDef(baseTags.license),
|
||||||
|
modifies: cloneTagDef(baseTags.modifies),
|
||||||
// Closure Compiler only
|
// Closure Compiler only
|
||||||
noalias: {
|
noalias: {
|
||||||
onTagged: ignore
|
onTagged: ignore
|
||||||
|
|||||||
@ -77,6 +77,18 @@ var self = this;
|
|||||||
<?js }); ?></ul>
|
<?js }); ?></ul>
|
||||||
<?js } ?>
|
<?js } ?>
|
||||||
|
|
||||||
|
<?js if (data.modifies && modifies.length) {?>
|
||||||
|
<h5>Modifies:</h5>
|
||||||
|
<?js if (modifies.length > 1) { ?><ul><?js
|
||||||
|
modifies.forEach(function(m) { ?>
|
||||||
|
<li><?js= self.partial('modifies.tmpl', m) ?></li>
|
||||||
|
<?js });
|
||||||
|
?></ul><?js } else {
|
||||||
|
modifies.forEach(function(m) { ?>
|
||||||
|
<?js= self.partial('modifies.tmpl', m) ?>
|
||||||
|
<?js });
|
||||||
|
} } ?>
|
||||||
|
|
||||||
<?js if (data.exceptions && exceptions.length) { ?>
|
<?js if (data.exceptions && exceptions.length) { ?>
|
||||||
<h5>Throws:</h5>
|
<h5>Throws:</h5>
|
||||||
<?js if (exceptions.length > 1) { ?><ul><?js
|
<?js if (exceptions.length > 1) { ?><ul><?js
|
||||||
|
|||||||
14
templates/default/tmpl/modifies.tmpl
Normal file
14
templates/default/tmpl/modifies.tmpl
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
<?js
|
||||||
|
var data = obj || {};
|
||||||
|
?>
|
||||||
|
|
||||||
|
<?js if (data.type && data.type.names) {?>
|
||||||
|
<dl>
|
||||||
|
<dt>
|
||||||
|
Type
|
||||||
|
</dt>
|
||||||
|
<dd>
|
||||||
|
<?js= this.partial('type.tmpl', data.type.names) ?>
|
||||||
|
</dd>
|
||||||
|
</dl>
|
||||||
|
<?js } ?>
|
||||||
5
test/fixtures/modifiestag.js
vendored
Normal file
5
test/fixtures/modifiestag.js
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
/**
|
||||||
|
* My mutator function.
|
||||||
|
* @modifies {(foo|bar)}
|
||||||
|
*/
|
||||||
|
function mutator(foo, bar) {}
|
||||||
15
test/specs/tags/modifiestag.js
Normal file
15
test/specs/tags/modifiestag.js
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
describe('@modifies tag', function() {
|
||||||
|
var docSet = jasmine.getDocSetFromFile('test/fixtures/modifiestag.js');
|
||||||
|
var mutator = docSet.getByLongname('mutator')[0];
|
||||||
|
|
||||||
|
it('should add the specified types to the doclet\'s `modifies` property', function() {
|
||||||
|
expect(mutator.modifies.length).toBe(1);
|
||||||
|
expect(mutator.modifies[0].type).toBeDefined();
|
||||||
|
expect(mutator.modifies[0].type.names).toBeDefined();
|
||||||
|
expect(mutator.modifies[0].type.names.length).toBe(2);
|
||||||
|
expect(mutator.modifies[0].type.names[0]).toBe('foo');
|
||||||
|
expect(mutator.modifies[0].type.names[1]).toBe('bar');
|
||||||
|
});
|
||||||
|
});
|
||||||
Loading…
x
Reference in New Issue
Block a user