documentation/lib/filter_access.js
Tom MacWright 25152edeb9 style(prettier): Use prettier for code formatting (#710)
* style(prettier): Use prettier for code formatting

This saves us style issues. Also adds husky and lint-staged for pre-commit testing

Refs https://github.com/documentationjs/documentation/issues/709
2017-04-10 14:25:45 -04:00

36 lines
971 B
JavaScript

'use strict';
/* @flow */
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 /*: Array<string>*/,
comments /*: Array<Comment>*/
) {
levels = levels || ['public', 'undefined', 'protected'];
function filter(comment) {
return comment.kind === 'note' ||
(!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;