diff options
| author | Guillaume Gomez <guillaume1.gomez@gmail.com> | 2021-08-12 13:25:08 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-08-12 13:25:08 +0200 |
| commit | faf7fb94f9cb7c66ecbc5e922726cabd3016da2d (patch) | |
| tree | d9ff7f4bf2d42280cd28a391bf1a2973824205d2 | |
| parent | 3d733f6785efbda9fa6196c4077df5b31273f1b9 (diff) | |
| parent | cc319f88a7481e951064f87114584d7daebb0d5f (diff) | |
| download | rust-faf7fb94f9cb7c66ecbc5e922726cabd3016da2d.tar.gz rust-faf7fb94f9cb7c66ecbc5e922726cabd3016da2d.zip | |
Rollup merge of #87941 - GuillaumeGomez:fix-rustdoc-js-tool, r=notriddle
Fix/improve rustdoc-js tool This tool is run when testing `src/test/rustdoc-js*`. r? `@notriddle`
| -rw-r--r-- | src/tools/rustdoc-js/tester.js | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/src/tools/rustdoc-js/tester.js b/src/tools/rustdoc-js/tester.js index 86b16f8b0e6..bb9cd00f3f5 100644 --- a/src/tools/rustdoc-js/tester.js +++ b/src/tools/rustdoc-js/tester.js @@ -20,15 +20,17 @@ function getNextStep(content, pos, stop) { // will blow up. Template strings are not tested and might also be // broken. function extractFunction(content, functionName) { - var indent = 0; + var level = 0; var splitter = "function " + functionName + "("; + var stop; + var pos, start; while (true) { - var start = content.indexOf(splitter); + start = content.indexOf(splitter); if (start === -1) { break; } - var pos = start; + pos = start; while (pos < content.length && content[pos] !== ')') { pos += 1; } @@ -44,30 +46,33 @@ function extractFunction(content, functionName) { } while (pos < content.length) { // Eat single-line comments - if (content[pos] === '/' && pos > 0 && content[pos-1] === '/') { + if (content[pos] === '/' && pos > 0 && content[pos - 1] === '/') { do { pos += 1; } while (pos < content.length && content[pos] !== '\n'); + // Eat multiline comment. + } else if (content[pos] === '*' && pos > 0 && content[pos - 1] === '/') { + do { + pos += 1; + } while (pos < content.length && content[pos] !== '/' && content[pos - 1] !== '*'); + // Eat quoted strings } else if (content[pos] === '"' || content[pos] === "'" || content[pos] === "`") { - var stop = content[pos]; - var is_escaped = false; + stop = content[pos]; do { if (content[pos] === '\\') { - pos += 2; - } else { pos += 1; } - } while (pos < content.length && - (content[pos] !== stop || content[pos - 1] === '\\')); + pos += 1; + } while (pos < content.length && content[pos] !== stop); - // Otherwise, check for indent + // Otherwise, check for block level. } else if (content[pos] === '{') { - indent += 1; + level += 1; } else if (content[pos] === '}') { - indent -= 1; - if (indent === 0) { + level -= 1; + if (level === 0) { return content.slice(start, pos + 1); } } |
