initial commit
This commit is contained in:
2
node_modules/@nuxt/vite-builder/dist/runtime/client.manifest.d.mts
generated
vendored
Normal file
2
node_modules/@nuxt/vite-builder/dist/runtime/client.manifest.d.mts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
declare function _default(): Promise<any>;
|
||||
export default _default;
|
||||
3
node_modules/@nuxt/vite-builder/dist/runtime/client.manifest.mjs
generated
vendored
Normal file
3
node_modules/@nuxt/vite-builder/dist/runtime/client.manifest.mjs
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import { viteNodeFetch } from './vite-node-shared.mjs'
|
||||
|
||||
export default () => viteNodeFetch('/manifest')
|
||||
2
node_modules/@nuxt/vite-builder/dist/runtime/vite-node-shared.d.mts
generated
vendored
Normal file
2
node_modules/@nuxt/vite-builder/dist/runtime/vite-node-shared.d.mts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
export const viteNodeOptions: any;
|
||||
export const viteNodeFetch: import("ofetch/dist/error-8a55452d").$;
|
||||
8
node_modules/@nuxt/vite-builder/dist/runtime/vite-node-shared.d.ts
generated
vendored
Normal file
8
node_modules/@nuxt/vite-builder/dist/runtime/vite-node-shared.d.ts
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
export interface ViteNodeRuntimeOptions {
|
||||
baseURL: string,
|
||||
rootDir: string,
|
||||
entryPath: string,
|
||||
base: string
|
||||
}
|
||||
|
||||
export function getViteNodeOptions (): ViteNodeRuntimeOptions
|
||||
11
node_modules/@nuxt/vite-builder/dist/runtime/vite-node-shared.mjs
generated
vendored
Normal file
11
node_modules/@nuxt/vite-builder/dist/runtime/vite-node-shared.mjs
generated
vendored
Normal file
@@ -0,0 +1,11 @@
|
||||
import { Agent as HTTPSAgent } from 'node:https'
|
||||
import { $fetch } from 'ofetch'
|
||||
|
||||
export const viteNodeOptions = JSON.parse(process.env.NUXT_VITE_NODE_OPTIONS || '{}')
|
||||
|
||||
export const viteNodeFetch = $fetch.create({
|
||||
baseURL: viteNodeOptions.baseURL,
|
||||
agent: viteNodeOptions.baseURL.startsWith('https://')
|
||||
? new HTTPSAgent({ rejectUnauthorized: false })
|
||||
: null
|
||||
})
|
||||
2
node_modules/@nuxt/vite-builder/dist/runtime/vite-node.d.mts
generated
vendored
Normal file
2
node_modules/@nuxt/vite-builder/dist/runtime/vite-node.d.mts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
declare function _default(ssrContext: any): Promise<any>;
|
||||
export default _default;
|
||||
99
node_modules/@nuxt/vite-builder/dist/runtime/vite-node.mjs
generated
vendored
Normal file
99
node_modules/@nuxt/vite-builder/dist/runtime/vite-node.mjs
generated
vendored
Normal file
@@ -0,0 +1,99 @@
|
||||
import { performance } from 'node:perf_hooks'
|
||||
import { createError } from 'h3'
|
||||
import { ViteNodeRunner } from 'vite-node/client'
|
||||
import consola from 'consola'
|
||||
import { viteNodeOptions, viteNodeFetch } from './vite-node-shared.mjs'
|
||||
|
||||
const runner = createRunner()
|
||||
let render
|
||||
|
||||
export default async (ssrContext) => {
|
||||
// Workaround for stub mode
|
||||
// https://github.com/nuxt/framework/pull/3983
|
||||
process.server = true
|
||||
|
||||
// Invalidate cache for files changed since last rendering
|
||||
const invalidates = await viteNodeFetch('/invalidates')
|
||||
const updates = runner.moduleCache.invalidateDepTree(invalidates)
|
||||
|
||||
// Execute SSR bundle on demand
|
||||
const start = performance.now()
|
||||
render = (updates.has(viteNodeOptions.entryPath) || !render) ? (await runner.executeFile(viteNodeOptions.entryPath)).default : render
|
||||
if (updates.size) {
|
||||
const time = Math.round((performance.now() - start) * 1000) / 1000
|
||||
consola.success(`Vite server hmr ${updates.size} files`, time ? `in ${time}ms` : '')
|
||||
}
|
||||
|
||||
const result = await render(ssrContext)
|
||||
return result
|
||||
}
|
||||
|
||||
function createRunner () {
|
||||
const _importers = new Map()
|
||||
return new ViteNodeRunner({
|
||||
root: viteNodeOptions.root, // Equals to Nuxt `srcDir`
|
||||
base: viteNodeOptions.base,
|
||||
resolveId (id, importer) { _importers.set(id, importer) },
|
||||
async fetchModule (id) {
|
||||
const importer = _importers.get(id)
|
||||
_importers.delete(id)
|
||||
id = id.replace(/\/\//g, '/') // TODO: fix in vite-node
|
||||
return await viteNodeFetch('/module/' + encodeURI(id)).catch((err) => {
|
||||
const errorData = err?.data?.data
|
||||
if (!errorData) {
|
||||
throw err
|
||||
}
|
||||
let _err
|
||||
try {
|
||||
const { message, stack } = formatViteError(errorData, id, importer)
|
||||
_err = createError({
|
||||
statusMessage: 'Vite Error',
|
||||
message,
|
||||
stack
|
||||
})
|
||||
} catch (formatError) {
|
||||
consola.warn('Internal nuxt error while formatting vite-node error. Please report this!', formatError)
|
||||
const message = `[vite-node] [TransformError] ${errorData?.message || '-'}`
|
||||
consola.error(message, errorData)
|
||||
throw createError({
|
||||
statusMessage: 'Vite Error',
|
||||
message,
|
||||
stack: `${message}\nat ${id}\n` + (errorData?.stack || '')
|
||||
})
|
||||
}
|
||||
throw _err
|
||||
})
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
function formatViteError (errorData, id, importer) {
|
||||
const errorCode = errorData.name || errorData.reasonCode || errorData.code
|
||||
const frame = errorData.frame || errorData.source || errorData.pluginCode
|
||||
|
||||
const getLocId = (locObj = {}) => locObj.file || locObj.id || locObj.url || id || ''
|
||||
const getLocPos = (locObj = {}) => locObj.line ? `${locObj.line}:${locObj.column || 0}` : ''
|
||||
const locId = getLocId(errorData.loc) || getLocId(errorData.location) || getLocId(errorData.input) || getLocId(errorData)
|
||||
const locPos = getLocPos(errorData.loc) || getLocPos(errorData.location) || getLocPos(errorData.input) || getLocPos(errorData)
|
||||
const loc = locId.replace(process.cwd(), '.') + (locPos ? `:${locPos}` : '')
|
||||
|
||||
const message = [
|
||||
'[vite-node]',
|
||||
errorData.plugin && `[plugin:${errorData.plugin}]`,
|
||||
errorCode && `[${errorCode}]`,
|
||||
loc,
|
||||
errorData.reason && `: ${errorData.reason}`,
|
||||
frame && `<br><pre>${frame.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>')}</pre><br>`
|
||||
].filter(Boolean).join(' ')
|
||||
|
||||
const stack = [
|
||||
message,
|
||||
`at ${loc} ${importer ? `(imported from ${importer})` : ''}`,
|
||||
errorData.stack
|
||||
].filter(Boolean).join('\n')
|
||||
|
||||
return {
|
||||
message,
|
||||
stack
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user