diff options
author | Michaël Zasso <targos@protonmail.com> | 2017-12-22 16:53:42 +0100 |
---|---|---|
committer | Michaël Zasso <targos@protonmail.com> | 2018-01-11 09:48:05 +0100 |
commit | 3dc30632755713179f345f4af024bd904c6162d0 (patch) | |
tree | f28c4f6dd6dfc5992edf301449d1a371d229755b /tools/node_modules/eslint/node_modules/unist-util-is/index.js | |
parent | a2c7085dd4a8e60d1a47572aca8bb6fcb7a32f88 (diff) | |
download | android-node-v8-3dc30632755713179f345f4af024bd904c6162d0.tar.gz android-node-v8-3dc30632755713179f345f4af024bd904c6162d0.tar.bz2 android-node-v8-3dc30632755713179f345f4af024bd904c6162d0.zip |
tools: move eslint from tools to tools/node_modules
This is required because we need to add the babel-eslint dependency
and it has to be able to resolve "eslint".
babel-eslint is required to support future ES features such as async
iterators and import.meta.
Refs: https://github.com/nodejs/node/pull/17755
PR-URL: https://github.com/nodejs/node/pull/17820
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
Diffstat (limited to 'tools/node_modules/eslint/node_modules/unist-util-is/index.js')
-rw-r--r-- | tools/node_modules/eslint/node_modules/unist-util-is/index.js | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/tools/node_modules/eslint/node_modules/unist-util-is/index.js b/tools/node_modules/eslint/node_modules/unist-util-is/index.js new file mode 100644 index 0000000000..290259a798 --- /dev/null +++ b/tools/node_modules/eslint/node_modules/unist-util-is/index.js @@ -0,0 +1,119 @@ +'use strict'; + +/* eslint-disable max-params */ + +/* Expose. */ +module.exports = is; + +/* Assert if `test` passes for `node`. + * When a `parent` node is known the `index` of node */ +function is(test, node, index, parent, context) { + var hasParent = parent !== null && parent !== undefined; + var hasIndex = index !== null && index !== undefined; + var check = convert(test); + + if ( + hasIndex && + (typeof index !== 'number' || index < 0 || index === Infinity) + ) { + throw new Error('Expected positive finite index or child node'); + } + + if (hasParent && (!is(null, parent) || !parent.children)) { + throw new Error('Expected parent node'); + } + + if (!node || !node.type || typeof node.type !== 'string') { + return false; + } + + if (hasParent !== hasIndex) { + throw new Error('Expected both parent and index'); + } + + return Boolean(check.call(context, node, index, parent)); +} + +function convert(test) { + if (typeof test === 'string') { + return typeFactory(test); + } + + if (test === null || test === undefined) { + return ok; + } + + if (typeof test === 'object') { + return ('length' in test ? anyFactory : matchesFactory)(test); + } + + if (typeof test === 'function') { + return test; + } + + throw new Error('Expected function, string, or object as test'); +} + +function convertAll(tests) { + var results = []; + var length = tests.length; + var index = -1; + + while (++index < length) { + results[index] = convert(tests[index]); + } + + return results; +} + +/* Utility assert each property in `test` is represented + * in `node`, and each values are strictly equal. */ +function matchesFactory(test) { + return matches; + + function matches(node) { + var key; + + for (key in test) { + if (node[key] !== test[key]) { + return false; + } + } + + return true; + } +} + +function anyFactory(tests) { + var checks = convertAll(tests); + var length = checks.length; + + return matches; + + function matches() { + var index = -1; + + while (++index < length) { + if (checks[index].apply(this, arguments)) { + return true; + } + } + + return false; + } +} + +/* Utility to convert a string into a function which checks + * a given node’s type for said string. */ +function typeFactory(test) { + return type; + + function type(node) { + return Boolean(node && node.type === test); + } +} + +/* Utility to return true. */ +function ok() { + return true; +} |