Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: environment api #16129

Merged
merged 118 commits into from
Apr 19, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
118 commits
Select commit Hold shift + click to select a range
83068fe
feat: separate module graphs per environment
patak-dev Mar 10, 2024
5f5e0ec
feat: abstract moduleGraph into ModuleExecutionEnvironment
patak-dev Mar 10, 2024
281cf97
fix: call updateModules for each environmnet
patak-dev Mar 11, 2024
4808b27
chore: rename server environment to node environment
patak-dev Mar 11, 2024
95ae29b
refactor: move safeModulesPath set to server
patak-dev Mar 11, 2024
d8ff12a
chore: rename module and error back to ssrModule and ssrError
patak-dev Mar 11, 2024
e966ba0
feat: add `hot` property to environments
sheremet-va Mar 11, 2024
1fe63b1
chore: run prettier on environment file
sheremet-va Mar 11, 2024
5e60d8a
refactor: hooks get an environment object instead of a string
patak-dev Mar 11, 2024
30be775
fix: HotContext only gets ModuleExecutionEnvironment
patak-dev Mar 11, 2024
e30b858
refactor: options and environment are required when calling container…
patak-dev Mar 11, 2024
03d3889
refactor: rework resolveId in ModuleExecutionEnvironment constructor
patak-dev Mar 11, 2024
fcebb7d
feat: environment.transformRequest
patak-dev Mar 12, 2024
f927702
chore: lint
patak-dev Mar 12, 2024
88fea3b
feat: configureDevEnvironments + configureBuildEnvironments
patak-dev Mar 12, 2024
60f7f2b
feat: vite runtime renamed to module runner (#16137)
sheremet-va Mar 13, 2024
81abf6e
wip: environment config overrides
patak-dev Mar 13, 2024
a99475e
chore: merge main
patak-dev Mar 13, 2024
92eccf9
chore: lint
patak-dev Mar 13, 2024
f4789a3
feat: builder config, runBuildTasks option
patak-dev Mar 14, 2024
7f94c03
feat: server.runHmrTasks
patak-dev Mar 14, 2024
9a600fe
chore: update
patak-dev Mar 14, 2024
b9ad620
chore: merge main
patak-dev Mar 14, 2024
5c6b6ff
fix: type error
patak-dev Mar 14, 2024
3e6216c
refactor: hooks to config for creating environments
patak-dev Mar 16, 2024
6e71b24
refactor: ModuleExecutionEnvironment -> DevEnvironment
patak-dev Mar 16, 2024
29f1b7b
refactor: environment id,type -> name + fixes
patak-dev Mar 16, 2024
cef1091
feat: inject environment in build hooks
patak-dev Mar 16, 2024
e03bac8
refactor: node -> ssr for default environment
patak-dev Mar 17, 2024
f1d660c
refactor: environments as array instead of map (#16193)
patak-dev Mar 18, 2024
ccf3de4
refactor: clientEnvironment instead of browserEnvironment (#16194)
patak-dev Mar 20, 2024
27e6488
chore: merge main
patak-dev Mar 22, 2024
a7a06fe
refactor: environments array to plain object
patak-dev Mar 22, 2024
8000e8e
refactor: isolate back compat module graph in its own module
patak-dev Mar 22, 2024
fee54ea
refactor: configEnvironment hook + enviroment config resolving
patak-dev Mar 22, 2024
d9ed857
test: fix after merge
patak-dev Mar 22, 2024
dbcc375
feat: support transport options to communicate between the environmen…
sheremet-va Mar 22, 2024
3806fe6
fix: optimizeDeps backward compatibility layer
patak-dev Mar 22, 2024
85ada0d
fix: partial backward compat for config.ssr
patak-dev Mar 22, 2024
c4f4dfb
fix: use "register" event for remote environment transport
sheremet-va Mar 25, 2024
a5ef42e
test: add test for worker transport
sheremet-va Mar 25, 2024
f29e95a
refactor: remove default nodeModuleRunner because it's not used anywhere
sheremet-va Mar 25, 2024
c9abcfc
refactor: rename createSsrEnvironment to createNodeEnvironment
sheremet-va Mar 25, 2024
6040ab3
chore: fix lint
sheremet-va Mar 25, 2024
b4e46fe
chore: fix lint
sheremet-va Mar 25, 2024
fbe6361
feat: environment in hooks, context vs param (#16261)
patak-dev Mar 26, 2024
36463d2
chore: merge main
patak-dev Mar 27, 2024
52edfc9
refactor: pass down name to the environment factory
sheremet-va Mar 27, 2024
9005841
refactor: allow custom connections in node module runner
sheremet-va Mar 27, 2024
8785f4f
chore: lint
sheremet-va Mar 27, 2024
96e825a
feat: --environment in CLI
patak-dev Mar 28, 2024
5477972
refactor: use ssr environment module graph in ssrFixStacktrace
sheremet-va Mar 28, 2024
a160a1b
fix: add auto complete to server.environments
sheremet-va Mar 28, 2024
31e1d3a
fix: fine-grained hmr
sheremet-va Mar 28, 2024
72fe84e
refactor: rename ssrInvalidates to invalidates
sheremet-va Mar 28, 2024
c7e4da2
refactor: base environment.config + environment.options
patak-dev Mar 28, 2024
2ddf28e
chore: update environment.server.config
patak-dev Mar 28, 2024
681ccd4
fix: injectEnvironmentToHooks
patak-dev Mar 29, 2024
a1d385c
fix: injectEnvironmentInContext
patak-dev Mar 29, 2024
c1fc111
refactor: buildEnvironments + hmrEnvironments
patak-dev Mar 29, 2024
3d37ac1
feat(hmr): call `hotUpdate` hook with file create/delete (#16249)
sapphi-red Mar 29, 2024
6f9467e
chore: merge main
patak-dev Mar 29, 2024
a5c7e4f
test(environment): add environment playground (#16299)
hi-ogawa Mar 29, 2024
ca0ecf9
test: skip hmt ssr test for now
sheremet-va Mar 29, 2024
a0b7edb
refactor: rename "hmrEnvironments" to "hotUpdateEnvironments"
sheremet-va Mar 29, 2024
4986641
test: fix windows test
sheremet-va Mar 29, 2024
41dcca1
chore: merge main
patak-dev Mar 29, 2024
fb9365c
fix: resolve.externalConditions
patak-dev Mar 30, 2024
beb40ef
fix: missing externalConditions back compat
patak-dev Mar 31, 2024
ef8c9b9
feat: build.ssrEmitAssets -> build.emitAssets
patak-dev Mar 31, 2024
a183a0f
refactor: remove environment name from the hmr context
sheremet-va Apr 2, 2024
9cfa916
refactor: move transport to properties
sheremet-va Apr 2, 2024
dd6332e
feat: environment aware createResolver and resolvePlugin
patak-dev Apr 3, 2024
f1dcd2c
feat: environment aware createIdResolver
patak-dev Apr 3, 2024
0bec1b9
feat: environment id resolver for css plugin
patak-dev Apr 3, 2024
a7e52aa
feat: environment aware depsOptimizer
patak-dev Apr 4, 2024
5bd8e95
refactor: ssrConfig.optimizeDeps.include/exclude
patak-dev Apr 4, 2024
1a7d290
feat: ssr.target -> environment.webCompatible
patak-dev Apr 5, 2024
2a0b524
feat: ssr.external/noExternal -> resolve.external/noExternal
patak-dev Apr 5, 2024
f96f682
release: v6.0.0-alpha.0
patak-dev Apr 5, 2024
3a27870
docs: fix capitalization typos (#16309)
jay-es Mar 29, 2024
67a74f8
fix: csp nonce injection when no closing tag (#16281) (#16282)
gregtwallace Mar 31, 2024
b39a7ed
ci: run lint in node 20 (#16338)
sapphi-red Apr 3, 2024
833dabf
chore: merge
sapphi-red Apr 3, 2024
a88d572
chore(deps): update tj-actions/changed-files action to v44 (#16326)
renovate[bot] Apr 3, 2024
c7efec4
chore(deps): update all non-major dependencies (#16325)
renovate[bot] Apr 3, 2024
9699ba3
fix: fix sourcemap when using object as `define` value (#15805)
hi-ogawa Apr 3, 2024
6c5536b
fix: do not access document in `/@vite/client` when not defined (#16318)
keyding Apr 3, 2024
dfce45b
chore: `pnpm audit --fix` (#16346)
sapphi-red Apr 3, 2024
bcac048
chore: merge
sapphi-red Apr 3, 2024
8d08db4
ci: run publish in node 20 (#16348)
sapphi-red Apr 3, 2024
a9bf430
perf: reduce size of injected __vite__mapDeps code (#16184)
panstromek Apr 5, 2024
f61d8b1
perf(css): only replace empty chunk if imported (#16349)
bluwy Apr 5, 2024
5f3c44f
chore: merge main
patak-dev Apr 5, 2024
8621c3f
fix(environment): use `environments.client.build.outDir` for preview …
hi-ogawa Apr 6, 2024
27371dc
chore: remove ssrConfig
patak-dev Apr 6, 2024
d91714b
refactor: isFileServingAllowed load fallback for SSR
patak-dev Apr 6, 2024
ea1c7eb
refactor: environment.dev.recoverable
patak-dev Apr 6, 2024
0ea8be9
chore: remove ssr.target use
patak-dev Apr 6, 2024
3ba9214
feat: dedupe/preserveSymlinks
patak-dev Apr 8, 2024
70731ce
refactor: lib options
patak-dev Apr 8, 2024
d15a157
feat: async createEnvironment
patak-dev Apr 8, 2024
f10561b
chore: merge main
patak-dev Apr 8, 2024
bdf13bb
fix: package types
patak-dev Apr 8, 2024
7254175
release: v6.0.0-alpha.1
patak-dev Apr 8, 2024
1f644d0
feat: rework more ssr.target webworker branches
patak-dev Apr 9, 2024
9f9a716
feat: environment aware define
patak-dev Apr 9, 2024
4cd3183
chore: merge main
patak-dev Apr 9, 2024
46c8910
chore: update
patak-dev Apr 9, 2024
9c5321b
release: v6.0.0-alpha.2
patak-dev Apr 9, 2024
84299f3
feat: environment.dev.warmup
patak-dev Apr 10, 2024
59b995e
refactor: proxy environment logger, remove hardcoded `[vite]` from hm…
sheremet-va Apr 12, 2024
52a71e6
refactor: environments have colors in the logger, update logger.info …
sheremet-va Apr 12, 2024
ae1798f
chore: rename runner to evaluator in serverModuleRunner
sheremet-va Apr 16, 2024
5b57f63
feat: deprecate ssrLoadModule (#16431)
sheremet-va Apr 16, 2024
b4fdfaf
feat: keep url queries in ssr mode (#16400)
sheremet-va Apr 16, 2024
319b8e0
feat: decouple DevEnvironment and server (#16460)
patak-dev Apr 19, 2024
635e6d5
chore: merge main
patak-dev Apr 19, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: vite runtime renamed to module runner (#16137)
  • Loading branch information
sheremet-va authored Mar 13, 2024
commit 60f7f2bc7cb73530f528e03dc23872eb58d8fe71
14 changes: 4 additions & 10 deletions docs/guide/api-vite-runtime.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,13 +24,7 @@ export class ViteRuntime {
/**
* URL to execute. Accepts file path, server path, or id relative to the root.
*/
public async executeUrl<T = any>(url: string): Promise<T>
/**
* Entry point URL to execute. Accepts file path, server path or id relative to the root.
* In the case of a full reload triggered by HMR, this is the module that will be reloaded.
* If this method is called multiple times, all entry points will be reloaded one at a time.
*/
public async executeEntrypoint<T = any>(url: string): Promise<T>
public async import<T = any>(url: string): Promise<T>
/**
* Clear all caches including HMR listeners.
*/
Expand All @@ -55,7 +49,7 @@ The `ViteRuntime` class requires `root` and `fetchModule` options when initiated

Runner in `ViteRuntime` is responsible for executing the code. Vite exports `ESModulesRunner` out of the box, it uses `new AsyncFunction` to run the code. You can provide your own implementation if your JavaScript runtime doesn't support unsafe evaluation.

The two main methods that runtime exposes are `executeUrl` and `executeEntrypoint`. The only difference between them is that all modules executed by `executeEntrypoint` will be reexecuted if HMR triggers `full-reload` event. Be aware that Vite Runtime doesn't update `exports` object when this happens (it overrides it), you would need to run `executeUrl` or get the module from `moduleCache` again if you rely on having the latest `exports` object.
Module runner exposes `import` method. When Vite server triggers `full-reload` HMR event, all affected modules will be re-executed. Be aware that Module Runner doesn't update `exports` object when this happens (it overrides it), you would need to run `import` or get the module from `moduleCache` again if you rely on having the latest `exports` object.

**Example Usage:**

Expand All @@ -72,7 +66,7 @@ const runtime = new ViteRuntime(
new ESModulesRunner(),
)

await runtime.executeEntrypoint('/src/entry-point.js')
await runtime.import('/src/entry-point.js')
```

## `ViteRuntimeOptions`
Expand Down Expand Up @@ -207,7 +201,7 @@ const __dirname = fileURLToPath(new URL('.', import.meta.url))
await server.listen()

const runtime = await createViteRuntime(server)
await runtime.executeEntrypoint('/src/entry-point.js')
await runtime.import('/src/entry-point.js')
})()
```

Expand Down
6 changes: 3 additions & 3 deletions docs/guide/ssr.md
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,7 @@ app.use('*', async (req, res, next) => {
// More advanced use case would be creating a runtime in a separate
// thread or even a different machine using ViteRuntime class
const runtime = await vite.createViteRuntime(server)
const { render } = await runtime.executeEntrypoint('/src/entry-server.js')
const { render } = await runtime.import('/src/entry-server.js')

// 4. render the app HTML. This assumes entry-server.js's exported
// `render` function calls appropriate framework SSR APIs,
Expand Down Expand Up @@ -170,7 +170,7 @@ The `dev` script in `package.json` should also be changed to use the server scri
To ship an SSR project for production, we need to:

1. Produce a client build as normal;
2. Produce an SSR build, which can be directly loaded via `import()` so that we don't have to go through Vite's `ssrLoadModule` or `runtime.executeEntrypoint`;
2. Produce an SSR build, which can be directly loaded via `import()` so that we don't have to go through Vite's `ssrLoadModule` or `runtime.import`;

Our scripts in `package.json` will look like this:

Expand All @@ -190,7 +190,7 @@ Then, in `server.js` we need to add some production specific logic by checking `

- Instead of reading the root `index.html`, use the `dist/client/index.html` as the template, since it contains the correct asset links to the client build.

- Instead of `await vite.ssrLoadModule('/src/entry-server.js')` or `await runtime.executeEntrypoint('/src/entry-server.js')`, use `import('./dist/server/entry-server.js')` (this file is the result of the SSR build).
- Instead of `await vite.ssrLoadModule('/src/entry-server.js')` or `await runtime.import('/src/entry-server.js')`, use `import('./dist/server/entry-server.js')` (this file is the result of the SSR build).

- Move the creation and all usage of the `vite` dev server behind dev-only conditional branches, then add static file serving middlewares to serve files from `dist/client`.

Expand Down
10 changes: 5 additions & 5 deletions packages/vite/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -32,9 +32,9 @@
"./client": {
"types": "./client.d.ts"
},
"./runtime": {
"types": "./dist/node/runtime.d.ts",
"import": "./dist/node/runtime.js"
"./module-runner": {
"types": "./dist/node/module-runner.d.ts",
"import": "./dist/node/module-runner.js"
},
"./dist/client/*": "./dist/client/*",
"./types/*": {
Expand All @@ -44,8 +44,8 @@
},
"typesVersions": {
"*": {
"runtime": [
"dist/node/runtime.d.ts"
"module-runner": [
"dist/node/module-runner.d.ts"
]
}
},
Expand Down
10 changes: 5 additions & 5 deletions packages/vite/rollup.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -177,11 +177,11 @@ function createNodeConfig(isProduction: boolean) {
})
}

function createRuntimeConfig(isProduction: boolean) {
function createModuleRunnerConfig(isProduction: boolean) {
return defineConfig({
...sharedNodeOptions,
input: {
runtime: path.resolve(__dirname, 'src/runtime/index.ts'),
'module-runner': path.resolve(__dirname, 'src/module-runner/index.ts'),
},
output: {
...sharedNodeOptions.output,
Expand Down Expand Up @@ -255,7 +255,7 @@ export default (commandLineArgs: any): RollupOptions[] => {
envConfig,
clientConfig,
createNodeConfig(isProduction),
createRuntimeConfig(isProduction),
createModuleRunnerConfig(isProduction),
createCjsConfig(isProduction),
])
}
Expand Down Expand Up @@ -347,10 +347,10 @@ const __require = require;
name: 'cjs-chunk-patch',
renderChunk(code, chunk) {
if (!chunk.fileName.includes('chunks/dep-')) return
// don't patch runtime utils chunk because it should stay lightweight and we know it doesn't use require
// don't patch runner utils chunk because it should stay lightweight and we know it doesn't use require
if (
chunk.name === 'utils' &&
chunk.moduleIds.some((id) => id.endsWith('/ssr/runtime/utils.ts'))
chunk.moduleIds.some((id) => id.endsWith('/ssr/module-runner/utils.ts'))
)
return
const match = code.match(/^(?:import[\s\S]*?;\s*)+/)
Expand Down
10 changes: 5 additions & 5 deletions packages/vite/rollup.dts.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ const external = [
export default defineConfig({
input: {
index: './temp/node/index.d.ts',
runtime: './temp/runtime/index.d.ts',
'module-runner': './temp/module-runner/index.d.ts',
},
output: {
dir: './dist/node',
Expand Down Expand Up @@ -91,10 +91,10 @@ function patchTypes(): Plugin {
},
renderChunk(code, chunk) {
if (
chunk.fileName.startsWith('runtime') ||
chunk.fileName.startsWith('module-runner') ||
chunk.fileName.startsWith('types.d-')
) {
validateRuntimeChunk.call(this, chunk)
validateRunnerChunk.call(this, chunk)
} else {
validateChunkImports.call(this, chunk)
code = replaceConfusingTypeNames.call(this, code, chunk)
Expand All @@ -107,9 +107,9 @@ function patchTypes(): Plugin {
}

/**
* Runtime chunk should only import local dependencies to stay lightweight
* Runner chunk should only import local dependencies to stay lightweight
*/
function validateRuntimeChunk(this: PluginContext, chunk: RenderedChunk) {
function validateRunnerChunk(this: PluginContext, chunk: RenderedChunk) {
for (const id of chunk.imports) {
if (
!id.startsWith('./') &&
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,11 @@ import {
ssrImportMetaKey,
ssrModuleExportsKey,
} from './constants'
import type { ViteModuleRunner, ViteRuntimeModuleContext } from './types'
import type { ModuleEvaluator, ModuleRunnerContext } from './types'

export class ESModulesRunner implements ViteModuleRunner {
async runViteModule(
context: ViteRuntimeModuleContext,
export class ESModulesEvaluator implements ModuleEvaluator {
async runInlinedModule(
context: ModuleRunnerContext,
code: string,
): Promise<any> {
// use AsyncFunction instead of vm module to support broader array of environments out of the box
Expand Down
Original file line number Diff line number Diff line change
@@ -1,21 +1,21 @@
import type { HMRPayload } from 'types/hmrPayload'
import { unwrapId } from '../shared/utils'
import type { ViteRuntime } from './runtime'
import { slash, unwrapId } from '../shared/utils'
import type { ModuleRunner } from './runner'

// updates to HMR should go one after another. It is possible to trigger another update during the invalidation for example.
export function createHMRHandler(
runtime: ViteRuntime,
runner: ModuleRunner,
): (payload: HMRPayload) => Promise<void> {
const queue = new Queue()
return (payload) => queue.enqueue(() => handleHMRPayload(runtime, payload))
return (payload) => queue.enqueue(() => handleHMRPayload(runner, payload))
}

export async function handleHMRPayload(
runtime: ViteRuntime,
runner: ModuleRunner,
payload: HMRPayload,
): Promise<void> {
const hmrClient = runtime.hmrClient
if (!hmrClient || runtime.isDestroyed()) return
const hmrClient = runner.hmrClient
if (!hmrClient || runner.isDestroyed()) return
switch (payload.type) {
case 'connected':
hmrClient.logger.debug(`[vite] connected.`)
Expand All @@ -26,14 +26,14 @@ export async function handleHMRPayload(
await Promise.all(
payload.updates.map(async (update): Promise<void> => {
if (update.type === 'js-update') {
// runtime always caches modules by their full path without /@id/ prefix
// runner always caches modules by their full path without /@id/ prefix
update.acceptedPath = unwrapId(update.acceptedPath)
update.path = unwrapId(update.path)
return hmrClient.queueUpdate(update)
}

hmrClient.logger.error(
'[vite] css hmr is not supported in runtime mode.',
'[vite] css hmr is not supported in runner mode.',
)
}),
)
Expand All @@ -46,22 +46,20 @@ export async function handleHMRPayload(
case 'full-reload': {
const { triggeredBy } = payload
const clearEntrypoints = triggeredBy
? [...runtime.entrypoints].filter((entrypoint) =>
runtime.moduleCache.isImported({
importedId: triggeredBy,
importedBy: entrypoint,
}),
? getModulesEntrypoints(
runner,
getModulesByFile(runner, slash(triggeredBy)),
)
: [...runtime.entrypoints]
: findAllEntrypoints(runner)

if (!clearEntrypoints.length) break
if (!clearEntrypoints.size) break

hmrClient.logger.debug(`[vite] program reload`)
await hmrClient.notifyListeners('vite:beforeFullReload', payload)
runtime.moduleCache.clear()
runner.moduleCache.clear()

for (const id of clearEntrypoints) {
await runtime.executeUrl(id)
await runner.import(id)
}
break
}
Expand Down Expand Up @@ -123,3 +121,46 @@ class Queue {
return true
}
}

function getModulesByFile(runner: ModuleRunner, file: string) {
const modules: string[] = []
for (const [id, mod] of runner.moduleCache.entries()) {
if (mod.meta && 'file' in mod.meta && mod.meta.file === file) {
modules.push(id)
}
}
return modules
}

function getModulesEntrypoints(
runner: ModuleRunner,
modules: string[],
visited = new Set<string>(),
entrypoints = new Set<string>(),
) {
for (const moduleId of modules) {
if (visited.has(moduleId)) continue
visited.add(moduleId)
const module = runner.moduleCache.getByModuleId(moduleId)
if (module.importers && !module.importers.size) {
entrypoints.add(moduleId)
continue
}
for (const importer of module.importers || []) {
getModulesEntrypoints(runner, [importer], visited, entrypoints)
}
}
return entrypoints
}

function findAllEntrypoints(
runner: ModuleRunner,
entrypoints = new Set<string>(),
): Set<string> {
for (const [id, mod] of runner.moduleCache.entries()) {
if (mod.importers && !mod.importers.size) {
entrypoints.add(id)
}
}
return entrypoints
}
Original file line number Diff line number Diff line change
@@ -1,21 +1,21 @@
// this file should re-export only things that don't rely on Node.js or other runtime features
// this file should re-export only things that don't rely on Node.js or other runner features

export { ModuleCacheMap } from './moduleCache'
export { ViteRuntime } from './runtime'
export { ESModulesRunner } from './esmRunner'
export { ModuleRunner } from './runner'
export { ESModulesEvaluator } from './esmEvaluator'

export type { HMRLogger, HMRConnection } from '../shared/hmr'
export type {
ViteModuleRunner,
ViteRuntimeModuleContext,
ModuleEvaluator,
ModuleRunnerContext,
ModuleCache,
FetchResult,
FetchFunction,
ResolvedResult,
SSRImportMetadata,
HMRRuntimeConnection,
ViteRuntimeImportMeta,
ViteRuntimeOptions,
ModuleRunnerHMRConnection,
ModuleRunnerImportMeta,
ModuleRunnerOptions,
} from './types'
export {
ssrDynamicImportKey,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { decodeBase64 } from './utils'
import { DecodedMap } from './sourcemap/decoder'
import type { ModuleCache } from './types'

const VITE_RUNTIME_SOURCEMAPPING_REGEXP = new RegExp(
const MODULE_RUNNER_SOURCEMAPPING_REGEXP = new RegExp(
`//# ${SOURCEMAPPING_URL}=data:application/json;base64,(.+)`,
)

Expand Down Expand Up @@ -77,43 +77,6 @@ export class ModuleCacheMap extends Map<string, ModuleCache> {
module.imports?.clear()
}

isImported(
{
importedId,
importedBy,
}: {
importedId: string
importedBy: string
},
seen = new Set<string>(),
): boolean {
importedId = this.normalize(importedId)
importedBy = this.normalize(importedBy)

if (importedBy === importedId) return true

if (seen.has(importedId)) return false
seen.add(importedId)

const fileModule = this.getByModuleId(importedId)
const importers = fileModule?.importers

if (!importers) return false

if (importers.has(importedBy)) return true

for (const importer of importers) {
if (
this.isImported({
importedBy: importedBy,
importedId: importer,
})
)
return true
}
return false
}

/**
* Invalidate modules that dependent on the given modules, up to the main entry
*/
Expand Down Expand Up @@ -157,7 +120,7 @@ export class ModuleCacheMap extends Map<string, ModuleCache> {
if (mod.map) return mod.map
if (!mod.meta || !('code' in mod.meta)) return null
const mapString = mod.meta.code.match(
VITE_RUNTIME_SOURCEMAPPING_REGEXP,
MODULE_RUNNER_SOURCEMAPPING_REGEXP,
)?.[1]
if (!mapString) return null
const baseFile = mod.meta.file || moduleId.split('?')[0]
Expand Down
Loading
Loading