mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-22 19:32:40 +00:00
56 lines
2.0 KiB
TypeScript
56 lines
2.0 KiB
TypeScript
|
import type { Plugin } from 'rollup'
|
||
|
import { parse } from 'acorn'
|
||
|
import { type Node, walk } from 'estree-walker'
|
||
|
import MagicString from 'magic-string'
|
||
|
import tsBlankSpace from 'ts-blank-space'
|
||
|
|
||
|
import { generateFinallyCode, generateInitCode, leading, trailing } from './timings-babel.mjs'
|
||
|
|
||
|
declare global {
|
||
|
// eslint-disable-next-line no-var
|
||
|
var ___logged: boolean
|
||
|
// eslint-disable-next-line no-var
|
||
|
var ___timings: Record<string, number>
|
||
|
// eslint-disable-next-line no-var
|
||
|
var ___calls: Record<string, number>
|
||
|
// eslint-disable-next-line no-var
|
||
|
var ___callers: Record<string, number>
|
||
|
}
|
||
|
|
||
|
export function AnnotateFunctionTimingsPlugin () {
|
||
|
return {
|
||
|
name: 'timings',
|
||
|
transform: {
|
||
|
order: 'post',
|
||
|
handler (code, id) {
|
||
|
const s = new MagicString(code)
|
||
|
try {
|
||
|
const ast = parse(tsBlankSpace(code), { sourceType: 'module', ecmaVersion: 'latest', locations: true })
|
||
|
walk(ast as Node, {
|
||
|
enter (node) {
|
||
|
if (node.type === 'FunctionDeclaration' && node.id && node.id.name) {
|
||
|
const functionName = node.id.name
|
||
|
const start = (node.body as Node & { start: number, end: number }).start
|
||
|
const end = (node.body as Node & { start: number, end: number }).end
|
||
|
|
||
|
if (!functionName || ['createJiti', 'captureStackTrace', '___captureStackTrace', '_interopRequireDefault'].includes(functionName) || !start || !end) { return }
|
||
|
|
||
|
s.prependLeft(start + 1, generateInitCode(functionName) + 'try {')
|
||
|
s.appendRight(end - 1, `} finally { ${generateFinallyCode(functionName)} }`)
|
||
|
}
|
||
|
},
|
||
|
})
|
||
|
code = s.toString()
|
||
|
if (!code.includes(leading)) {
|
||
|
code = [leading, code, trailing].join('\n')
|
||
|
}
|
||
|
return code
|
||
|
} catch (e) {
|
||
|
// eslint-disable-next-line no-console
|
||
|
console.log(e, code, id)
|
||
|
}
|
||
|
},
|
||
|
},
|
||
|
} satisfies Plugin
|
||
|
}
|