{"version":3,"sources":["https://lively-kernel.org/lively4/lively4-petrinet/src/components/widgets/ast-capabilities.js"],"names":["loc","range","FileIndex","babelDefault","babel","t","types","template","ASTCapabilities","constructor","codeProvider","codeChanged","selectionRanges","selections","length","firstSelection","map","_getFirstSelectionOrCursorPosition","anchor","cursor","head","programPath","myProgramPath","parsingFailed","programPathFor","sourceCode","code","traverseAsAST","Program","path","err","undefined","rootNode","parent","finishedEnrichment","memberAssignments","Map","aexprs","canParse","nextPath","startingPath","isValid","pathToShow","traverse","enter","stop","getLastPath","nextPathCallback","getFirstChildOrSelf","child","getPathBeforeCursor","selectionStart","foundPath","exit","pathLocation","node","pathEnd","end","isBefore","getInnermostPathContainingSelection","selection","nextPathContainingCursor","newStartingPath","containsRange","prevPath","getSelectedPaths","pathContainingWholeSelection","isPathExactlySelected","selectedPaths","containsPartsOfRange","push","skip","flat","getSelectedStatements","getOutermostPathContainingSelectionWithMinimalSelectionRange","isStatement","isBlockStatement","Statement","getSelectedExpressions","isExpression","isIdentifier","Expression","currentPath","findParent","isEqual","forwardList","parentPath","linearizedPathList","backwardList","reverse","selectNextASTNodeWith","condition","reversed","pathList","maxPaths","getNextASTNodeInListWith","selectPaths","getFirstSelectedIdentifier","startPath","first","Identifier","getFirstSelectedIdentifierWithName","name","getAllIdentifiers","identifiers","getDeclaration","identifier","scope","hasBinding","getBinding","getBindingDeclarationIdentifierPath","binding","getBindingsInFile","astBindings","getASTBinding","getClassBindings","identifierPaths","Set","referencePaths","constantViolations","cv","includes","isMemberExpression","isThisExpression","object","classPath","getClassPath","methodPath","getMethodPath","getClassMethodBindings","getMemberBindings","isClassMethod","classMethod","methodIdentifier","getUnbound","members","getAllUnboundIdentifierNames","unboundIdentifiers","filter","value","index","self","indexOf","conditionFunc","currentPathInList","find","pathInList","currentIndex","i","selectNodes","nodes","selectStringContentsOnly","ranges","selectedRange","start","_cmCharacter","paths","ClassMethod","key","FunctionDeclaration","id","ClassDeclaration","getColorLiterals","pPath","colorPaths","colorRegex","StringLiteral","match","expandSelection","strictlyContainsRange","reduceSelection","selectNextASTChild","currentNode","nextNode","isLiteral","isSuper","isDebuggerStatement","selectNextASTNodeLikeThis","type","selectNextReference","selectedPath","bindings","sortedBindings","sort","a","b","selectDeclaration","identName","declaration","isImportSpecifier","classUrls","getCorrespondingClasses","then","arr","cl","url","functionUrls","getFunctionExportURLs","urls","concat","forEach","lively","openBrowser","container","asyncGet","livelyEditor","newCodeMirror","livelyCodeMirror","cm","awaitEditor","astCapabilities","ac","rename","bindingItems","getPossibleBindingsAcrossFiles","comp","openComponentInWindow","focus","setAdditionalInput","setTitle","references","selectItems","newName","getAdditionalInput","camelCase","reference","fetch","r","text","codeLines","split","String","prototype","replaceBetween","what","substring","line","ch","newCode","join","files","saveFile","reloadModule","System","import","selectBindings","printAllBindings","openReferencesMenu","current","ids","db","file","some","toArray","program","column","lastIndexOf","identifierName","findImports","functions","classes","isInDescribe","possiblePath","isIn","callee","isDirectlyIn","Array","elem","reduce","accu","updateColor","currentLocation","color","location","scrollInfo","transformAsAST","visitor","isStringLiteral","scrollTo","openHTMLAccessorsMenu","initialSelectionState","getExistingAccessors","classMethodIdentifier","ExportDefaultDeclaration","body","generateHTMLAccessors","compileListOfIDs","existingMethods","generateMethodNameFromProperty","selectedItems","warn","item","generateCodeFragment","compileHTMLGetter","htmlURI","html","fetchText","tmp","innerHTML","childNodes","content","querySelectorAll","ea","htmlLines","idsWithLocation","indexOfId","generateTestCase","compileTestCase","generateGetter","compileGetter","generateSetter","compileSetter","generateClass","compileClass","replacementGenerator","identifierObject","generatedCode","pathBefore","pathWithin","unshiftContainer","insertAfter","pathToSelect","explanation","EXP","stringLiteral","propertyName","blockStatement","returnStatement","memberExpression","thisExpression","expressionStatement","assignmentExpression","className","classDeclaration","classBody","property","methodName","callExpression","addImport","importName","isFunction","existingImportStatement","isImportDeclaration","source","importStatement","importDeclaration","importSpecifier","unshift","specifiers","spec","imported","replaceWith","findParameters","surroundingMethod","actualSelections","needsToBeParameter","bindingPath","isSelected","shouldBeAsync","hasAwait","isAwaitExpression","AwaitExpression","couldBeStatic","hasThis","ThisExpression","findReturnValues","declarationInSelection","constantViolationInSelection","constantViolation","referenceOutsideSelection","needsToBeReturned","constantViolationOutsideSelection","declaredInExtractedCode","createMethod","parameter","returnValues","extractingExpression","shouldBeStatic","returnValue","returnIdentifier","objectExpression","objectProperty","methodContent","p","newMethod","async","static","remove","methodCall","awaitExpression","variableType","variableDeclaration","variableDeclarator","objectPattern","replaceWithMultiple","extractMethod","transformed","extraction","selectMethodExtraction","parameters","pathsToSelect","silent","expressions","extractExpressionIntoLocalVariable","done","pathLocationToBeExtracted","res","isSelectedPath","getPathLocation","ensureBlock","statements","blockNode","isArrowFunctionExpression","Error","targetLocation","blockLocation","parentKey","isFor","isWhile","becameABlock","replace","isIfStatement","pathLocationsToSelect","resultExtracted","pathByLocationFromProgram","generateUidIdentifier","decl","ID","INIT","referree","insertedDeclaration","getStatementParent","insertBefore","insertedDeclarationIdentifier","get","pathLocationsToPathes","inlineLocalVariable","foo","exitedEarly","kind","declarationIdentifierPath","isVariableDeclarator","isVariableDeclaration","initPath","o","wrapExpressionIntoActiveExpression","ae","EXPR","expression","pathRange","reg","result","exec","part","startsWith","parseInt","pathLocations","possibleClasses","methods","me","possibleExports","exports","where","anyOf","locations","e","eCl","lively4url","exp","getAexprAtCursor","aexprPath","CallExpression","contains","isAExpr","hasActiveExpressionsDirective","directives","ensureEnrichment","enrich","console","error","extra","visited","returnVisited","Scope","Object","entries","_name","extractMemberAssignments","enrichFunctionNodes","expr","collectExpressionInformation","MemberExpression","computed","isAssignmentExpression","assignment","assignedValue","obj","objKey","entry","newMap","set","objEntry","leakingBindings","callExpressions","objects","returns","objExpr","add","ReturnStatement","ret","has","call","results","resolvedObjects","isObjectExpression","isUpdateExpression","val","isConditionalExpression","isCallExpression","resolvedCallees","func","assignmentsOf","shadowedBindings","propertyEntry","memberDependencies","isObjectProperty","isObjectMethod","isFunctionDeclaration","isPattern","resolveDependencies","dependencies","_resolveDependencies","dep","size","member","getAllActiveExpressions","_collectAExprs","allAExpr","AEXPR_IDENTIFIER_NAME","ReferencedIdentifier","outerBinding","actualBinding"],"mappings":"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","file":"ast-capabilities.js","sourcesContent":["import { loc, range } from 'utils';\n\nimport FileIndex from \"src/client/fileindex.js\";\n\nimport babelDefault from 'systemjs-babel-build';\nconst babel = babelDefault.babel;\n\nconst t = babel.types;\nconst template = babel.template;\n\nexport default class ASTCapabilities {\n\n  constructor(codeProvider) {\n    this.codeProvider = codeProvider;\n    this.codeChanged();\n  }\n\n  get selectionRanges() {\n    if (this.codeProvider.selections.length == 0) {\n      return this.firstSelection;\n    }\n    return this.codeProvider.selections.map(range);\n  }\n\n  get firstSelection() {\n    return range(this._getFirstSelectionOrCursorPosition());\n  }\n\n  _getFirstSelectionOrCursorPosition() {\n    if (this.codeProvider.selections.length == 0) {\n      return { anchor: this.codeProvider.cursor, head: this.codeProvider.cursor };\n    }\n    return this.codeProvider.selections[0];\n  }\n\n  /*MD ## Navigation MD*/\n  /**\n   * Get the root path\n  */\n  get programPath() {\n    if (!this.myProgramPath && !this.parsingFailed) {\n      this.myProgramPath = this.programPathFor(this.sourceCode);\n      this.parsingFailed = !this.myProgramPath;\n    }\n    return this.myProgramPath;\n  }\n\n  programPathFor(code) {\n    var programPath = null;\n    try {\n      code.traverseAsAST({\n        Program(path) {\n          programPath = path;\n        }\n      });\n    } catch (err) {\n      return undefined;\n    }\n\n    return programPath;\n  }\n\n  get rootNode() {\n    return this.programPath && this.programPath.parent;\n  }\n\n  /**\n   * Invalidates old state on code change\n  */\n  codeChanged() {\n    this.myProgramPath = undefined;\n    this.parsingFailed = null;\n    this.finishedEnrichment = false;\n    this.memberAssignments = new Map();\n    this.aexprs = undefined;\n  }\n\n  get canParse() {\n    if (this.parsingFailed == null) this.programPath;\n    return !this.parsingFailed;\n  }\n\n  /** \n   * Return first child in depth first search that satisfies a condition\n   */\n  nextPath(startingPath, isValid) {\n    let pathToShow;\n\n    startingPath.traverse({\n      enter(path) {\n        if (!pathToShow && isValid(path)) {\n          pathToShow = path;\n          path.stop();\n        }\n      }\n    });\n\n    return pathToShow;\n  }\n\n  /**\n   * Return the last valid path that is generated by a given callback function on the previous path\n   */\n  getLastPath(startingPath, nextPathCallback) {\n    let pathToShow = startingPath;\n    while (true) {\n      let nextPath = nextPathCallback(pathToShow);\n      if (nextPath) {\n        pathToShow = nextPath;\n      } else {\n        break;\n      }\n    }\n\n    return pathToShow;\n  }\n\n  /**\n   * Returns the first child of a node or the node itself, if it has no children\n   */\n  getFirstChildOrSelf(startingPath) {\n    let child;\n    startingPath.traverse({\n      enter(path) {\n        if (!child) {\n          child = path;\n        }\n      }\n    });\n    return child || startingPath;\n  }\n\n  /**\n  * Returns the nearest path before the cursor location\n  */\n  getPathBeforeCursor(startingPath, anchor) {\n    const selectionStart = loc(anchor);\n    let foundPath;\n    startingPath.traverse({\n      exit(path) {\n        const pathLocation = path.node.loc;\n        const pathEnd = loc(pathLocation.end);\n        if (selectionStart.isBefore(pathEnd)) {\n          path.stop();\n          return;\n        }\n        foundPath = path;\n      }\n    });\n    return foundPath;\n  }\n\n  /**\n   * Returns the innermost node, that contains the selected text.\n   */\n  getInnermostPathContainingSelection(startingPath, selection) {\n    // go down to minimal selected node\n    const nextPathContainingCursor = (newStartingPath, selection) => {\n      return this.nextPath(newStartingPath, path => {\n        return range(path.node.loc).containsRange(selection);\n      });\n    };\n    return this.getLastPath(startingPath, prevPath => nextPathContainingCursor(prevPath, selection));\n  }\n\n  getSelectedPaths(programPath) {\n    return this.selectionRanges.map(selection => {\n      const pathContainingWholeSelection = this.getInnermostPathContainingSelection(programPath, selection);\n\n      //path already matches the selection\n      if (this.isPathExactlySelected(pathContainingWholeSelection, selection)) {\n        return pathContainingWholeSelection;\n      }\n\n      //find children that match the selection\n      let selectedPaths = [];\n      pathContainingWholeSelection.traverse({\n        enter(path) {\n          if (selection.containsPartsOfRange(range(path.node.loc))) {\n            selectedPaths.push(path);\n          }\n          path.skip();\n        }\n      });\n      return selectedPaths;\n    }).flat();\n  }\n\n  getSelectedStatements(programPath) {\n    return this.selectionRanges.map(selection => {\n      //Replace with get surrounding statement?\n      const pathContainingWholeSelection = this.getOutermostPathContainingSelectionWithMinimalSelectionRange(programPath, selection);\n\n      if (t.isStatement(pathContainingWholeSelection) && !t.isBlockStatement(pathContainingWholeSelection)) {\n        return pathContainingWholeSelection;\n      }\n\n      //find children that match the selection\n      let selectedPaths = [];\n      pathContainingWholeSelection.traverse({\n        Statement(path) {\n          if (selection.containsPartsOfRange(range(path.node.loc))) {\n            selectedPaths.push(path);\n          }\n          path.skip();\n        }\n      });\n      return selectedPaths;\n    }).flat();\n  }\n\n  getSelectedExpressions(programPath) {\n    return this.selectionRanges.map(selection => {\n      //Replace with get surrounding statement?\n      const pathContainingWholeSelection = this.getOutermostPathContainingSelectionWithMinimalSelectionRange(programPath, selection);\n\n      if (t.isExpression(pathContainingWholeSelection) && !t.isIdentifier(pathContainingWholeSelection)) {\n        return pathContainingWholeSelection;\n      }\n      //find children that match the selection\n      let selectedPaths = [];\n      pathContainingWholeSelection.traverse({\n        Expression(path) {\n          if (selection.containsPartsOfRange(range(path.node.loc)) && !t.isIdentifier(path)) {\n            selectedPaths.push(path);\n          }\n          path.skip();\n        }\n      });\n      return selectedPaths;\n    }).flat();\n  }\n\n  /** \n   * Takes the outermost node which corresponding selection range is minimal for containing the selected text.\n   * a      foo = bar\n   * --b    foo\n   *   --c  foo\n   * \n   * In this example, when 'foo' is selected, b will be returned, since it is the outermost node that contains the\n   * entire selection, but nothing more.\n   */\n  getOutermostPathContainingSelectionWithMinimalSelectionRange(startingPath, selection) {\n    var currentPath = this.getInnermostPathContainingSelection(startingPath, selection);\n    currentPath.findParent(path => {\n      if (selection.isEqual(range(path.node.loc))) {\n        currentPath = path;\n      }\n      return false;\n    });\n    return currentPath;\n  }\n\n  /**\n   * Array of all children in depth first search order\n   */\n  forwardList(parentPath) {\n    const linearizedPathList = [];\n    parentPath.traverse({\n      exit(path) {\n        linearizedPathList.push(path);\n      }\n    });\n    return linearizedPathList;\n  }\n\n  /**\n   * Array of all children in reversed depth first search order\n   */\n  backwardList(parentPath) {\n    const linearizedPathList = [];\n    parentPath.traverse({\n      enter(path) {\n        linearizedPathList.push(path);\n      }\n    });\n    return linearizedPathList.reverse();\n  }\n\n  /**\n   * select the selection range of the next ast node after the current selection that satisfies a given condition\n   * select previous selection instead of next, if reversed is set to true\n   */\n  selectNextASTNodeWith(condition, reversed) {\n    const programPath = this.programPath;\n    const pathList = reversed ? this.backwardList(programPath) : this.forwardList(programPath);\n\n    const maxPaths = this.selectionRanges.map(selection => {\n\n      const currentPath = this.getOutermostPathContainingSelectionWithMinimalSelectionRange(programPath, selection);\n\n      // do we fully select the current path?\n      if (selection.isEqual(range(currentPath.node.loc))) {\n        return this.getNextASTNodeInListWith(condition, pathList, currentPath);\n      } else {\n        return currentPath;\n      }\n    });\n\n    this.selectPaths(maxPaths);\n  }\n\n  getFirstSelectedIdentifier(startPath) {\n    if (t.isIdentifier(startPath.node)) {\n      return startPath;\n    }\n    var first;\n    startPath.traverse({\n      Identifier(path) {\n        if (!first) {\n          first = path;\n          path.stop();\n        }\n      }\n    });\n    return first;\n  }\n\n  getFirstSelectedIdentifierWithName(startPath, name) {\n    if (t.isIdentifier(startPath.node, { name: name })) {\n      return startPath;\n    }\n    var first;\n    startPath.traverse({\n      Identifier(path) {\n        if (!first && t.isIdentifier(path.node, { name: name })) {\n          first = path;\n          path.stop();\n        }\n      }\n    });\n    return first;\n  }\n\n  getAllIdentifiers(startPath) {\n    var identifiers = [];\n    startPath.traverse({\n      Identifier(path) {\n        identifiers.push(path);\n      }\n    });\n    return identifiers;\n  }\n\n  getDeclaration(identifier) {\n    if (identifier.scope.hasBinding(identifier.node.name)) {\n      return identifier.scope.getBinding(identifier.node.name).path;\n    }\n  }\n\n  getBindingDeclarationIdentifierPath(binding) {\n    return this.getFirstSelectedIdentifierWithName(binding.path, binding.identifier.name);\n  }\n\n  getBindingsInFile(startPath) {\n    var identifier = this.getFirstSelectedIdentifier(startPath);\n    if (!identifier) return [];\n    const astBindings = this.getASTBinding(identifier);\n\n    if (astBindings) {\n      return astBindings;\n    }\n\n    return this.getClassBindings(identifier);\n  }\n\n  /**\n   * Returns all bindings of a given identifier\n   */\n  getASTBinding(identifier) {\n    if (identifier.scope.hasBinding(identifier.node.name)) {\n      const binding = identifier.scope.getBinding(identifier.node.name);\n      const identifierPaths = [...new Set([this.getBindingDeclarationIdentifierPath(binding), ...binding.referencePaths, ...binding.constantViolations.map(cv => this.getFirstSelectedIdentifierWithName(cv, binding.identifier.name))])];\n      if (identifierPaths.includes(identifier)) {\n        return identifierPaths;\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Returns bindings of given identifier in its class\n   */\n  getClassBindings(identifier) {\n    if (t.isMemberExpression(identifier.parent)) {\n      if (t.isThisExpression(identifier.parent.object)) {\n        let classPath = this.getClassPath(this.programPath);\n        let methodPath = this.getMethodPath(classPath, identifier.node.name);\n        if (methodPath) {\n          return this.getClassMethodBindings(methodPath);\n        } else {\n          return this.getMemberBindings(identifier);\n        }\n      }\n    } else if (t.isClassMethod(identifier.parent)) {\n      return this.getClassMethodBindings(identifier.parentPath);\n    }\n  }\n\n  getClassMethodBindings(classMethod) {\n    var methodIdentifier;\n    classMethod.traverse({\n      Identifier(path) {\n        path.stop();\n        methodIdentifier = path;\n      }\n    });\n    return [methodIdentifier, ...this.getMemberBindings(methodIdentifier)];\n  }\n\n  /**\n   * if getUnbound is set to true, instead of getting all member Expressions with this (= that are bound) we only get those, that are unbound\n   */\n  getMemberBindings(identifier, getUnbound = false, startPath = this.programPath) {\n    var members = [];\n    startPath.traverse({\n      Identifier(path) {\n        if (t.isMemberExpression(path.parent) && path.node.name === identifier.node.name) {\n          if (getUnbound || t.isThisExpression(path.parent.object)) {\n            members.push(path);\n          }\n        }\n      }\n    });\n    return members;\n  }\n\n  getAllUnboundIdentifierNames(startPath = this.programPath) {\n    var unboundIdentifiers = [];\n    startPath.traverse({\n      Identifier(path) {\n        if (t.isMemberExpression(path.parent)) {\n          if (!t.isThisExpression(path.parent.object)) {\n            unboundIdentifiers.push(path);\n          }\n        }\n      }\n    });\n    return unboundIdentifiers.map(binding => binding.node.name).filter((value, index, self) => self.indexOf(value) === index);\n  }\n\n  getNextASTNodeInListWith(conditionFunc, pathList, path) {\n    const currentPathInList = pathList.find(pathInList => pathInList.node === path.node);\n    const currentIndex = pathList.indexOf(currentPathInList);\n    for (var i = currentIndex + 1; i < pathList.length; i++) {\n      if (conditionFunc(path, pathList[i])) {\n        return pathList[i];\n      }\n    }\n    return pathList[pathList.length - 1];\n  }\n\n  /** \n   * Select the text corresponding to the given nodes\n   */\n  selectNodes(nodes, selectStringContentsOnly = false) {\n    const ranges = nodes.map(node => {\n      let selectedRange = range(node.loc);\n      if (selectStringContentsOnly) {\n        //only select the contents, not the quotes around it \n        selectedRange.start._cmCharacter++;\n        selectedRange.end._cmCharacter--;\n      }\n      return selectedRange;\n    });\n    this.codeProvider.selections = ranges;\n  }\n\n  /** \n   * Select the text corresponding to the given paths\n   */\n  selectPaths(paths, selectStringContentsOnly = false) {\n    this.selectNodes(paths.map(path => path.node), selectStringContentsOnly);\n  }\n\n  /** \n   * Get the path for the first method with the given name\n   */\n  getMethodPath(programPath, name) {\n    let methodPath;\n    programPath.traverse({\n      ClassMethod(path) {\n        if (!methodPath && path.node.key.name == name) {\n          methodPath = path;\n        }\n      },\n      FunctionDeclaration(path) {\n        if (!methodPath && path.node.id.name == name) {\n          methodPath = path;\n        }\n      }\n    });\n    return methodPath;\n  }\n\n  /** \n   * Get the path of the first class\n   */\n  getClassPath(programPath) {\n    let classPath;\n    programPath.traverse({\n      ClassDeclaration(path) {\n        if (!classPath) {\n          classPath = path;\n        }\n      }\n    });\n    return classPath;\n  }\n\n  getColorLiterals() {\n    var pPath = this.programPath;\n    if (!pPath) return;\n    let colorPaths = [];\n    const colorRegex = /(0[xX]|#)[0-9a-fA-F]{6}$/g;\n    pPath.traverse({\n      StringLiteral(path) {\n        if (path.node.value.match(colorRegex)) {\n          colorPaths.push(path);\n        }\n      }\n    });\n    return colorPaths;\n  }\n\n  /*MD ### Shortcuts MD*/\n\n  expandSelection() {\n    const maxPaths = this.selectionRanges.map(selection => {\n      const pathToShow = this.getInnermostPathContainingSelection(this.programPath, selection);\n\n      // go up again\n      return pathToShow.find(path => {\n        return range(path.node.loc).strictlyContainsRange(selection);\n      }) || pathToShow;\n    });\n\n    this.selectPaths(maxPaths);\n  }\n\n  reduceSelection() {\n    const maxPaths = this.selectionRanges.map(selection => {\n      const pathToShow = this.getInnermostPathContainingSelection(this.programPath, selection);\n\n      return this.getFirstChildOrSelf(pathToShow);\n    });\n\n    this.selectPaths(maxPaths);\n  }\n\n  selectNextASTChild(reversed) {\n    return this.selectNextASTNodeWith((currentNode, nextNode) => {\n      return t.isIdentifier(nextNode) || t.isLiteral(nextNode) || t.isThisExpression(nextNode) || t.isSuper(nextNode) || t.isDebuggerStatement(nextNode);\n    }, reversed);\n  }\n\n  selectNextASTNodeLikeThis(reversed) {\n    return this.selectNextASTNodeWith((currentNode, nextNode) => currentNode.type == nextNode.type, reversed);\n  }\n\n  selectNextReference(reversed) {\n    const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n\n    const bindings = this.getBindingsInFile(selectedPath);if (bindings) {\n      let sortedBindings = [...bindings].sort((a, b) => a.node.start - b.node.start);\n      let index = sortedBindings.indexOf(selectedPath);\n      index += reversed ? -1 : 1;\n      index = (index + sortedBindings.length) % sortedBindings.length;\n      this.selectPaths([sortedBindings[index]]);\n    }\n  }\n\n  async selectDeclaration() {\n    const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n    const identifier = this.getFirstSelectedIdentifier(selectedPath);\n    if (!identifier) {\n      return;\n    }\n    const identName = identifier.node.name;\n\n    const declaration = await this.getDeclaration(identifier);\n    //needs smarter selection of source\n    if (declaration && !t.isImportSpecifier(declaration)) {\n      this.selectPaths([declaration]);\n    } else {\n      let classPath = this.getClassPath(this.programPath);\n      let methodPath = this.getMethodPath(classPath, identName);\n      if (methodPath) {\n        this.selectNodes([methodPath.node.key]);\n      } else {\n\n        // Find the declaration in other files and open the possible files in a new browser at the correct location\n        const classUrls = await this.getCorrespondingClasses(identName).then(arr => arr.map(cl => cl.url));\n        const functionUrls = await this.getFunctionExportURLs(identName);\n        const urls = classUrls.concat(functionUrls);\n\n        urls.forEach(url => lively.openBrowser(url, true).then(container => {\n          container.asyncGet(\"#editor\").then(async livelyEditor => {\n            let newCodeMirror = livelyEditor.livelyCodeMirror();\n            var cm = await livelyEditor.awaitEditor();\n            newCodeMirror.astCapabilities(cm).then(ac => {\n              ac.selectPaths([ac.getMethodPath(ac.programPath, identName)]);\n            });\n          });\n        }));\n      }\n    }\n    /**\n      TODO: if our dependencies don't have the method, we can search all classes    \n      Also: do not only search for methods, but for members too (even though they are technically not bindings?)\n    */\n  }\n\n  async rename() {\n    const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n\n    var identifier = this.getFirstSelectedIdentifier(selectedPath);\n    if (!identifier) return;\n    const astBindings = this.getASTBinding(identifier);\n\n    // If there is a binding in the current AST, all references get selected for renaming\n    if (astBindings) {\n      this.selectPaths(astBindings);\n      return;\n    }\n\n    /**\n     * If not: the user gets a list of all possible occurrences and can select entries for renaming and can choose the new name.\n     * Afterwards the selected occurrences in other files get refactored in the background.\n     */\n    const bindingItems = await this.getPossibleBindingsAcrossFiles(identifier);\n\n    let comp = await lively.openComponentInWindow(\"lively-code-occurence-selection\");\n    comp.focus();\n    comp.setAdditionalInput(\"Name\", \"enter new name\");\n    comp.setTitle(\"Rename \" + identifier.node.name);\n    const references = await comp.selectItems(bindingItems);\n\n    const newName = comp.getAdditionalInput().camelCase();\n    if (newName === \"\") return;\n\n    for (const reference of references) {\n      const code = await fetch(reference.url).then(r => r.text());\n\n      const codeLines = code.split(\"\\n\");\n\n      String.prototype.replaceBetween = function (start, end, what) {\n        return this.substring(0, start) + what + this.substring(end);\n      };\n      codeLines[reference.line] = codeLines[reference.line].replaceBetween(reference.ch, reference.ch + identifier.node.name.length, newName);\n\n      const newCode = codeLines.join(\"\\n\");\n      await lively.files.saveFile(reference.url, newCode);\n      await lively.reloadModule(reference.url);\n      await System.import(reference.url);\n    }\n  }\n\n  selectBindings() {\n    const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n\n    const bindings = this.getBindingsInFile(selectedPath);\n    if (bindings) {\n      this.selectPaths(bindings);\n    }\n  }\n\n  async printAllBindings() {\n    const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n\n    // const bindings = this.getBindings(selectedPath);\n    var identifier = this.getFirstSelectedIdentifier(selectedPath);\n\n    // find classes that contain the method\n    const bindingItems = await this.getPossibleBindingsAcrossFiles(identifier);\n\n    this.openReferencesMenu(bindingItems, identifier.node.name);\n  }\n\n  /**\n   * Uses the FileIndex to look for possible bindings in other files and returns an array containing elements with the name of found files, their urls and the line and column of the occurrence.\n   */\n  async getPossibleBindingsAcrossFiles(identifier) {\n    let index = await FileIndex.current();\n    let ids = await index.db.files.filter(file => {\n      if (!file.unboundIdentifiers) return false;\n      return file.unboundIdentifiers.some(id => id.name == identifier.name);\n    }).toArray();\n    const bindingItems = [];\n\n    for (const id of ids) {\n      const code = await fetch(id.url).then(r => r.text());\n      const program = this.programPathFor(code);\n      for (const reference of this.getMemberBindings(identifier, true, program)) {\n        const line = reference.node.loc.start.line - 1;\n        const ch = reference.node.loc.start.column;\n        bindingItems.push({ id: id.url.substring(id.url.lastIndexOf(\"/\") + 1) + \": \" + line, url: id.url, line, ch });\n      }\n    }\n\n    return bindingItems;\n  }\n\n  async openReferencesMenu(ids, identifierName) {\n    let comp = await lively.openComponentInWindow(\"lively-code-occurence-selection\");\n    comp.focus();\n    comp.setTitle(\"References of \" + identifierName);\n    return comp.selectItems(ids);\n  }\n\n  async findImports() {\n    let functions, classes, identName;\n    const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n    const identifier = this.getFirstSelectedIdentifier(selectedPath);\n    if (identifier) {\n      identName = identifier.node.name;\n      functions = await this.getFunctionExportURLs(identName);\n      classes = await this.getCorrespondingClasses(identName);\n    }\n    return { identName, functions, classes };\n  }\n  /*MD ## Factoring Menu MD*/\n\n  /*MD ### Factoring Menu Helper Methods MD*/\n\n  // returns innermostDescribePath \n  isInDescribe(path) {\n    let possiblePath = this.isIn(\"CallExpression\", path, \"describe\");\n\n    while (possiblePath !== null) {\n      if (possiblePath.node && possiblePath.node.callee.name === \"describe\") {\n        break;\n      }\n      possiblePath = this.isIn(\"CallExpression\", possiblePath.parentPath, \"describe\");\n    }\n    return possiblePath;\n  }\n\n  // returns a parentPath if path is somewhere in a path with a type stored in type\n  // or null if no type matches\n  // type can be a single type string or an array of type strings\n  isIn(type, path) {\n    while (path !== null) {\n      if (this.isDirectlyIn(type, path)) {\n        return path;\n      }\n      path = path.parentPath;\n    }\n    return null;\n  }\n\n  // returns if path is directly in a path with a type stored in type\n  // type can be a single type string or an array of type strings \n  isDirectlyIn(type, path) {\n    if (type instanceof Array) {\n      return type.map(elem => this.isDirectlyIn(elem, path)).reduce((accu, elem) => accu || elem, false);\n    }\n    return path.node && path.node.type === type;\n  }\n\n  /*MD ## Color Picker MD*/\n\n  updateColor(currentLocation, color) {\n    var location = { anchor: currentLocation, head: currentLocation };\n    const scrollInfo = this.scrollInfo;\n    this.sourceCode = this.sourceCode.transformAsAST(() => ({\n      visitor: {\n        Program: programPath => {\n          const path = this.getInnermostPathContainingSelection(programPath, range(location)); //this.getPathBeforeCursor(programPath, currentLocation);\n          if (t.isStringLiteral(path.node)) {\n            path.node.value = color;\n          }\n        }\n      }\n    })).code;\n    this.scrollTo(scrollInfo);\n  }\n  /*MD ## Generations MD*/\n\n  /*MD ### Generate Testcase / Class / get / set / HTML accessors MD*/\n\n  async openHTMLAccessorsMenu(ids, initialSelectionState) {\n    let comp = await lively.openComponentInWindow(\"lively-code-occurence-selection\");\n    comp.focus();\n    comp.setTitle(\"Select HTML Accessors to generate\");\n    return comp.selectItems(ids, initialSelectionState);\n  }\n\n  getExistingAccessors() {\n    let classMethodIdentifier = [];\n    this.programPath.traverse({\n      ExportDefaultDeclaration(path) {\n        if (path && path.node.declaration && path.node.declaration.type == \"ClassDeclaration\") {\n          classMethodIdentifier = path.node.declaration.body.body.map(elem => elem.key.name);\n          path.stop();\n        }\n      }\n    });\n    return classMethodIdentifier;\n  }\n\n  async generateHTMLAccessors() {\n    const ids = await this.compileListOfIDs();\n    if (ids.length === 0) {\n      return;\n    }\n\n    let existingMethods = this.getExistingAccessors();\n    let initialSelectionState = ids.map(elem => existingMethods.includes(this.generateMethodNameFromProperty(elem.id)));\n    const selectedItems = await this.openHTMLAccessorsMenu(ids, initialSelectionState);\n\n    if (selectedItems.length === 0) {\n      return;\n    }\n    lively.warn(`${selectedItems.length} Accessors generated`);\n\n    selectedItems.forEach(item => {\n      this.generateCodeFragment(item.id, name => this.compileHTMLGetter(name));\n      const selectedPath = this.getInnermostPathContainingSelection(this.programPath, this.firstSelection);\n      let line = selectedPath.parent.loc.end.line + 1;\n      this.codeProvider.cursor = loc({ line, ch: 0 });\n    });\n  }\n\n  // collects all html element ids of the current file\n  async compileListOfIDs() {\n    const htmlURI = this.codeProvider.htmlURI;\n    let html = await htmlURI.fetchText();\n\n    if (html === \"File not found!\\n\") {\n      lively.warn(\"There is no HTML associated with this file.\");\n      return [];\n    }\n\n    let tmp = <div></div>;\n    tmp.innerHTML = html;\n    let ids = tmp.childNodes[0].content.querySelectorAll(\"[id]\").map(ea => ea.id);\n\n    const htmlLines = html.split(\"\\n\");\n\n    const idsWithLocation = [];\n    for (const id of ids) {\n      for (const line of htmlLines) {\n        const indexOfId = line.indexOf(\"id=\\\"\" + id + \"\\\"\");\n        if (indexOfId !== -1) {\n          idsWithLocation.push({ id, url: htmlURI, line: htmlLines.indexOf(line), ch: indexOfId + 4 });\n          break;\n        }\n      }\n    }\n    return idsWithLocation;\n  }\n\n  generateTestCase() {\n    this.generateCodeFragment(\"ExplainWhatIsTested\", id => this.compileTestCase(id.identifier));\n  }\n\n  generateGetter() {\n    this.generateCodeFragment(\"NameThisGetter\", id => this.compileGetter(id.identifier));\n  }\n\n  generateSetter() {\n    this.generateCodeFragment(\"NameThisSetter\", id => this.compileSetter(id.identifier));\n  }\n\n  generateClass() {\n    this.generateCodeFragment(\"SetClassName\", id => this.compileClass(id.identifier));\n  }\n\n  async generateCodeFragment(identifier, replacementGenerator) {\n    const scrollInfo = this.scrollInfo;\n    const selection = this.firstSelection;\n\n    var identifierObject = { identifier };\n\n    var generatedCode;\n    this.sourceCode = this.sourceCode.transformAsAST(() => ({\n      visitor: {\n        Program: programPath => {\n          let pathBefore = this.getPathBeforeCursor(programPath, selection.start);\n          let pathWithin = this.getInnermostPathContainingSelection(programPath, this.firstSelection);\n          generatedCode = replacementGenerator(identifierObject);\n          if (pathBefore === undefined) {\n            // we're on top of the program\n            pathWithin.unshiftContainer('body', generatedCode);\n          } else if (this.isDirectlyIn(pathWithin.type, pathBefore.parentPath)) {\n            // we're inside of a code block, but not in the first line\n            pathBefore.insertAfter(generatedCode);\n          } else {\n            // we're in the first line of a block\n            pathWithin.unshiftContainer('body', generatedCode);\n          }\n        }\n      }\n    })).code;\n\n    // after code generation, we have to find the generated code another time to be able to select it for renaming\n    var pathToSelect;\n    this.programPath.traverse({\n      StringLiteral(path) {\n        if (!pathToSelect && path.node.value == identifierObject.identifier) {\n          pathToSelect = path;\n        }\n      },\n      Identifier(path) {\n        if (path.node.name == identifierObject.identifier) {\n          pathToSelect = path;\n          path.stop();\n        }\n      }\n    });\n    this.selectPaths([pathToSelect], true);\n\n    this.scrollTo(scrollInfo);\n  }\n\n  compileTestCase(explanation) {\n    return template(\"it(EXP, () => {\\n\" + \"let put = 'code here';\" + \"})\")({\n      EXP: t.stringLiteral(explanation)\n    });\n  }\n\n  compileGetter(propertyName) {\n    return t.classMethod(\"get\", t.identifier(propertyName), [], t.blockStatement([t.returnStatement(t.memberExpression(t.thisExpression(), t.identifier(\"internalPropertyName\")))]));\n  }\n\n  compileSetter(propertyName) {\n    return t.classMethod(\"set\", t.identifier(propertyName), [t.Identifier(\"newValue\")], t.blockStatement([t.expressionStatement(t.assignmentExpression(\"=\", t.memberExpression(t.thisExpression(), t.identifier(\"internalPropertyName\")), t.identifier(\"newValue\")))]));\n  }\n\n  compileClass(className) {\n    return t.classDeclaration(t.identifier(className), null, t.classBody([t.classMethod(\"constructor\", t.Identifier(\"constructor\"), [], t.blockStatement([]))]), []);\n  }\n\n  compileHTMLGetter(property) {\n    var propertyName = property.identifier;\n    var methodName = this.generateMethodNameFromProperty(propertyName);\n    property.identifier = methodName;\n    return t.classMethod(\"get\", t.identifier(methodName), [], t.blockStatement([t.returnStatement(t.callExpression(t.memberExpression(t.thisExpression(), t.identifier(\"get\")), [t.stringLiteral(\"#\" + propertyName)]))]));\n  }\n\n  generateMethodNameFromProperty(name) {\n    return name.camelCase();\n  }\n\n  /*MD ### Generate Import MD*/\n\n  /**\n   * Converts the selected expression to a member expression and adds an import to the file if it doesn't already exist.\n   */\n  addImport(url, importName, isFunction) {\n    const selection = this.firstSelection;\n    const scrollInfo = this.scrollInfo;\n    this.sourceCode = this.sourceCode.transformAsAST(() => ({\n      visitor: {\n        Program: programPath => {\n          let existingImportStatement = this.nextPath(programPath, path => {\n            return t.isImportDeclaration(path) && path.node.source.value == url;\n          });\n          let selectedPath = this.getInnermostPathContainingSelection(programPath, selection);\n          if (!existingImportStatement) {\n            let importStatement = t.importDeclaration([t.importSpecifier(t.identifier(importName), t.identifier(importName))], t.stringLiteral(url));\n            programPath.node.body.unshift(importStatement);\n          } else if (!existingImportStatement.node.specifiers.some(spec => spec.imported.name == importName)) {\n            existingImportStatement.node.specifiers.push(t.identifier(importName));\n          }\n          if (!isFunction) {\n            selectedPath.replaceWith(t.memberExpression(t.identifier(importName), t.identifier(selectedPath.node.name)));\n          }\n        }\n      }\n    })).code;\n    this.scrollTo(scrollInfo);\n  }\n\n  /*MD ## Transformations MD*/\n\n  /*MD ### Extract Method MD*/\n  findParameters(identifiers, surroundingMethod, actualSelections) {\n    return identifiers.filter(identifier => {\n      return this.needsToBeParameter(identifier, surroundingMethod);\n    }).filter(identifier => {\n      const bindingPath = identifier.scope.getBinding(identifier.node.name).path;\n      return !this.isSelected(bindingPath, actualSelections);\n    }).map(identifier => {\n      return this.getBindingDeclarationIdentifierPath(identifier.scope.getBinding(identifier.node.name)).node;\n    });\n  }\n\n  shouldBeAsync(content) {\n    let hasAwait = false;\n    content.forEach(startPath => {\n      if (t.isAwaitExpression(startPath.node)) {\n        hasAwait = true;\n      } else {\n        startPath.traverse({\n          AwaitExpression(path) {\n            hasAwait = true;\n            path.stop();\n          }\n        });\n      }\n    });\n\n    return hasAwait;\n  }\n\n  couldBeStatic(content) {\n    let hasThis = false;\n    content.forEach(startPath => {\n      startPath.traverse({\n        ThisExpression(path) {\n          hasThis = true;\n          path.stop();\n        }\n      });\n    });\n\n    return !hasThis;\n  }\n\n  needsToBeParameter(identifier, surroundingMethod) {\n    return identifier.scope.hasBinding(identifier.node.name) && !surroundingMethod.parentPath.scope.hasBinding(identifier.node.name);\n  }\n\n  findReturnValues(identifiers, surroundingMethod, actualSelections) {\n    const bindings = [...new Set(identifiers.filter(identifier => {\n      return identifier.scope.hasBinding(identifier.node.name) && !surroundingMethod.parentPath.scope.hasBinding(identifier.node.name);\n    }).map(identifier => {\n      return identifier.scope.getBinding(identifier.node.name);\n    }))];\n\n    return bindings.filter(binding => {\n      const declarationInSelection = this.isSelected(binding.path, actualSelections);\n      const constantViolationInSelection = binding.constantViolations.some(constantViolation => this.isSelected(constantViolation, actualSelections));\n      const referenceOutsideSelection = binding.referencePaths.some(reference => !this.isSelected(reference, actualSelections));\n\n      return this.needsToBeReturned(declarationInSelection, constantViolationInSelection, referenceOutsideSelection);\n    }).map(binding => {\n      const constantViolationOutsideSelection = binding.constantViolations.some(constantViolation => !this.isSelected(constantViolation, actualSelections));\n      return { node: this.getBindingDeclarationIdentifierPath(binding).node, declaredInExtractedCode: this.isSelected(binding.path, actualSelections), constantViolationOutsideSelection };\n    });\n  }\n\n  needsToBeReturned(declarationInSelection, constantViolationInSelection, referenceOutsideSelection) {\n    return !declarationInSelection && constantViolationInSelection || (constantViolationInSelection || declarationInSelection) && referenceOutsideSelection;\n  }\n\n  createMethod(content, parameter, returnValues, scope, extractingExpression, shouldBeAsync, shouldBeStatic) {\n    if (extractingExpression && returnValues.length > 0) {\n      lively.warn(\"Unable to extract an expression, that assigns something to variables used outside the expression.\");\n    }\n    var returnStatement;\n    returnValues.forEach(returnValue => returnValue.returnIdentifier = returnValue.declaredInExtractedCode ? returnValue.node : t.identifier(returnValue.node.name + \"_return\"));\n    if (returnValues.length == 1) {\n      returnStatement = t.returnStatement(returnValues[0].node);\n    } else if (returnValues.length > 1) {\n      returnStatement = t.returnStatement(t.objectExpression(returnValues.map(i => t.objectProperty(i.returnIdentifier, i.node, false, true))));\n    }\n\n    var methodContent = content.map(p => {\n      //remove formatting for proper re-formatting\n      p.node.loc = null;\n      p.node.start = null;\n      p.node.end = null;\n      return p.node;\n    });\n    if (returnStatement) {\n      methodContent.push(returnStatement);\n    } else if (extractingExpression) {\n      methodContent = [t.returnStatement(content[0].node)];\n    }\n    const newMethod = t.classMethod(\"method\", t.identifier(\"HopefullyNobodyEverUsesThisMethodName\"), parameter, t.blockStatement(methodContent));\n    newMethod.async = shouldBeAsync;\n    newMethod.static = shouldBeStatic;\n    scope.insertAfter(newMethod);\n    for (let i = 0; i < content.length - 1; i++) {\n      content[i].remove();\n    }\n    var methodCall;\n    var callExpression = t.callExpression(t.identifier(\"this.HopefullyNobodyEverUsesThisMethodName\"), parameter);\n    if (shouldBeAsync) {\n      lively.warn(\"Extracting async method. This could change the control flow.\");\n      callExpression = t.awaitExpression(callExpression);\n    }\n    if (returnValues.length == 1) {\n      if (returnValues[0].declaredInExtractedCode) {\n        const variableType = returnValues[0].constantViolationOutsideSelection ? \"var\" : \"const\";\n        methodCall = [t.variableDeclaration(variableType, [t.variableDeclarator(returnValues[0].node, callExpression)])];\n      } else {\n        methodCall = [t.expressionStatement(t.assignmentExpression(\"=\", returnValues[0].node, callExpression))];\n      }\n    } else if (returnValues.length > 1) {\n      const objectPattern = t.objectPattern(returnValues.map(i => t.objectProperty(i.returnIdentifier, i.returnIdentifier, false, true)));\n      methodCall = [t.variableDeclaration(\"const\", [t.variableDeclarator(objectPattern, callExpression)])];\n      returnValues.forEach(returnStatement => {\n        if (returnStatement.node != returnStatement.returnIdentifier) {\n          methodCall.push(t.expressionStatement(t.assignmentExpression(\"=\", returnStatement.node, returnStatement.returnIdentifier)));\n        }\n      });\n    } else {\n      methodCall = [callExpression];\n    }\n    content[content.length - 1].replaceWithMultiple(methodCall);\n  }\n\n  async extractMethod() {\n    const scrollInfo = this.scrollInfo;\n    const transformed = this.sourceCode.transformAsAST(({ types: t, template }) => ({\n      visitor: {\n        Program: programPath => {\n          const extraction = this.selectMethodExtraction(programPath);\n          if (!extraction) return;\n          const {\n            selectedPaths,\n            extractingExpression,\n            actualSelections\n          } = extraction;\n\n          const identifiers = selectedPaths.map(this.getAllIdentifiers).flat();\n          let surroundingMethod = selectedPaths[0].find(parent => {\n            return parent.node.type == \"ClassMethod\";\n          });\n          var shouldBeStatic = this.couldBeStatic(selectedPaths);\n          if (!surroundingMethod) {\n            surroundingMethod = selectedPaths[selectedPaths.length - 1];\n          } else {\n            shouldBeStatic = surroundingMethod.node.static;\n          }\n          const shouldBeAsync = this.shouldBeAsync(selectedPaths);\n          const parameters = this.findParameters(identifiers, surroundingMethod, actualSelections);\n          const returnValues = this.findReturnValues(identifiers, surroundingMethod, actualSelections);\n          this.createMethod(selectedPaths, [...new Set(parameters)], returnValues, surroundingMethod, extractingExpression, shouldBeAsync, shouldBeStatic);\n        }\n      }\n    }));\n    this.sourceCode = transformed.code;\n    this.scrollTo(scrollInfo);\n    const pathsToSelect = [];\n    this.programPath.traverse({\n      Identifier(path) {\n        if (path.node.name == \"HopefullyNobodyEverUsesThisMethodName\") {\n          pathsToSelect.push(path);\n        }\n      }\n    });\n    this.selectPaths(pathsToSelect);\n  }\n\n  /*MD ### Extract Variable MD*/\n\n  selectMethodExtraction(programPath, silent = false) {\n    var selectedPaths = this.getSelectedStatements(programPath);\n    var extractingExpression = false;\n\n    if (selectedPaths.length == 0) {\n      var expressions = this.getSelectedExpressions(programPath);\n      if (expressions.length > 1) {\n        if (!silent) lively.warn('You cannot extract multiple statements at once. Select statements or a single expression!');\n        return;\n      } else if (expressions.length == 0) {\n        if (!silent) lively.warn('Select statements or an expression to extract!');\n        return;\n      } else {\n        selectedPaths = expressions;\n        extractingExpression = true;\n      }\n    }\n\n    const actualSelections = selectedPaths.map(path => {\n      return range(path.node.loc);\n    });\n    return {\n      selectedPaths,\n      extractingExpression,\n      actualSelections\n    };\n  }\n\n  async extractExpressionIntoLocalVariable() {\n    const selection = this.firstSelection;\n    let done = false;\n\n    const scrollInfo = this.scrollInfo;\n\n    let pathLocationToBeExtracted;\n    const res = this.sourceCode.transformAsAST(({ types: t }) => ({\n      visitor: {\n        Expression: path => {\n          if (!done) {\n            const isSelectedPath = this.isPathExactlySelected(path, selection);\n            if (isSelectedPath) {\n              pathLocationToBeExtracted = path.getPathLocation();\n\n              path.find(p => {\n                const parentPath = p.parentPath;\n                if (!parentPath) {\n                  return false;\n                }\n\n                function ensureBlock(body) {\n                  if (!body.node) return false;\n\n                  if (body.isBlockStatement()) {\n                    return false;\n                  }\n\n                  const statements = [];\n                  if (body.isStatement()) {\n                    statements.push(body.node);\n                    const blockNode = t.blockStatement(statements);\n                    body.replaceWith(blockNode);\n                    return true;\n                  } else if (body.parentPath.isArrowFunctionExpression() && body.isExpression()) {\n                    statements.push(t.returnStatement(body.node));\n                    const blockNode = t.blockStatement(statements);\n                    body.replaceWith(blockNode);\n                    return true;\n                  } else {\n                    throw new Error(\"I never thought this was even possible.\");\n                  }\n                }\n\n                const targetLocation = path.getPathLocation();\n                const blockLocation = p.getPathLocation();\n                if (p.parentKey === 'body' && (parentPath.isFor() || parentPath.isWhile())) {\n                  const becameABlock = ensureBlock(p);\n                  if (becameABlock) {\n                    pathLocationToBeExtracted = blockLocation + '.body[0]' + targetLocation.replace(blockLocation, '');\n                  }\n                  return true;\n                }\n                if (p.parentKey === 'body' && parentPath.isFunction()) {\n                  const becameABlock = ensureBlock(p);\n                  if (becameABlock) {\n                    pathLocationToBeExtracted = blockLocation + '.body[0].argument' + targetLocation.replace(blockLocation, '');\n                  }\n                  return true;\n                }\n                if ((p.parentKey === 'consequent' || p.parentKey === 'alternate') && parentPath.isIfStatement()) {\n                  const becameABlock = ensureBlock(p);\n                  if (becameABlock) {\n                    pathLocationToBeExtracted = blockLocation + '.body[0]' + targetLocation.replace(blockLocation, '');\n                  }\n                  return true;\n                }\n              });\n\n              done = true;\n            }\n          }\n        }\n      }\n    }));\n\n    if (!pathLocationToBeExtracted) {\n      lively.warn('No Expression to extract found.');\n      return;\n    }\n\n    const pathLocationsToSelect = [];\n    const resultExtracted = res.code.transformAsAST(({ types: t, template }) => ({\n      visitor: {\n        Program: programPath => {\n          const path = this.pathByLocationFromProgram(programPath, pathLocationToBeExtracted);\n          let value = '';\n          path.traverse({\n            Identifier(p) {\n              value += '-' + p.node.name;\n            }\n          });\n          if (value.length > 0) {\n            // #TODO: ensure unique identifier\n            value = value.camelCase();\n          } else {\n            value = path.scope.generateUidIdentifier('temp').name;\n          }\n          const identifier = t.Identifier(value);\n          const decl = template('const ID = INIT;')({\n            ID: identifier,\n            INIT: path.node\n          });\n\n          let referree = t.Identifier(value);\n\n          path.replaceWith(referree);\n          const insertedDeclaration = path.getStatementParent().insertBefore(decl)[0];\n          const insertedDeclarationIdentifier = insertedDeclaration.get('declarations')[0].get('id');\n\n          pathLocationsToSelect.push(insertedDeclarationIdentifier.getPathLocation());\n          pathLocationsToSelect.push(path.getPathLocation());\n        }\n      }\n    }));\n    this.sourceCode = resultExtracted.code;\n\n    const pathsToSelect = this.pathLocationsToPathes(pathLocationsToSelect);\n\n    this.selectPaths(pathsToSelect);\n    this.scrollTo(scrollInfo);\n  }\n\n  async inlineLocalVariable(foo) {\n    const scrollInfo = this.scrollInfo;\n    let exitedEarly = false;\n\n    const pathLocationsToSelect = [];\n\n    let transformed = this.sourceCode.transformAsAST(({ types: t, template }) => ({\n      visitor: {\n        Program: programPath => {\n\n          const selectedPath = this.getInnermostPathContainingSelection(programPath, this.firstSelection);\n\n          const identifier = this.getFirstSelectedIdentifier(selectedPath);\n          if (!identifier) {\n            lively.warn('no identifier selected');\n            exitedEarly = true;\n            return;\n          }\n\n          const name = identifier.node.name;\n          if (!identifier.scope.hasBinding(name)) {\n            lively.warn('no binding found for ' + name);\n            exitedEarly = true;\n            return;\n          }\n\n          let binding = identifier.scope.getBinding(name);\n          if (!binding) {\n            lively.warn('selected identifier is not referencing a variable ' + name);\n            exitedEarly = true;\n            return;\n          }\n\n          if (!['var', 'let', 'const'].includes(binding.kind)) {\n            lively.warn('binding for \"' + name + '\" is of kind \"' + binding.kind + '\" but should be any of \"var\", \"let\", or \"const\"');\n            exitedEarly = true;\n            return;\n          }\n\n          const constantViolations = binding.constantViolations.map(cv => this.getFirstSelectedIdentifierWithName(cv, binding.identifier.name));\n          if (constantViolations.length > 0) {\n            lively.warn('cannot inline because there is a constant violation for variable ' + name);\n            exitedEarly = true;\n            return;\n          }\n\n          const declarationIdentifierPath = this.getBindingDeclarationIdentifierPath(binding);\n          if (!declarationIdentifierPath.parentPath.isVariableDeclarator()) {\n            lively.warn('declaration is probably in a destructuring');\n            exitedEarly = true;\n            return;\n          }\n\n          const referencePaths = binding.referencePaths;\n          if (referencePaths.length === 0) {\n            lively.warn('variable \"' + name + '\" is never referenced');\n            exitedEarly = true;\n            return;\n          }\n\n          const identifierPaths = [declarationIdentifierPath, ...referencePaths, ...constantViolations];\n          if (!identifierPaths.includes(identifier)) {\n            lively.warn('selected identifier is not referencing a variable ' + name);\n            exitedEarly = true;\n            return;\n          }\n\n          const variableDeclarator = declarationIdentifierPath.findParent(parentPath => parentPath.isVariableDeclarator());\n          const variableDeclaration = declarationIdentifierPath.findParent(parentPath => parentPath.isVariableDeclaration());\n          const initPath = variableDeclarator.get('init');\n\n          // remove declaration\n          if (variableDeclaration.get('declarations').length === 1) {\n            variableDeclaration.remove();\n          } else {\n            variableDeclarator.remove();\n          }\n\n          // inline declaration\n          referencePaths.forEach(p => {\n            pathLocationsToSelect.push(p.getPathLocation());\n          });\n          referencePaths.forEach(p => {\n            p.replaceWith(initPath.node);\n          });\n          const o = { a: 42, b: 17 };\n        }\n      }\n    }));\n\n    if (exitedEarly) {\n      return;\n    }\n\n    this.sourceCode = transformed.code;\n\n    const pathsToSelect = this.pathLocationsToPathes(pathLocationsToSelect);\n    this.selectPaths(pathsToSelect);\n\n    this.scrollTo(scrollInfo);\n  }\n\n  async wrapExpressionIntoActiveExpression() {\n    const selection = this.firstSelection;\n    let done = false;\n\n    const scrollInfo = this.scrollInfo;\n\n    let pathLocationToBeExtracted;\n    const res = this.sourceCode.transformAsAST(() => ({\n      visitor: {\n        Expression: path => {\n          if (!done) {\n            const isSelectedPath = this.isPathExactlySelected(path, selection);\n            if (isSelectedPath) {\n              pathLocationToBeExtracted = path.getPathLocation();\n              done = true;\n            }\n          }\n        }\n      }\n    }));\n\n    if (!pathLocationToBeExtracted) {\n      lively.warn('No `Expression` to wrap found.');\n      return;\n    }\n\n    const pathLocationsToSelect = [];\n    const resultExtracted = res.code.transformAsAST(({ template }) => ({\n      visitor: {\n        Program: programPath => {\n          const path = this.pathByLocationFromProgram(programPath, pathLocationToBeExtracted);\n          const ae = template('aexpr(() => EXPR)')({\n            EXPR: path.node\n          }).expression;\n\n          path.replaceWith(ae);\n\n          pathLocationsToSelect.push(path.getPathLocation());\n        }\n      }\n    }));\n    this.sourceCode = resultExtracted.code;\n\n    const pathsToSelect = this.pathLocationsToPathes(pathLocationsToSelect);\n\n    this.selectPaths(pathsToSelect);\n    this.scrollTo(scrollInfo);\n  }\n\n  /*MD ## Accessors MD*/\n\n  get sourceCode() {\n    return this.codeProvider.code;\n  }\n  set sourceCode(text) {\n    this.codeProvider.code = text;\n    this.codeChanged();\n    return this.codeProvider.code;\n  }\n\n  get scrollInfo() {\n    return this.codeProvider.scrollInfo;\n  }\n\n  scrollTo(scrollInfo) {\n    this.codeProvider.scrollInfo = scrollInfo;\n  }\n\n  /*MD ## Utilities MD*/\n\n  isSelected(path, selections = null) {\n    if (!selections) {\n      selections = this.selectionRanges;\n    }\n    const pathRange = range(path.node.loc);\n    for (const selection of selections) {\n      if (selection.containsRange(pathRange)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  isPathExactlySelected(path, selection) {\n    return selection.isEqual(range(path.node.loc));\n  }\n\n  pathByLocationFromProgram(programPath, location) {\n    let path = programPath;\n    const reg = /(\\.[A-Za-z0-9]+|(\\[[0-9]+\\]))/ig;\n    let result;\n    while ((result = reg.exec(location)) !== null) {\n      let part = result[0];\n      if (part.startsWith('.')) {\n        part = part.replace('.', '');\n        path = path.get(part);\n      } else {\n        part = part.replace(/\\[|\\]/ig, '');\n        part = parseInt(part);\n        path = path[part];\n      }\n    }\n\n    return path;\n  }\n\n  pathLocationsToPathes(pathLocations) {\n    const paths = [];\n\n    this.sourceCode.traverseAsAST({\n      Program: path => {\n        pathLocations.forEach(location => {\n          paths.push(this.pathByLocationFromProgram(path, location));\n        });\n      }\n    });\n\n    return paths;\n  }\n\n  async getCorrespondingClasses(methodName) {\n    let index = await FileIndex.current();\n\n    //find classes that contain the method\n    let possibleClasses = await index.db.classes.filter(cl => {\n      return cl.methods.some(me => me.name == methodName);\n    }).toArray();\n\n    //find files that export things with the urls from the found classes\n    let possibleExports = await index.db.exports.where('url').anyOf(possibleClasses.map(cl => cl.url)).toArray();\n\n    //reduce the found classes with the found possible exports\n    let locations = possibleClasses.filter(cl => {\n      return possibleExports.some(e => e.url == cl.url && e.classes.some(eCl => eCl == cl.name));\n    });\n    return locations.filter(ea => ea.url.match(lively4url)); //filter local files\n  }\n\n  async getFunctionExportURLs(methodName) {\n    let index = await FileIndex.current();\n    let locations = await index.db.exports.filter(exp => {\n      return exp.functions.some(me => me == methodName);\n    }).toArray();\n    return locations.map(loc => loc.url).filter(url => url.match(lively4url));\n  }\n\n  /*MD ## Active_Expressions MD*/\n\n  getAexprAtCursor(location) {\n    let aexprPath;\n    this.programPath.traverse({\n      CallExpression(path) {\n        if (!range(path.node.loc).contains(location)) {\n          path.skip();\n        } else if (isAExpr(path)) {\n          aexprPath = path;\n          path.stop();\n        }\n      }\n    });\n    return aexprPath;\n  }\n\n  get hasActiveExpressionsDirective() {\n    return this.programPath.node.directives.some(node => {\n      return node.value.value === \"enable aexpr\";\n    });\n  }\n\n  ensureEnrichment() {\n    if (this.finishedEnrichment) return true;\n    if (!this.programPath || !this.hasActiveExpressionsDirective) return false;\n    try {\n      this.enrich();\n    } catch (err) {\n      console.error(\"Unable to process source code\", err);\n      return false;\n    }\n    return true;\n  }\n\n  enrich() {\n    let self = this;\n    this.rootNode.traverseAsAST({\n      enter(path) {\n        path.node.extra = {\n          // this is necessary due to possible circles\n          // this collects the correct dependencies\n          // breaks (meaning not beeing entirely correct anymore) as soon as a node is contained by more than one circle (but this turned out to be unlikely)\n          visited: 2,\n          //same for return recursion\n          returnVisited: 2\n        };\n      }\n    });\n\n    // adds the corresponding binding to every identifier\n    this.rootNode.traverseAsAST({\n      Scope(path) {\n        Object.entries(path.scope.bindings).forEach(([_name, binding]) => {\n          binding.referencePaths.forEach(path => {\n            path.node.extra.binding = binding;\n          });\n        });\n      }\n    });\n\n    this.extractMemberAssignments();\n\n    this.enrichFunctionNodes();\n\n    this.programPath.traverse({\n      Expression(expr) {\n        self.collectExpressionInformation(expr);\n      }\n    });\n\n    this.finishedEnrichment = true;\n  }\n\n  // Filters every member assignment and registers it in `this.memberAssignments`\n  extractMemberAssignments() {\n    let self = this;\n    this.programPath.traverse({\n      MemberExpression(expr) {\n        if (expr.node.computed) return;\n        if (!expr.parentPath.isAssignmentExpression()) return;\n        let assignment = self.assignedValue(expr.parentPath);\n\n        let obj = expr.get(\"object\");\n        let objKey = obj.node.extra.binding || 'misc';\n        let property = expr.get(\"property\").node.name;\n\n        let entry = self.memberAssignments.get(property);\n        if (!entry) {\n          // property unknown, adding new property and its accesses to the map\n          let newMap = new Map();\n\n          newMap.set(objKey, [assignment]);\n          self.memberAssignments.set(property, newMap);\n        } else {\n          let objEntry = entry.get(objKey);\n          if (!objEntry) {\n            objEntry = [];\n            entry.set(objKey, objEntry);\n          }\n          objEntry.push(assignment);\n        }\n      }\n    });\n  }\n\n  enrichFunctionNodes() {\n    // adds bindings definend outside of the current scope(e.g. Function) to the scope\n    this.rootNode.traverseAsAST({\n      'Function|ArrowFunctionExpression|Program'(path) {\n        path.node.extra.leakingBindings = leakingBindings(path);\n        const callExpressions = path.node.extra.callExpressions = [];\n        const objects = path.node.extra.objects = new Map();\n        const returns = path.node.extra.returns = [];\n\n        path.traverse({\n          MemberExpression(expr) {\n            if (expr.parentPath.isAssignmentExpression()) return;\n            let objExpr = expr.get(\"object\").node;\n            let property = expr.get(\"property\").node.name;\n\n            let entry = objects.get(objExpr);\n            if (!entry) {\n              objects.set(objExpr, new Set([property]));\n            } else {\n              entry.add(property);\n            }\n          }\n        });\n\n        path.traverse({\n          ReturnStatement(ret) {\n            if (ret.has(\"argument\")) {\n              returns.push(ret.get(\"argument\"));\n            }\n          },\n          CallExpression(call) {\n            callExpressions.push(call);\n          }\n        });\n      }\n    });\n  }\n\n  /* Main recursion for enriching AST \n  *  Resolves Expression nodes and follows their children in order to find\n  *  - resolvedObjects - the {ObjExpression, [Bindings]} in which the expression may result\n  *  - resolvedCallees - the [Function] which callepressions may actually be\n  *  - results         - the [Function] which may be returned by an expression or Identifier\n  *\n  */\n  collectExpressionInformation(path) {\n    if (path.node.extra.returnVisited <= 0) {\n      return [];\n    }\n\n    path.node.extra.returnVisited -= 1;\n\n    if (path.node.extra.results) {\n      return path.node.extra.results;\n    }\n\n    let results = [];\n    let resolvedObjects = [];\n\n    if (path.isObjectExpression()) {\n      resolvedObjects = [{ objectExpression: path, bindings: new Set() }];\n    } else if (path.isIdentifier()) {\n      if (!path.parentPath.isUpdateExpression()) {\n        let binding = path.node.extra.binding;\n        if (binding) {\n          [binding.path, ...binding.constantViolations].forEach(item => {\n            this.collectExpressionInformation(item);\n            results.push(item.node.extra.results);\n            item.node.extra.resolvedObjects.forEach(obj => {\n              obj.bindings.add(binding);\n              resolvedObjects.push(obj);\n            });\n          });\n        }\n      }\n    } else if (path.isAssignmentExpression() || path.isVariableDeclarator()) {\n      let val = this.assignedValue(path);\n      this.collectExpressionInformation(val);\n      results = val.node.extra.results;\n      resolvedObjects = val.node.extra.resolvedObjects;\n    } else if (path.isFunction()) {\n      results = [path];\n    } else if (path.isConditionalExpression()) {\n      [path.get(\"consequent\"), path.get(\"alternate\")].forEach(expr => {\n        this.collectExpressionInformation(expr);\n        results.push(expr.node.extra.results);\n        resolvedObjects.push(expr.node.extra.resolvedObjects);\n      });\n    } else if (path.isCallExpression()) {\n      const callee = path.get(\"callee\");\n      let resolvedCallees = [];\n      this.collectExpressionInformation(callee);\n      callee.node.extra.results.forEach(func => {\n        this.collectExpressionInformation(func);\n        const body = func.get(\"body\");\n        if (!body.isBlockStatement()) {\n          // slim arrow function        \n          this.collectExpressionInformation(body);\n          results.push(body.node.extra.results);\n        } else {\n          func.node.extra.returns.forEach(returnStatement => {\n            this.collectExpressionInformation(returnStatement);\n            results.push(returnStatement.node.extra.results);\n            resolvedObjects.push(returnStatement.node.extra.resolvedObjects);\n          });\n        }\n        // hey we found a callee as well. \n        resolvedCallees.push(func);\n      });\n      path.node.extra.resolvedCallees = resolvedCallees.flat();\n    } else if (path.isMemberExpression()) {\n      const objExpr = path.get(\"object\");\n      this.collectExpressionInformation(objExpr);\n\n      let tmp = objExpr.node.extra.resolvedObjects.flat();\n      tmp.forEach(result => {\n        this.assignmentsOf(path.get(\"property\").node.name, result).forEach(assignment => {\n          this.collectExpressionInformation(assignment);\n          results.push(assignment.node.extra.results);\n          resolvedObjects.push(assignment.node.extra.resolvedObjects);\n        });\n      });\n    }\n    path.node.extra.resolvedObjects = resolvedObjects.flat();\n    path.node.extra.results = results.flat();\n  }\n\n  // Returns for a given 'property' and {ObjExpression, [Binding]} all known assignments including the declaration\n  assignmentsOf(property, obj) {\n\n    let result = [];\n    this.shadowedBindings(obj.bindings).forEach(binding => {\n\n      let propertyEntry = this.memberAssignments.get(property) || new Map();\n      let memberDependencies = propertyEntry.get(\"misc\") || [];\n      memberDependencies.forEach(assignment => result.push(assignment));\n\n      let objEntry = propertyEntry.get(binding);\n      if (objEntry) {\n        objEntry.forEach(assignment => result.push(assignment));\n      }\n    });\n\n    // try to read as much from the given ObjectExpression as possible\n    let objExpr = obj.objectExpression; // the nodePath\n    if (objExpr && objExpr.isObjectExpression()) {\n      let tmp = objExpr.get(\"properties\").find(path => path.get(\"key\").node.name === property);\n      if (tmp) {\n        if (tmp.isObjectProperty()) {\n          result.push(tmp.get(\"value\"));\n        } else if (tmp.isObjectMethod()) {\n          result.push(tmp);\n        }\n      }\n    }\n    return result;\n  }\n\n  assignedValue(path) {\n    if (path.isUpdateExpression()) return path;\n    if (path.isFunctionDeclaration()) return path;\n    if (path.isAssignmentExpression()) return path.get(\"right\");\n    if (path.isVariableDeclarator()) {\n      const id = path.get(\"id\");\n      if (id.isPattern()) return; // #TODO\n      return path.get(\"init\");\n    }\n    return;\n  }\n\n  /* returns all [binding] that the input [binding] may be assigned to.\n   * ATTENTION: this only works for object bindings, since literal values are copied in javascript\n   * `let a = 4; let b = a` `b` is not shadowed but if `a` is an object, then it is shadowed, so instead of using the actual binding `b`, we use every binding `b` resolves to (including `b`)\n   * \n   * //Where is b changed?\n   * let a = {x:1};\n   * let b = a; // a is shadowed binding\n   * a.x = 2; //<--!!!\n   * //b is equal to {x:2}\n   */\n  shadowedBindings(bindings) {\n\n    /* this should be stored in the members map or in an extra property. \n    * DOES NOT DETECT DEPENDENCIES THROUGH SIMPLE ASSIGNMENTS (a la `a = b`)\n    * do this with extra sweep as last enrichment step, when the new property in there\n    */\n    let result = bindings;\n    bindings.forEach(binding => {\n      binding.path.node.extra.resolvedObjects.forEach(obj => {\n        if (obj.bindings) {\n          obj.bindings.forEach(item => result.add(item));\n        }\n      });\n    });\n\n    return result;\n  }\n\n  /* returns a set of nodes where the active Expression on this location may be changed\n   * DOES NOT care for execution order of the code\n   * uses heuristics e.g. fixed recursion depth\n   */\n  resolveDependencies(path) {\n    if (!this.ensureEnrichment()) return new Set();\n\n    if (path.node.dependencies != null) {\n      return path.node.dependencies;\n    }\n\n    return this._resolveDependencies(path);\n  }\n\n  _resolveDependencies(path) {\n    const self = this;\n    if ((path.node.extra.visited -= 1) <= 0) {\n      return path.node.extra.dependencies || new Set();\n    }\n\n    if (path.node.extra.dependencies) {\n      // the dependencies were already collected... just return them\n      return path.node.extra.dependencies;\n    }\n\n    let dependencies = new Set([...this.shadowedBindings(path.node.extra.leakingBindings)].map(binding => [...binding.constantViolations]).flat());\n    path.node.extra.callExpressions.forEach(callExpression => {\n      callExpression.node.extra.resolvedCallees.forEach(callee => {\n        if (t.isFunction(callee)) {\n          this._resolveDependencies(callee).forEach(dep => dependencies.add(dep));\n        }\n\n        if (t.isAssignmentExpression(callee)) {\n          const value = this.assignedValue(callee);\n          if (t.isFunction(value) || t.isArrowFunctionExpression(value)) {\n            this._resolveDependencies(value).forEach(dep => dependencies.add(dep));\n          }\n        }\n\n        if (t.isVariableDeclarator(callee)) {\n          //NOP\n        }\n      });\n    });\n\n    if (path.node.extra.objects.size) {\n      for (const [objExpr, members] of path.node.extra.objects.entries()) {\n        if (t.isThisExpression(objExpr)) continue;\n        for (const member of members) {\n          self.assignmentsOf(member, { bindings: new Set([objExpr.extra.binding]) }).forEach(assignment => {\n            dependencies.add(assignment);\n          });\n        }\n      }\n    }\n    path.node.extra.dependencies = dependencies;\n    return dependencies;\n  }\n\n  getAllActiveExpressions() {\n    return this.aexprs || (this.aexprs = this._collectAExprs());\n  }\n\n  _collectAExprs() {\n    const allAExpr = [];\n    this.programPath.traverse({\n      CallExpression(path) {\n        if (isAExpr(path)) {\n          allAExpr.push(path);\n        }\n      }\n    });\n    return allAExpr;\n  }\n\n}\n\n/*MD ## Active Expressions Helper*/\n\nconst AEXPR_IDENTIFIER_NAME = 'aexpr';\n\nfunction leakingBindings(path) {\n  const bindings = new Set();\n  path.traverse({\n    ReferencedIdentifier(id) {\n      const outerBinding = path.scope.getBinding(id.node.name);\n      if (!outerBinding) return;\n      const actualBinding = id.scope.getBinding(id.node.name);\n      if (outerBinding === actualBinding) {\n        bindings.add(actualBinding);\n      }\n    }\n  });\n  return bindings;\n}\n\nfunction isAExpr(path) {\n  return t.isCallExpression(path) && t.isIdentifier(path.node.callee) && path.node.callee.name === AEXPR_IDENTIFIER_NAME && !path.scope.hasBinding(AEXPR_IDENTIFIER_NAME, true);\n}"]}