[bug] Fix edit parameter flow and test (#5997)
* Fix callstack blowup in edit flow * Avoid dumb timeout issue with command registration in test * A snapshot a day keeps the bugs away! 📷🐛 * Use a safer way to wait for modeling command registration in test * A snapshot a day keeps the bugs away! 📷🐛 * A snapshot a day keeps the bugs away! 📷🐛 * A snapshot a day keeps the bugs away! 📷🐛 * De-flake create parameter test step --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
This commit is contained in:
@ -4,7 +4,7 @@ import { useKclContext } from 'lang/KclProvider'
|
||||
import { findUniqueName } from 'lang/modifyAst'
|
||||
import { PrevVariable, findAllPreviousVariables } from 'lang/queryAst'
|
||||
import { Expr, SourceRange } from 'lang/wasm'
|
||||
import { useEffect, useRef, useState } from 'react'
|
||||
import { useEffect, useMemo, useRef, useState } from 'react'
|
||||
import { getCalculatedKclExpressionValue } from './kclHelpers'
|
||||
import { parse, resultIsOk } from 'lang/wasm'
|
||||
import { err } from 'lib/trap'
|
||||
@ -44,8 +44,11 @@ export function useCalculateKclExpression({
|
||||
| (typeof context)['selectionRanges']['graphSelections'][number]['codeRef']['range']
|
||||
| undefined = context.selectionRanges.graphSelections[0]?.codeRef?.range
|
||||
// If there is no selection, use the end of the code
|
||||
const endingSourceRange = sourceRange ||
|
||||
selectionRange || [code.length, code.length]
|
||||
// If we don't memoize this, we risk an infinite set/read state loop
|
||||
const endingSourceRange = useMemo(
|
||||
() => sourceRange || selectionRange || [code.length, code.length],
|
||||
[code, selectionRange, sourceRange]
|
||||
)
|
||||
const inputRef = useRef<HTMLInputElement>(null)
|
||||
const [availableVarInfo, setAvailableVarInfo] = useState<
|
||||
ReturnType<typeof findAllPreviousVariables>
|
||||
|
Reference in New Issue
Block a user