astx
Version:
super powerful structural search and replace for JavaScript and TypeScript to automate your refactoring
349 lines (308 loc) • 35.7 kB
JavaScript
import CompilePathError from '../util/CompilePathError.mjs'
import compileMatcher, { mergeCaptures } from './index.mjs'
import indentDebug from './indentDebug.mjs'
const defaultUnorderedFields = {}
for (const [type, field] of [
['ClassBody', 'body'],
['ClassDeclaration', 'implements'],
['DeclareClass', 'implements'],
['DeclareExportDeclaration', 'specifiers'],
['DeclareInterface', 'extends'],
['EnumDeclaration', 'body'],
['ExportNamedDeclaration', 'specifiers'],
['ImportDeclaration', 'specifiers'],
['InterfaceDeclaration', 'extends'],
['IntersectionTypeAnnotation', 'types'],
['JSXOpeningElement', 'attributes'],
['ObjectExpression', 'properties'],
['ObjectPattern', 'properties'],
['ObjectTypeAnnotation', 'properties'],
['TSEnumDeclaration', 'members'],
['TSInterfaceBody', 'body'],
['TSInterfaceDeclaration', 'extends'],
['TSIntersectionType', 'types'],
['TSTypeLiteral', 'members'],
['TSUnionType', 'types'],
['UnionTypeAnnotation', 'types'],
]) {
const forType =
defaultUnorderedFields[type] || (defaultUnorderedFields[type] = {})
forType[field] = true
}
function getDefaultUnordered(path) {
var _defaultUnorderedFiel
if (Array.isArray(path)) {
var _path$
const parent =
(_path$ = path[0]) === null || _path$ === void 0
? void 0
: _path$.parentPath
if (!parent) return false
return getDefaultUnordered(parent)
}
if (!path.node || !path.name) return false
return Boolean(
(_defaultUnorderedFiel = defaultUnorderedFields[path.node.type]) === null ||
_defaultUnorderedFiel === void 0
? void 0
: _defaultUnorderedFiel[path.name]
)
}
export default function compileGenericArrayMatcher(
path,
compileOptions,
{
compileElemMatcher = compileMatcher,
defaultUnordered = getDefaultUnordered(path),
skipElement = () => false,
} = {}
) {
const paths = Array.isArray(path) ? path : path.filter(() => true)
const pattern = path.map((p) => p.node)
const { debug } = compileOptions
const elemOptions = { ...compileOptions, debug: indentDebug(debug, 2) }
let matchers = pattern.map((value, i) =>
compileElemMatcher(paths[i], elemOptions)
)
assertArrayMatchersValid(matchers)
const unordered =
matchers.some((m) => m.restPlaceholder || m.placeholder === '$Unordered') ||
(defaultUnordered &&
!matchers.some((m) => m.placeholder === '$Ordered' || m.arrayPlaceholder))
matchers = matchers.filter(
(m) => m.placeholder !== '$Ordered' && m.placeholder !== '$Unordered'
)
if (unordered) {
return compileUnorderedArrayMatcher(paths, compileOptions, {
matchers,
})
}
if (matchers.some((m) => m.placeholder || m.arrayPlaceholder)) {
return compileOrderedArrayMatcher(paths, compileOptions, {
matchers,
skipElement,
})
}
return compileExactArrayMatcher(paths, compileOptions, {
matchers,
skipElement,
})
}
function assertArrayMatchersValid(matchers) {
const otherMatchers = []
let arrayMatcherCount = 0
let restMatcher
for (let i = 0; i < matchers.length; i++) {
if (matchers[i].restPlaceholder) {
if (restMatcher) {
throw new CompilePathError(
`can't have two or more rest matchers as siblings`,
matchers[i].pattern
)
} else if (arrayMatcherCount) {
throw new CompilePathError(
`can't mix array and rest matchers`,
matchers[i].pattern
)
} else {
restMatcher = matchers[i]
}
} else if (matchers[i].arrayPlaceholder) {
if (restMatcher) {
throw new CompilePathError(
`can't mix array and rest matchers`,
matchers[i].pattern
)
}
arrayMatcherCount++
} else {
otherMatchers.push(matchers[i])
}
}
}
function compileOrderedArrayMatcher(
paths,
compileOptions,
{ matchers, skipElement = () => false }
) {
const { debug } = compileOptions
function remainingElements(matcherIndex) {
let count = 0
for (let i = matcherIndex; i < matchers.length; i++) {
if (!matchers[i].arrayPlaceholder) count++
}
return count
}
function matchElem(paths, sliceStart, arrayIndex, matcherIndex, matchSoFar) {
while (arrayIndex < paths.length && skipElement(paths[arrayIndex]))
arrayIndex++
if (arrayIndex === paths.length) {
return remainingElements(matcherIndex) === 0 ? matchSoFar || {} : null
}
if (matcherIndex === matchers.length) return null
const matcher = matchers[matcherIndex]
const { arrayPlaceholder } = matcher
if (arrayPlaceholder) {
if (matcherIndex === matchers.length - 1) {
return mergeCaptures(matchSoFar, {
arrayCaptures: {
[arrayPlaceholder]: paths.slice(sliceStart),
},
})
}
return matchElem(
paths,
sliceStart,
arrayIndex,
matcherIndex + 1,
matchSoFar
)
} else {
var _matchers
const origMatchSoFar = matchSoFar
const prevArrayPlaceholder =
(_matchers = matchers[matcherIndex - 1]) === null ||
_matchers === void 0
? void 0
: _matchers.arrayPlaceholder
const end = prevArrayPlaceholder
? paths.length - remainingElements(matcherIndex + 1)
: arrayIndex + 1
for (let i = arrayIndex; i < end; i++) {
const elemPath = paths[i]
if (skipElement(elemPath)) continue
matchSoFar = matcher.match(elemPath, origMatchSoFar)
if (!matchSoFar) continue
if (prevArrayPlaceholder) {
matchSoFar = mergeCaptures(matchSoFar, {
arrayCaptures: {
[prevArrayPlaceholder]: paths.slice(sliceStart, i),
},
})
}
const restMatch = matchElem(
paths,
i + 1,
i + 1,
matcherIndex + 1,
matchSoFar
)
if (restMatch) return restMatch
}
}
return null
}
return {
pattern: paths,
match: (path, matchSoFar) => {
debug('Array (ordered)')
if (!Array.isArray(path.value)) return null
const paths = path.filter(() => true)
let result = matchElem(paths, 0, 0, 0, matchSoFar)
if (!result) return result // make sure all * captures are present in results
// (if there are more than one adjacent *, all captured paths will be in the
// last one and the rest will be empty)
for (const matcher of matchers) {
var _result, _result$arrayCaptures
const { arrayPlaceholder } = matcher
if (!arrayPlaceholder) continue
if (
!(
(_result = result) !== null &&
_result !== void 0 &&
(_result$arrayCaptures = _result.arrayCaptures) !== null &&
_result$arrayCaptures !== void 0 &&
_result$arrayCaptures[arrayPlaceholder]
)
)
result = mergeCaptures(result, {
arrayCaptures: {
[arrayPlaceholder]: [],
},
})
}
return result
},
}
}
function compileUnorderedArrayMatcher(
paths,
compileOptions,
{ matchers, skipElement = () => false }
) {
const { debug } = compileOptions
const restMatcher = matchers.find((m) => m.restPlaceholder)
matchers = matchers.filter((m) => !m.restPlaceholder)
const restPlaceholder =
restMatcher === null || restMatcher === void 0
? void 0
: restMatcher.restPlaceholder
return {
pattern: paths,
match: (path, result) => {
debug('Array (unordered)')
if (!Array.isArray(path.value)) return null
const paths = path.filter(() => true)
for (const m of matchers) {
let i
let found = false
for (i = 0; i < paths.length; i++) {
if (skipElement(paths[i])) {
i++
continue
}
const match = m.match(paths[i], result)
if (!match) continue
result = match
paths.splice(i, 1)
found = true
break
}
if (!found) {
return null
}
}
if (restPlaceholder) {
return mergeCaptures(result, {
arrayCaptures: {
[restPlaceholder]: paths,
},
})
} else {
if (paths.length) {
return null
}
return result || {}
}
},
}
}
function compileExactArrayMatcher(
paths,
compileOptions,
{ matchers, skipElement = () => false }
) {
const { debug } = compileOptions
return {
pattern: paths,
match: (path, matchSoFar) => {
debug('Array (exact)')
if (!Array.isArray(path.value)) return null
const paths = path.filter((p) => !skipElement(p))
let m = 0,
i = 0
while (i < paths.length || m < matchers.length) {
debug(' [%d]', i)
if (i >= paths.length || m >= matchers.length) {
debug(' length mismatch')
return null
}
matchSoFar = matchers[m].match(paths[i], matchSoFar)
if (!matchSoFar) return null
m++
i++
}
return matchSoFar || {}
},
}
} //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CompilePathError","compileMatcher","mergeCaptures","indentDebug","defaultUnorderedFields","type","field","forType","getDefaultUnordered","path","Array","isArray","parent","parentPath","node","name","Boolean","compileGenericArrayMatcher","compileOptions","compileElemMatcher","defaultUnordered","skipElement","paths","filter","pattern","map","p","debug","elemOptions","matchers","value","i","assertArrayMatchersValid","unordered","some","m","restPlaceholder","placeholder","arrayPlaceholder","compileUnorderedArrayMatcher","compileOrderedArrayMatcher","compileExactArrayMatcher","otherMatchers","arrayMatcherCount","restMatcher","length","push","remainingElements","matcherIndex","count","matchElem","sliceStart","arrayIndex","matchSoFar","matcher","arrayCaptures","slice","origMatchSoFar","prevArrayPlaceholder","end","elemPath","match","restMatch","result","find","found","splice"],"sources":["../../src/compileMatcher/GenericArrayMatcher.ts"],"sourcesContent":["import { NodePath, Node } from '../types'\nimport CompilePathError from '../util/CompilePathError'\nimport compileMatcher, {\n  CompiledMatcher,\n  CompileOptions,\n  MatchResult,\n  mergeCaptures,\n} from '.'\nimport indentDebug from './indentDebug'\n\nconst defaultUnorderedFields: { [k in string]?: { [k in string]?: true } } = {}\nfor (const [type, field] of [\n  ['ClassBody', 'body'],\n  ['ClassDeclaration', 'implements'],\n  ['DeclareClass', 'implements'],\n  ['DeclareExportDeclaration', 'specifiers'],\n  ['DeclareInterface', 'extends'],\n  ['EnumDeclaration', 'body'],\n  ['ExportNamedDeclaration', 'specifiers'],\n  ['ImportDeclaration', 'specifiers'],\n  ['InterfaceDeclaration', 'extends'],\n  ['IntersectionTypeAnnotation', 'types'],\n  ['JSXOpeningElement', 'attributes'],\n  ['ObjectExpression', 'properties'],\n  ['ObjectPattern', 'properties'],\n  ['ObjectTypeAnnotation', 'properties'],\n  ['TSEnumDeclaration', 'members'],\n  ['TSInterfaceBody', 'body'],\n  ['TSInterfaceDeclaration', 'extends'],\n  ['TSIntersectionType', 'types'],\n  ['TSTypeLiteral', 'members'],\n  ['TSUnionType', 'types'],\n  ['UnionTypeAnnotation', 'types'],\n]) {\n  const forType =\n    defaultUnorderedFields[type] || (defaultUnorderedFields[type] = {})\n  forType[field] = true\n}\n\nfunction getDefaultUnordered(\n  path: NodePath<Node, Node[]> | NodePath<Node, Node>[]\n): boolean {\n  if (Array.isArray(path)) {\n    const parent = path[0]?.parentPath\n    if (!parent) return false\n    return getDefaultUnordered(parent)\n  }\n  if (!path.node || !path.name) return false\n  return Boolean(defaultUnorderedFields[path.node.type]?.[path.name])\n}\n\nexport default function compileGenericArrayMatcher(\n  path: NodePath<Node, Node[]> | NodePath<Node, Node>[],\n  compileOptions: CompileOptions,\n  {\n    compileElemMatcher = compileMatcher,\n    defaultUnordered = getDefaultUnordered(path),\n    skipElement = () => false,\n  }: {\n    compileElemMatcher?: (\n      path: NodePath,\n      options: CompileOptions\n    ) => CompiledMatcher\n    defaultUnordered?: boolean\n    skipElement?: (path: NodePath) => boolean\n  } = {}\n): CompiledMatcher {\n  const paths = Array.isArray(path) ? path : path.filter(() => true)\n  const pattern: Node[] = path.map((p: NodePath) => p.node)\n  const { debug } = compileOptions\n  const elemOptions = {\n    ...compileOptions,\n    debug: indentDebug(debug, 2),\n  }\n  let matchers: CompiledMatcher[] = pattern.map((value, i) =>\n    compileElemMatcher(paths[i], elemOptions)\n  )\n\n  assertArrayMatchersValid(matchers)\n\n  const unordered =\n    matchers.some((m) => m.restPlaceholder || m.placeholder === '$Unordered') ||\n    (defaultUnordered &&\n      !matchers.some((m) => m.placeholder === '$Ordered' || m.arrayPlaceholder))\n\n  matchers = matchers.filter(\n    (m) => m.placeholder !== '$Ordered' && m.placeholder !== '$Unordered'\n  )\n\n  if (unordered) {\n    return compileUnorderedArrayMatcher(paths, compileOptions, {\n      matchers,\n    })\n  }\n\n  if (matchers.some((m) => m.placeholder || m.arrayPlaceholder)) {\n    return compileOrderedArrayMatcher(paths, compileOptions, {\n      matchers,\n      skipElement,\n    })\n  }\n\n  return compileExactArrayMatcher(paths, compileOptions, {\n    matchers,\n    skipElement,\n  })\n}\n\nfunction assertArrayMatchersValid(matchers: CompiledMatcher[]) {\n  const otherMatchers: CompiledMatcher[] = []\n  let arrayMatcherCount = 0\n  let restMatcher\n  for (let i = 0; i < matchers.length; i++) {\n    if (matchers[i].restPlaceholder) {\n      if (restMatcher) {\n        throw new CompilePathError(\n          `can't have two or more rest matchers as siblings`,\n          matchers[i].pattern as NodePath\n        )\n      } else if (arrayMatcherCount) {\n        throw new CompilePathError(\n          `can't mix array and rest matchers`,\n          matchers[i].pattern as NodePath\n        )\n      } else {\n        restMatcher = matchers[i]\n      }\n    } else if (matchers[i].arrayPlaceholder) {\n      if (restMatcher) {\n        throw new CompilePathError(\n          `can't mix array and rest matchers`,\n          matchers[i].pattern as NodePath\n        )\n      }\n      arrayMatcherCount++\n    } else {\n      otherMatchers.push(matchers[i])\n    }\n  }\n}\n\nfunction compileOrderedArrayMatcher(\n  paths: NodePath<Node, Node>[],\n  compileOptions: CompileOptions,\n  {\n    matchers,\n    skipElement = () => false,\n  }: {\n    matchers: CompiledMatcher[]\n    skipElement?: (path: NodePath) => boolean\n  }\n): CompiledMatcher {\n  const { debug } = compileOptions\n\n  function remainingElements(matcherIndex: number): number {\n    let count = 0\n    for (let i = matcherIndex; i < matchers.length; i++) {\n      if (!matchers[i].arrayPlaceholder) count++\n    }\n    return count\n  }\n\n  function matchElem(\n    paths: NodePath[],\n    sliceStart: number,\n    arrayIndex: number,\n    matcherIndex: number,\n    matchSoFar: MatchResult\n  ): MatchResult {\n    while (arrayIndex < paths.length && skipElement(paths[arrayIndex]))\n      arrayIndex++\n\n    if (arrayIndex === paths.length) {\n      return remainingElements(matcherIndex) === 0 ? matchSoFar || {} : null\n    }\n\n    if (matcherIndex === matchers.length) return null\n\n    const matcher = matchers[matcherIndex]\n\n    const { arrayPlaceholder } = matcher\n\n    if (arrayPlaceholder) {\n      if (matcherIndex === matchers.length - 1) {\n        return mergeCaptures(matchSoFar, {\n          arrayCaptures: {\n            [arrayPlaceholder]: paths.slice(sliceStart),\n          },\n        })\n      }\n\n      return matchElem(\n        paths,\n        sliceStart,\n        arrayIndex,\n        matcherIndex + 1,\n        matchSoFar\n      )\n    } else {\n      const origMatchSoFar = matchSoFar\n      const prevArrayPlaceholder = matchers[matcherIndex - 1]?.arrayPlaceholder\n      const end = prevArrayPlaceholder\n        ? paths.length - remainingElements(matcherIndex + 1)\n        : arrayIndex + 1\n\n      for (let i = arrayIndex; i < end; i++) {\n        const elemPath = paths[i]\n\n        if (skipElement(elemPath)) continue\n\n        matchSoFar = matcher.match(elemPath, origMatchSoFar)\n\n        if (!matchSoFar) continue\n\n        if (prevArrayPlaceholder) {\n          matchSoFar = mergeCaptures(matchSoFar, {\n            arrayCaptures: {\n              [prevArrayPlaceholder]: paths.slice(sliceStart, i),\n            },\n          })\n        }\n\n        const restMatch = matchElem(\n          paths,\n          i + 1,\n          i + 1,\n          matcherIndex + 1,\n          matchSoFar\n        )\n\n        if (restMatch) return restMatch\n      }\n    }\n\n    return null\n  }\n\n  return {\n    pattern: paths,\n    match: (path: NodePath, matchSoFar: MatchResult): MatchResult => {\n      debug('Array (ordered)')\n\n      if (!Array.isArray(path.value)) return null\n      const paths = (path as NodePath<Node, Node[]>).filter(() => true)\n\n      let result = matchElem(paths, 0, 0, 0, matchSoFar)\n      if (!result) return result\n\n      // make sure all * captures are present in results\n      // (if there are more than one adjacent *, all captured paths will be in the\n      // last one and the rest will be empty)\n      for (const matcher of matchers) {\n        const { arrayPlaceholder } = matcher\n        if (!arrayPlaceholder) continue\n        if (!result?.arrayCaptures?.[arrayPlaceholder])\n          result = mergeCaptures(result, {\n            arrayCaptures: { [arrayPlaceholder]: [] },\n          })\n      }\n      return result\n    },\n  }\n}\n\nfunction compileUnorderedArrayMatcher(\n  paths: NodePath<Node, Node>[],\n  compileOptions: CompileOptions,\n  {\n    matchers,\n    skipElement = () => false,\n  }: {\n    matchers: CompiledMatcher[]\n    skipElement?: (path: NodePath) => boolean\n  }\n): CompiledMatcher {\n  const { debug } = compileOptions\n\n  const restMatcher = matchers.find((m) => m.restPlaceholder)\n  matchers = matchers.filter((m) => !m.restPlaceholder)\n  const restPlaceholder = restMatcher?.restPlaceholder\n\n  return {\n    pattern: paths,\n    match: (path: NodePath, result: MatchResult): MatchResult => {\n      debug('Array (unordered)')\n\n      if (!Array.isArray(path.value)) return null\n\n      const paths = (path as NodePath<Node, Node[]>).filter(() => true)\n\n      for (const m of matchers) {\n        let i\n        let found = false\n        for (i = 0; i < paths.length; i++) {\n          if (skipElement(paths[i])) {\n            i++\n            continue\n          }\n          const match = m.match(paths[i], result)\n          if (!match) continue\n          result = match\n          paths.splice(i, 1)\n          found = true\n          break\n        }\n        if (!found) {\n          return null\n        }\n      }\n      if (restPlaceholder) {\n        return mergeCaptures(result, {\n          arrayCaptures: { [restPlaceholder]: paths },\n        })\n      } else {\n        if (paths.length) {\n          return null\n        }\n        return result || {}\n      }\n    },\n  }\n}\n\nfunction compileExactArrayMatcher(\n  paths: NodePath<Node, Node>[],\n  compileOptions: CompileOptions,\n  {\n    matchers,\n    skipElement = () => false,\n  }: {\n    matchers: CompiledMatcher[]\n    skipElement?: (path: NodePath) => boolean\n  }\n): CompiledMatcher {\n  const { debug } = compileOptions\n  return {\n    pattern: paths,\n    match: (path: NodePath, matchSoFar: MatchResult): MatchResult => {\n      debug('Array (exact)')\n\n      if (!Array.isArray(path.value)) return null\n\n      const paths = path.filter((p) => !skipElement(p))\n\n      let m = 0,\n        i = 0\n      while (i < paths.length || m < matchers.length) {\n        debug('  [%d]', i)\n        if (i >= paths.length || m >= matchers.length) {\n          debug('    length mismatch')\n          return null\n        }\n        matchSoFar = matchers[m].match(paths[i], matchSoFar)\n        if (!matchSoFar) return null\n        m++\n        i++\n      }\n      return matchSoFar || {}\n    },\n  }\n}\n"],"mappings":"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"}