UNPKG

firedoc

Version:

API Doc generator rewritten from [YUIDoc](https://github.com/yui/yuidoc). We use this tool to document a large JavaScript game engine [Fireball](http://github.com/fireball-x/fireball) at [docs-zh.fireball-x.com/api](http://docs-zh.fireball-x.com/api/) and

649 lines (647 loc) 21 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for lib/firedoc.js</title> <meta charset="utf-8"> <link rel="stylesheet" href="../prettify.css"> <link rel="stylesheet" href="../base.css"> <style type='text/css'> div.coverage-summary .sorter { background-image: url(../sort-arrow-sprite.png); } </style> </head> <body> <div class="header low"> <h1>Code coverage report for <span class="entity">lib/firedoc.js</span></h1> <h2> Statements: <span class="metric">46.48% <small>(33 / 71)</small></span> &nbsp;&nbsp;&nbsp;&nbsp; Branches: <span class="metric">36.11% <small>(13 / 36)</small></span> &nbsp;&nbsp;&nbsp;&nbsp; Functions: <span class="metric">12.5% <small>(1 / 8)</small></span> &nbsp;&nbsp;&nbsp;&nbsp; Lines: <span class="metric">47.06% <small>(32 / 68)</small></span> &nbsp;&nbsp;&nbsp;&nbsp; Ignored: <span class="metric"><span class="ignore-none">none</span></span> &nbsp;&nbsp;&nbsp;&nbsp; </h2> <div class="path"><a href="../index.html">All files</a> &#187; <a href="index.html">lib/</a> &#187; firedoc.js</div> </div> <div class="body"> <pre><table class="coverage"> <tr><td class="line-count">1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202</td><td class="line-coverage"><span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">4</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">&nbsp; /** * This is the __module__ description for the `YUIDoc` module. * ``` * var options = { * paths: [ './lib' ], * outdir: './out' * }; * ``` * * @module firedoc * @submodule helpers * @submodule utils * @main firedoc */ &nbsp; const _ = require('underscore'); const path = require('path'); const fs = require('graceful-fs'); const readdirp = require('readdirp'); const debug = require('debug')('firedoc'); &nbsp; /** * Firedoc main class * * @class Firedoc * @constructor * @param config The config object */ function Firedoc (config) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!(this instanceof Firedoc)) { <span class="cstat-no" title="statement not covered" > return new Firedoc(config);</span> } &nbsp; /** * Holds the number of files that we are processing. * @property filecount * @type Boolean * @private */ this.filecount = 0; /** * Holder for the list of files we are processing. * @property filemap * @type Object * @private */ this.filemap = {}; /** * Holder for the list of directories we are processing. * @property dirmap * @type Object * @private */ this.dirmap = {}; &nbsp; /** * Internal holder for configuration options. * @property options * @type Object * @private */ this.options = { writeJSON: true, extensions: '.js', excludes: [ '.git', '.svn', 'CVS', 'build_rollup_tmp', 'build_tmp', 'node_modules' ], norecurse: false, path: './', cwd: process.cwd(), http: false, dest: path.join(process.cwd(), 'out'), theme: path.join(__dirname, '../themes/default'), syntaxtype: 'js' }; &nbsp; // setup options var cwd = config.cwd || this.options.cwd; <span class="missing-if-branch" title="else path not taken" >E</span>if (fs.existsSync(cwd + '/package.json')) { var pkg = require(cwd + '/package.json'); &nbsp; // load firedoc options var firedocOption = pkg.firedoc; delete pkg.firedoc; &nbsp; //compatible with firedoc.options <span class="missing-if-branch" title="if path not taken" >I</span>if (pkg.yuidoc &amp;&amp; <span class="branch-1 cbranch-no" title="branch not covered" >pkg.yuidoc.options)</span> { <span class="cstat-no" title="statement not covered" > firedocOption = pkg.yuidoc.options;</span> <span class="cstat-no" title="statement not covered" > delete pkg.yuidoc;</span> } this.options.project = pkg; this.options = _.extend(this.options, firedocOption); &nbsp; // compatible with the old options this.options.dest = this.options.outdir; this.options.path = this.options.paths &amp;&amp; <span class="branch-1 cbranch-no" title="branch not covered" >this.options.paths[0];</span> &nbsp; // extend by NODE_ENV var envOption = pkg['firedoc.' + process.env.NODE_ENV]; if (envOption) { this.options = _.extend(this.options, envOption); } } else { <span class="cstat-no" title="statement not covered" > this.options.path = config.path || this.options.path;</span> } &nbsp; // setup options from config for (var key in config) { <span class="missing-if-branch" title="else path not taken" >E</span>if (!_.isUndefined(config[key])) this.options[key] = config[key]; } &nbsp; // if `markdown` enabled, set theme <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.markdown === true) { <span class="cstat-no" title="statement not covered" > this.options.theme = path.join(__dirname, '../themes/markdown');</span> } <span class="missing-if-branch" title="if path not taken" >I</span>if (!path.isAbsolute(this.options.path)) { <span class="cstat-no" title="statement not covered" > this.options.path = path.join(process.cwd(), this.options.path);</span> } <span class="missing-if-branch" title="else path not taken" >E</span>if (!path.isAbsolute(this.options.dest)) { this.options.dest = path.join(process.cwd(), this.options.dest); } }; exports.Firedoc = Firedoc; &nbsp; Firedoc.prototype = { &nbsp; /** * Walks the paths and parses the directory contents * * @method walk * @private */ walk: <span class="fstat-no" title="function not covered" >function (callback) {</span> <span class="cstat-no" title="statement not covered" > var self = this;</span> <span class="cstat-no" title="statement not covered" > readdirp(</span> { root: this.options.path, fileFilter: '*.@(js|rs|ts|coffee)', directoryFilter: self.options.excludes.map( <span class="fstat-no" title="function not covered" > function (ex) {</span> <span class="cstat-no" title="statement not covered" > return '!' + ex;</span> } ) } ).on('data', <span class="fstat-no" title="function not covered" >function (entry) {</span> <span class="cstat-no" title="statement not covered" > var text = fs.readFileSync(entry.fullPath, 'utf8');</span> <span class="cstat-no" title="statement not covered" > self.filecount += 1;</span> <span class="cstat-no" title="statement not covered" > self.filemap[entry.fullPath] = text.replace(/\r?\n|\r/g, '\n');</span> <span class="cstat-no" title="statement not covered" > self.dirmap[entry.fullPath] = entry.fullParentDir;</span> }).on('end', callback); }, &nbsp; lint: <span class="fstat-no" title="function not covered" >function (warnings) {</span> <span class="cstat-no" title="statement not covered" > var code = 0, count = 0;</span> <span class="cstat-no" title="statement not covered" > if (warnings &amp;&amp; warnings.length) {</span> <span class="cstat-no" title="statement not covered" > code = 1;</span> <span class="cstat-no" title="statement not covered" > console.log('YUIDoc found', warnings.length, 'lint errors in your docs');</span> <span class="cstat-no" title="statement not covered" > warnings.forEach(<span class="fstat-no" title="function not covered" >function (item) {</span></span> <span class="cstat-no" title="statement not covered" > count++;</span> <span class="cstat-no" title="statement not covered" > console.log('#' + count, item.message, item.line + '\n');</span> }); } }, &nbsp; /** * Process the config, walk the file tree and write out the JSON data. * @method build * @param {Function} callback */ build: <span class="fstat-no" title="function not covered" >function (callback) {</span> <span class="cstat-no" title="statement not covered" > debug('Starting from: ' + this.options.path);</span> <span class="cstat-no" title="statement not covered" > var self = this;</span> <span class="cstat-no" title="statement not covered" > this.walk(<span class="fstat-no" title="function not covered" >function () {</span></span> <span class="cstat-no" title="statement not covered" > var parser = require('./docparser');</span> <span class="cstat-no" title="statement not covered" > var builder = require('./builder');</span> <span class="cstat-no" title="statement not covered" > var ast = parser.parse(</span> self.options.syntaxtype, self.filemap, self.dirmap); &nbsp; <span class="cstat-no" title="statement not covered" > debug('Parsing completed');</span> <span class="cstat-no" title="statement not covered" > if (self.options.lint) {</span> <span class="cstat-no" title="statement not covered" > debug('lint the warnings from ast');</span> <span class="cstat-no" title="statement not covered" > self.lint(ast.warnings);</span> <span class="cstat-no" title="statement not covered" > if (_.isFunction(callback)) <span class="cstat-no" title="statement not covered" >return callback(ast.warnings);</span></span> } <span class="cstat-no" title="statement not covered" > if (self.options.parseOnly) {</span> <span class="cstat-no" title="statement not covered" > debug('skip the build because parse only');</span> <span class="cstat-no" title="statement not covered" > if (_.isFunction(callback)) <span class="cstat-no" title="statement not covered" >callback(null, ast, self.options);</span></span> <span class="cstat-no" title="statement not covered" > return;</span> } <span class="cstat-no" title="statement not covered" > builder.compile(ast, self.options, callback);</span> }); } }; &nbsp;</pre></td></tr> </table></pre> </div> <div class="footer"> <div class="meta">Generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Thu Jul 02 2015 15:00:46 GMT+0800 (CST)</div> </div> <script src="../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../sorter.js"></script> </body> </html>