summaryrefslogtreecommitdiff
path: root/src/compiler/utils/nodes_match.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/compiler/utils/nodes_match.ts')
-rw-r--r--src/compiler/utils/nodes_match.ts44
1 files changed, 22 insertions, 22 deletions
diff --git a/src/compiler/utils/nodes_match.ts b/src/compiler/utils/nodes_match.ts
index 9c8e1fb48..563742635 100644
--- a/src/compiler/utils/nodes_match.ts
+++ b/src/compiler/utils/nodes_match.ts
@@ -1,34 +1,34 @@
// @ts-nocheck
export function nodes_match(a, b) {
- if (!!a !== !!b) return false;
- if (Array.isArray(a) !== Array.isArray(b)) return false;
+ if (!!a !== !!b) return false;
+ if (Array.isArray(a) !== Array.isArray(b)) return false;
- if (a && typeof a === 'object') {
- if (Array.isArray(a)) {
- if (a.length !== b.length) return false;
- return a.every((child, i) => nodes_match(child, b[i]));
- }
+ if (a && typeof a === 'object') {
+ if (Array.isArray(a)) {
+ if (a.length !== b.length) return false;
+ return a.every((child, i) => nodes_match(child, b[i]));
+ }
- const a_keys = Object.keys(a).sort();
- const b_keys = Object.keys(b).sort();
+ const a_keys = Object.keys(a).sort();
+ const b_keys = Object.keys(b).sort();
- if (a_keys.length !== b_keys.length) return false;
+ if (a_keys.length !== b_keys.length) return false;
- let i = a_keys.length;
- while (i--) {
- const key = a_keys[i];
- if (b_keys[i] !== key) return false;
+ let i = a_keys.length;
+ while (i--) {
+ const key = a_keys[i];
+ if (b_keys[i] !== key) return false;
- if (key === 'start' || key === 'end') continue;
+ if (key === 'start' || key === 'end') continue;
- if (!nodes_match(a[key], b[key])) {
- return false;
- }
- }
+ if (!nodes_match(a[key], b[key])) {
+ return false;
+ }
+ }
- return true;
- }
+ return true;
+ }
- return a === b;
+ return a === b;
}