UNPKG

htmlcs

Version:

html hint tool, focused on semantic code style.

492 lines (491 loc) 13.6 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for htmlcs/lib/htmlcs.js</title> <meta charset="utf-8" /> <link rel="stylesheet" href="../../prettify.css" /> <link rel="stylesheet" href="../../base.css" /> <meta name="viewport" content="width=device-width, initial-scale=1"> <style type='text/css'> .coverage-summary .sorter { background-image: url(../../sort-arrow-sprite.png); } </style> </head> <body> <div class='wrapper'> <div class='pad1'> <h1> <a href="../../index.html">all files</a> / <a href="index.html">htmlcs/lib/</a> htmlcs.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>40/40</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>6/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>6/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>40/40</span> </div> </div> </div> <div class='status-line high'></div> <pre><table class="coverage"> <tr><td class="line-count quiet">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</td><td class="line-coverage quiet"><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"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></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"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-yes"></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">103×</span> <span class="cline-any cline-yes">103×</span> <span class="cline-any cline-yes">251×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">103×</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"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes">39×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">39×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">39×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">39×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">39×</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">39×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">39×</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"></span> <span class="cline-any cline-yes">37×</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"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></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></td><td class="text"><pre class="prettyprint lang-js">/** * @file htmlcs methods * @author nighca&lt;nighca@live.cn&gt; */ &nbsp; var htmlGenner = require('html-code-gen'); &nbsp; var util = require('./util'); var parse = require('./parse'); var rules = require('./rules'); var Reporter = require('./reporter'); var otherFormatters = require('./other-formatter'); &nbsp; /** * The report item. * * @typedef {Object} Report * @property {string} type - typeof the message, one of "info", "warn", "error" * @property {number} line - line number of the report * @property {number} column - column number of the report * @property {string} code - code of the report * @property {string} message - message of the report * @property {string} rule - name of the report's rule */ &nbsp; /** * Do hint with given code &amp; config. * * @param {string} code - given code * @param {Object} cfg - given config * @return {Report[]} the hint result, list of reports */ var hint = function (code, cfg) { // get rid of \r code = code.replace(/\r\n?/g, '\n'); &nbsp; cfg = cfg || {}; &nbsp; // max error num var maxError = cfg['max-error']; delete cfg['max-error']; &nbsp; // get reporter var reporter = new Reporter(); &nbsp; // get parser var parser = parse.getParser(); &nbsp; // collect inline configs var inlineCfg = rules.collectInlineCfg(parser); &nbsp; // configure reporter with inline reporter-config ( enable / disable ) reporter.config(inlineCfg.reporter); &nbsp; // lint parser rules.lintParser(parser, reporter, cfg, inlineCfg.rules, code); &nbsp; // parse &amp; lint document var document = parse(code, parser); rules.lintDocument(document, reporter, cfg, inlineCfg.rules, code); &nbsp; // get result var result = reporter.result(); // num control if (maxError) { result = result.slice(0, maxError); } &nbsp; // do position ( pos -&gt; line &amp; column ) var position = util.getPosition(code); result.forEach(function (item) { util.extend(item, position(item.pos)); }); &nbsp; return result; }; &nbsp; /** * Do hint with given code &amp; config. * * @param {string} code - given code * @param {Object} cfg - given config * @return {Promise&lt;Report[]&gt;} the hint result, list of reports */ var hintAsync = function (code, cfg) { return Promise.resolve(hint(code, cfg)); }; &nbsp; var formatWithGivenPrint = function (code, cfg, print) { cfg = cfg || {}; &nbsp; // get parser var parser = parse.getParser(); &nbsp; // collect inline configs var inlineCfg = rules.collectInlineCfg(parser); &nbsp; // parse document var document = parse(code, parser); &nbsp; // format options var options = util.extend({ 'indent-size': 4, 'indent-char': 'space', 'max-char': 120, 'formatter': otherFormatters }, cfg.format); &nbsp; rules.format(document, cfg, inlineCfg.rules, options); &nbsp; return print(document, options); }; &nbsp; /** * Do format with given code &amp; config. * * @param {string} code - given code * @param {Object} cfg - given config * @return {string} the formatted code */ var format = function (code, cfg) { return formatWithGivenPrint(code, cfg, htmlGenner.print); }; &nbsp; /** * Do async format with given code &amp; config. * * @param {string} code - given code * @param {Object} cfg - given config * @return {Promise&lt;string&gt;} the formatted code */ var formatAsync = function (code, cfg) { return formatWithGivenPrint(code, cfg, htmlGenner.printAsync); }; &nbsp; module.exports = { addRule: rules.add.bind(rules), hint: hint, hintAsync: hintAsync, format: format, formatAsync: formatAsync }; &nbsp;</pre></td></tr> </table></pre> <div class='push'></div><!-- for sticky footer --> </div><!-- /wrapper --> <div class='footer quiet pad2 space-top1 center small'> Code coverage generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Wed May 10 2017 15:40:38 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>