Adding in support for multi-parameter logs and actual logging to console.
This commit is contained in:
parent
e6d536bcc8
commit
e146d995eb
|
@ -19,7 +19,7 @@
|
||||||
$: success = !error && !empty
|
$: success = !error && !empty
|
||||||
$: highlightedResult = highlight(expressionResult)
|
$: highlightedResult = highlight(expressionResult)
|
||||||
$: highlightedLogs = expressionLogs.map(l => ({
|
$: highlightedLogs = expressionLogs.map(l => ({
|
||||||
log: highlight(l.log),
|
log: highlight(l.log.join(", ")),
|
||||||
line: l.line,
|
line: l.line,
|
||||||
}))
|
}))
|
||||||
|
|
||||||
|
|
|
@ -124,28 +124,38 @@ export function processJS(handlebars: string, context: any) {
|
||||||
if (!isBackendService()) {
|
if (!isBackendService()) {
|
||||||
// this counts the lines in the wrapped JS *before* the user's code, so that we can minus it
|
// this counts the lines in the wrapped JS *before* the user's code, so that we can minus it
|
||||||
const jsLineCount = frontendWrapJS(js).split(js)[0].split("\n").length
|
const jsLineCount = frontendWrapJS(js).split(js)[0].split("\n").length
|
||||||
const log = (log: string) => {
|
const buildLogResponse = (
|
||||||
// quick way to find out what line this is being called from
|
type: "log" | "info" | "debug" | "warn" | "error" | "trace" | "table"
|
||||||
// its an anonymous function and we look for the overall length to find the
|
) => {
|
||||||
// line number we care about (from the users function)
|
return (...props: any[]) => {
|
||||||
// JS stack traces are in the format function:line:column
|
console[type](...props)
|
||||||
const lineNumber = new Error().stack?.match(
|
props.forEach((prop, index) => {
|
||||||
/<anonymous>:(\d+):\d+/
|
if (typeof prop === "object") {
|
||||||
)?.[1]
|
props[index] = JSON.stringify(prop)
|
||||||
logs.push({
|
}
|
||||||
log,
|
})
|
||||||
line: lineNumber ? parseInt(lineNumber) - jsLineCount : undefined,
|
// quick way to find out what line this is being called from
|
||||||
})
|
// its an anonymous function and we look for the overall length to find the
|
||||||
|
// line number we care about (from the users function)
|
||||||
|
// JS stack traces are in the format function:line:column
|
||||||
|
const lineNumber = new Error().stack?.match(
|
||||||
|
/<anonymous>:(\d+):\d+/
|
||||||
|
)?.[1]
|
||||||
|
logs.push({
|
||||||
|
log: props,
|
||||||
|
line: lineNumber ? parseInt(lineNumber) - jsLineCount : undefined,
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
sandboxContext.console = {
|
sandboxContext.console = {
|
||||||
log: log,
|
log: buildLogResponse("log"),
|
||||||
info: log,
|
info: buildLogResponse("info"),
|
||||||
debug: log,
|
debug: buildLogResponse("debug"),
|
||||||
warn: log,
|
warn: buildLogResponse("warn"),
|
||||||
error: log,
|
error: buildLogResponse("error"),
|
||||||
// two below may need special cases
|
// two below may need special cases
|
||||||
trace: log,
|
trace: buildLogResponse("trace"),
|
||||||
table: log,
|
table: buildLogResponse("table"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,6 @@ export interface ProcessOptions {
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Log {
|
export interface Log {
|
||||||
log: string
|
log: any[]
|
||||||
line?: number
|
line?: number
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue