mirror of
https://github.com/tenrok/BBob.git
synced 2026-06-11 18:02:26 +03:00
da6709d437
* feat: use swc.rs instead of babel * BREAKING CHANGE: now we use swc.rs as main bundler and transpiler instead of babel - jest now uses swc - rollup now uses swc * feat: benchmark now separate package with `npm start` and colored output - benchmark as separate package with error throw if package drops performance * feat: all lerna packages now using scripts/pkg-task * feat(github): publish to npm and github registry - when release was created this action automaticly publish packages to npm and github * feat(github): move all from Travis CI to Github Actions - code analysis and tests now using github actions * test: increase tests coverage - add more tests for @bbob/react, @bbob/vue2 and @bbob/parser
61 lines
1.4 KiB
JavaScript
61 lines
1.4 KiB
JavaScript
/* eslint-disable no-plusplus */
|
|
const isObj = (value) => (typeof value === 'object');
|
|
const isBool = (value) => (typeof value === 'boolean');
|
|
|
|
export function iterate(t, cb) {
|
|
const tree = t;
|
|
|
|
if (Array.isArray(tree)) {
|
|
for (let idx = 0; idx < tree.length; idx++) {
|
|
tree[idx] = iterate(cb(tree[idx]), cb);
|
|
}
|
|
} else if (tree && isObj(tree) && tree.content) {
|
|
iterate(tree.content, cb);
|
|
}
|
|
|
|
return tree;
|
|
}
|
|
|
|
export function same(expected, actual) {
|
|
if (typeof expected !== typeof actual) {
|
|
return false;
|
|
}
|
|
|
|
if (!isObj(expected) || expected === null) {
|
|
return expected === actual;
|
|
}
|
|
|
|
if (Array.isArray(expected)) {
|
|
return expected.every((exp) => [].some.call(actual, (act) => same(exp, act)));
|
|
}
|
|
|
|
return Object.keys(expected).every((key) => {
|
|
const ao = actual[key];
|
|
const eo = expected[key];
|
|
|
|
if (isObj(eo) && eo !== null && ao !== null) {
|
|
return same(eo, ao);
|
|
}
|
|
|
|
if (isBool(eo)) {
|
|
return eo !== (ao === null);
|
|
}
|
|
|
|
return ao === eo;
|
|
});
|
|
}
|
|
|
|
export function match(expression, cb) {
|
|
return Array.isArray(expression)
|
|
? iterate(this, (node) => {
|
|
for (let idx = 0; idx < expression.length; idx++) {
|
|
if (same(expression[idx], node)) {
|
|
return cb(node);
|
|
}
|
|
}
|
|
|
|
return node;
|
|
})
|
|
: iterate(this, (node) => (same(expression, node) ? cb(node) : node));
|
|
}
|