2023-07-16 13:02:12 +07:00
|
|
|
import chalk from "chalk"
|
|
|
|
|
|
|
|
const rootFile = /.*at file:/
|
|
|
|
export function trace(msg: string, err: Error) {
|
|
|
|
const stack = err.stack
|
|
|
|
console.log()
|
2023-07-23 07:27:41 +07:00
|
|
|
console.log(
|
2023-07-24 01:49:26 +07:00
|
|
|
"\n" +
|
|
|
|
chalk.bgRed.black.bold(" ERROR ") +
|
|
|
|
"\n" +
|
2023-07-23 07:27:41 +07:00
|
|
|
chalk.red(` ${msg}`) +
|
|
|
|
(err.message.length > 0 ? `: ${err.message}` : ""),
|
|
|
|
)
|
2023-07-16 13:02:12 +07:00
|
|
|
if (!stack) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
let reachedEndOfLegibleTrace = false
|
2023-07-23 07:27:41 +07:00
|
|
|
for (const line of stack.split("\n").slice(1)) {
|
2023-07-16 13:02:12 +07:00
|
|
|
if (reachedEndOfLegibleTrace) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!line.includes("node_modules")) {
|
|
|
|
console.log(` ${line}`)
|
|
|
|
if (rootFile.test(line)) {
|
|
|
|
reachedEndOfLegibleTrace = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|