documentation/lib/filter_access.js
2016-03-14 18:26:07 -07:00

31 lines
877 B
JavaScript

'use strict';
var walk = require('./walk');
/**
* Exclude given access levels from the generated documentation: this allows
* users to write documentation for non-public members by using the
* `@private` tag.
*
* @param {Array<string>} [levels=['public', 'undefined', 'protected']] included access levels.
* @param {Array<Object>} comments parsed comments (can be nested)
* @return {Array<Object>} filtered comments
*/
function filterAccess(levels, comments) {
levels = levels || ['public', 'undefined', 'protected'];
function filter(comment) {
return !comment.ignore && levels.indexOf(String(comment.access)) !== -1;
}
function recurse(comment) {
for (var scope in comment.members) {
comment.members[scope] = comment.members[scope].filter(filter);
}
}
return walk(comments.filter(filter), recurse);
}
module.exports = filterAccess;