71 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
var _ = require('lodash');
 | 
						|
 | 
						|
module.exports = function processClassDocs(log, getJSDocComment) {
 | 
						|
 | 
						|
  return {
 | 
						|
    $runAfter: ['processModuleDocs'],
 | 
						|
    $runBefore: ['parsing-tags', 'generateDocsFromComments'],
 | 
						|
    ignorePrivateMembers: false,
 | 
						|
    $process: function(docs) {
 | 
						|
      var memberDocs = [];
 | 
						|
      var ignorePrivateMembers = this.ignorePrivateMembers;
 | 
						|
      _.forEach(docs, function(classDoc) {
 | 
						|
        if ( classDoc.docType === 'class' ) {
 | 
						|
 | 
						|
          classDoc.members = [];
 | 
						|
 | 
						|
          // Create a new doc for each member of the class
 | 
						|
          _.forEach(classDoc.elements, function(memberDoc) {
 | 
						|
 | 
						|
            var memberName = memberDoc.name.location.toString();
 | 
						|
 | 
						|
            if (ignorePrivateMembers && memberName.charAt(0) === '_') return;
 | 
						|
 | 
						|
            memberDocs.push(memberDoc);
 | 
						|
 | 
						|
            memberDoc.docType = 'member';
 | 
						|
            memberDoc.classDoc = classDoc;
 | 
						|
            memberDoc.name = memberName;
 | 
						|
            if (memberDoc.parameterList) {
 | 
						|
              memberDoc.params = memberDoc.parameterList.parameters.map(function(param) {
 | 
						|
                return param.location.toString();
 | 
						|
              });
 | 
						|
            }
 | 
						|
 | 
						|
            if (memberDoc.commentBefore ) {
 | 
						|
              // If this export has a comment, remove it from the list of
 | 
						|
              // comments collected in the module
 | 
						|
              var index = classDoc.moduleDoc.comments.indexOf(memberDoc.commentBefore);
 | 
						|
              if ( index !== -1 ) {
 | 
						|
                classDoc.moduleDoc.comments.splice(index, 1);
 | 
						|
              }
 | 
						|
 | 
						|
              _.assign(memberDoc, getJSDocComment(memberDoc.commentBefore));
 | 
						|
            }
 | 
						|
 | 
						|
            // Constuctor is a special case member
 | 
						|
            if (memberName === 'constructor') {
 | 
						|
              classDoc.constructorDoc = memberDoc;
 | 
						|
            } else {
 | 
						|
              insertSorted(classDoc.members, memberDoc, 'name');
 | 
						|
            }
 | 
						|
 | 
						|
          });
 | 
						|
        }
 | 
						|
      });
 | 
						|
 | 
						|
      return docs.concat(memberDocs);
 | 
						|
    }
 | 
						|
  };
 | 
						|
};
 | 
						|
 | 
						|
 | 
						|
function insertSorted(collection, item, property) {
 | 
						|
  var index = collection.length;
 | 
						|
  while(index>0) {
 | 
						|
    if(collection[index-1][property] < item[property]) break;
 | 
						|
    index -= 1;
 | 
						|
  }
 | 
						|
  collection.splice(index, 0, item);
 | 
						|
}
 |