mirror of
https://github.com/jsdoc/jsdoc.git
synced 2025-12-08 19:46:11 +00:00
add '@callback' tag (#260)
This commit is contained in:
parent
4da46d6a48
commit
9e5a47f195
@ -625,12 +625,22 @@ exports.defineTags = function(dictionary) {
|
||||
if (tag.value.name) {
|
||||
doclet.addTag('name', tag.value.name);
|
||||
}
|
||||
if (tag.value.type) {
|
||||
|
||||
// callbacks are always type {function}
|
||||
if (tag.originalTitle === 'callback') {
|
||||
doclet.type = {
|
||||
names: [
|
||||
'function'
|
||||
]
|
||||
};
|
||||
}
|
||||
else if (tag.value.type) {
|
||||
doclet.type = tag.value.type;
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
})
|
||||
.synonym('callback');
|
||||
|
||||
dictionary.defineTag('undocumented', {
|
||||
mustNotHaveValue: true,
|
||||
|
||||
21
test/fixtures/callbacktag.js
vendored
Normal file
21
test/fixtures/callbacktag.js
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
/**
|
||||
* @param {requestResponseCallback} cb
|
||||
*/
|
||||
function makeSpecialRequest(cb) {
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {wrongTypeCallback} cb
|
||||
*/
|
||||
function makeExtraSpecialRequest(cb) {
|
||||
}
|
||||
|
||||
/**
|
||||
* @callback requestResponseCallback
|
||||
* @param {number} responseCode
|
||||
* @param {string} responseText
|
||||
*/
|
||||
|
||||
/**
|
||||
* @callback {(object|string)} wrongTypeCallback
|
||||
*/
|
||||
27
test/specs/documentation/callback.js
Normal file
27
test/specs/documentation/callback.js
Normal file
@ -0,0 +1,27 @@
|
||||
/*global describe: true, expect: true, it: true, jasmine: true */
|
||||
describe('callback tag', function() {
|
||||
var docSet = jasmine.getDocSetFromFile('test/fixtures/callbacktag.js');
|
||||
|
||||
function callbackTests(callback) {
|
||||
expect(callback).toBeDefined();
|
||||
|
||||
expect(callback.type).toBeDefined();
|
||||
expect(typeof callback.type).toEqual('object');
|
||||
|
||||
expect(callback.type.names).toBeDefined();
|
||||
expect(callback.type.names instanceof Array).toEqual(true);
|
||||
expect(callback.type.names.length).toEqual(1);
|
||||
|
||||
expect(callback.type.names[0]).toEqual('function');
|
||||
}
|
||||
|
||||
it('correctly handles callbacks that do not define a {type}', function() {
|
||||
var callback = docSet.getByLongname('requestResponseCallback')[0];
|
||||
callbackTests(callback);
|
||||
});
|
||||
|
||||
it('correctly handles callbacks that define an incorrect {type}', function() {
|
||||
var callback = docSet.getByLongname('wrongTypeCallback')[0];
|
||||
callbackTests(callback);
|
||||
});
|
||||
});
|
||||
Loading…
x
Reference in New Issue
Block a user