From b4f5153d18636a44ea0c648a1e59652da5061a28 Mon Sep 17 00:00:00 2001 From: Rich Trott Date: Sat, 24 Dec 2016 14:49:58 -0800 Subject: [PATCH] tools: refactor json.js * Simplify regular expressions (see below) * Remove unneeded `parseYAML()` wrapper * Remove unused callback argument Regular expression simplifications include: * Changing trailing `*?$/` to `*$/` because non-greedy matching to the end of a line will not change behavior * Change regexp beginnings eike `/^(?:property:?\s*)?[^.\[]+` to the equivalent `/[^.\]]+` * For regular expressions changed per the above, remove case-insensitivity if it no longer affects the regexp --- tools/doc/json.js | 22 ++++++++-------------- 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/tools/doc/json.js b/tools/doc/json.js index f8210ef17fda5c..3e329a965f068c 100644 --- a/tools/doc/json.js +++ b/tools/doc/json.js @@ -102,7 +102,7 @@ function doJSON(input, filename, cb) { current.list.push(tok); current.list.level = 1; } else if (type === 'html' && common.isYAMLBlock(tok.text)) { - current.meta = parseYAML(tok.text); + current.meta = common.extractAndParseYAML(tok.text); } else { current.desc = current.desc || []; if (!Array.isArray(current.desc)) { @@ -302,10 +302,6 @@ function processList(section) { delete section.list; } -function parseYAML(text) { - return common.extractAndParseYAML(text); -} - // textRaw = "someobject.someMethod(a[, b=100][, c])" function parseSignature(text, sig) { var params = text.match(paramExpr); @@ -314,7 +310,7 @@ function parseSignature(text, sig) { params = params.split(/,/); var optionalLevel = 0; var optionalCharDict = {'[': 1, ' ': 0, ']': -1}; - params.forEach(function(p, i, _) { + params.forEach(function(p, i) { p = p.trim(); if (!p) return; var param = sig.params[i]; @@ -544,14 +540,12 @@ function deepCopy_(src) { // these parse out the contents of an H# tag var eventExpr = /^Event(?::|\s)+['"]?([^"']+).*$/i; -var classExpr = /^Class:\s*([^ ]+).*?$/i; -var propExpr = /^(?:property:?\s*)?[^.]+\.([^ .()]+)\s*?$/i; -var braceExpr = /^(?:property:?\s*)?[^.\[]+(\[[^\]]+\])\s*?$/i; -var classMethExpr = - /^class\s*method\s*:?[^.]+\.([^ .()]+)\([^)]*\)\s*?$/i; -var methExpr = - /^(?:method:?\s*)?(?:[^.]+\.)?([^ .()]+)\([^)]*\)\s*?$/i; -var newExpr = /^new ([A-Z][a-zA-Z]+)\([^)]*\)\s*?$/; +var classExpr = /^Class:\s*([^ ]+).*$/i; +var propExpr = /^[^.]+\.([^ .()]+)\s*$/; +var braceExpr = /^[^.[]+(\[[^\]]+\])\s*$/; +var classMethExpr = /^class\s*method\s*:?[^.]+\.([^ .()]+)\([^)]*\)\s*$/i; +var methExpr = /^(?:[^.]+\.)?([^ .()]+)\([^)]*\)\s*$/; +var newExpr = /^new ([A-Z][a-zA-Z]+)\([^)]*\)\s*$/; var paramExpr = /\((.*)\);?$/; function newSection(tok) {