* WIP: Add the KCL file path into the executor * reuse the stuff that works with settings.project_directory Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixes on both sides Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixes on both sides Signed-off-by: Jess Frazelle <github@jessfraz.com> * helper method Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixes Signed-off-by: Jess Frazelle <github@jessfraz.com> * update kcl-samples tests to not change dirs Signed-off-by: Jess Frazelle <github@jessfraz.com> * update kcl-samples tests to not change dirs Signed-off-by: Jess Frazelle <github@jessfraz.com> * fmt Signed-off-by: Jess Frazelle <github@jessfraz.com> --------- Signed-off-by: Jess Frazelle <github@jessfraz.com> Co-authored-by: Jonathan Tran <jonnytran@gmail.com>
127 lines
2.7 KiB
TypeScript
127 lines
2.7 KiB
TypeScript
import {
|
|
Program,
|
|
executor,
|
|
ProgramMemory,
|
|
kclLint,
|
|
emptyExecState,
|
|
ExecState,
|
|
} from 'lang/wasm'
|
|
import { enginelessExecutor } from 'lib/testHelpers'
|
|
import { EngineCommandManager } from 'lang/std/engineConnection'
|
|
import { KCLError } from 'lang/errors'
|
|
import { Diagnostic } from '@codemirror/lint'
|
|
import { Node } from 'wasm-lib/kcl/bindings/Node'
|
|
|
|
export type ToolTip =
|
|
| 'lineTo'
|
|
| 'line'
|
|
| 'angledLine'
|
|
| 'angledLineOfXLength'
|
|
| 'angledLineOfYLength'
|
|
| 'angledLineToX'
|
|
| 'angledLineToY'
|
|
| 'xLine'
|
|
| 'yLine'
|
|
| 'xLineTo'
|
|
| 'yLineTo'
|
|
| 'angledLineThatIntersects'
|
|
| 'tangentialArcTo'
|
|
| 'circle'
|
|
|
|
export const toolTips: Array<ToolTip> = [
|
|
'line',
|
|
'lineTo',
|
|
'angledLine',
|
|
'angledLineOfXLength',
|
|
'angledLineOfYLength',
|
|
'angledLineToX',
|
|
'angledLineToY',
|
|
'xLine',
|
|
'yLine',
|
|
'xLineTo',
|
|
'yLineTo',
|
|
'angledLineThatIntersects',
|
|
'tangentialArcTo',
|
|
]
|
|
|
|
export async function executeAst({
|
|
ast,
|
|
path,
|
|
engineCommandManager,
|
|
// If you set programMemoryOverride we assume you mean mock mode. Since that
|
|
// is the only way to go about it.
|
|
programMemoryOverride,
|
|
}: {
|
|
ast: Node<Program>
|
|
path?: string
|
|
engineCommandManager: EngineCommandManager
|
|
programMemoryOverride?: ProgramMemory
|
|
isInterrupted?: boolean
|
|
}): Promise<{
|
|
logs: string[]
|
|
errors: KCLError[]
|
|
execState: ExecState
|
|
isInterrupted: boolean
|
|
}> {
|
|
try {
|
|
const execState = await (programMemoryOverride
|
|
? enginelessExecutor(ast, programMemoryOverride, path)
|
|
: executor(ast, engineCommandManager, path))
|
|
|
|
await engineCommandManager.waitForAllCommands()
|
|
|
|
return {
|
|
logs: [],
|
|
errors: [],
|
|
execState,
|
|
isInterrupted: false,
|
|
}
|
|
} catch (e: any) {
|
|
let isInterrupted = false
|
|
if (e instanceof KCLError) {
|
|
// Detect if it is a force interrupt error which is not a KCL processing error.
|
|
if (
|
|
e.msg ===
|
|
'Failed to wait for promise from engine: JsValue("Force interrupt, executionIsStale, new AST requested")'
|
|
) {
|
|
isInterrupted = true
|
|
}
|
|
return {
|
|
errors: [e],
|
|
logs: [],
|
|
execState: emptyExecState(),
|
|
isInterrupted,
|
|
}
|
|
} else {
|
|
console.log(e)
|
|
return {
|
|
logs: [e],
|
|
errors: [],
|
|
execState: emptyExecState(),
|
|
isInterrupted,
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
export async function lintAst({
|
|
ast,
|
|
}: {
|
|
ast: Program
|
|
}): Promise<Array<Diagnostic>> {
|
|
try {
|
|
const discovered_findings = await kclLint(ast)
|
|
return discovered_findings.map((lint) => {
|
|
return {
|
|
message: lint.finding.title,
|
|
severity: 'info',
|
|
from: lint.pos[0],
|
|
to: lint.pos[1],
|
|
}
|
|
})
|
|
} catch (e: any) {
|
|
console.log(e)
|
|
return []
|
|
}
|
|
}
|