UNPKG

astx

Version:

super powerful structural search and replace for JavaScript and TypeScript to automate your refactoring

349 lines (308 loc) 35.7 kB
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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"}