Skip to content

Commit

Permalink
perf: optimize URL constructors with relative paths
Browse files Browse the repository at this point in the history
  • Loading branch information
kherock committed Aug 12, 2022
1 parent 947ad10 commit 5aa4769
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 27 deletions.
63 changes: 42 additions & 21 deletions packages/vite/src/node/plugins/assetImportMetaUrl.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
import path from 'node:path'
import MagicString from 'magic-string'
import { stripLiteral } from 'strip-literal'
import type { Plugin } from '../plugin'
import type { ResolvedConfig } from '../config'
import type { ResolveFn } from '../'
import { isParentDirectory, normalizePath, transformStableResult } from '../utils'
import {
isParentDirectory,
normalizePath,
slash,
transformStableResult
} from '../utils'
import { fileToUrl } from './asset'
import { preloadHelperId } from './importAnalysisBuild'

Expand All @@ -18,6 +24,7 @@ import { preloadHelperId } from './importAnalysisBuild'
* ```
*/
export function assetImportMetaUrlPlugin(config: ResolvedConfig): Plugin {
const normalizedPublicDir = normalizePath(config.publicDir)
let assetResolver: ResolveFn

return {
Expand Down Expand Up @@ -65,31 +72,45 @@ export function assetImportMetaUrlPlugin(config: ResolvedConfig): Plugin {
}

const url = rawUrl.slice(1, -1)
assetResolver ??= config.createResolver({
root: config.publicDir,
extensions: [],
mainFields: [],
tryIndex: false,
preferRelative: true
})
const resolved = await assetResolver(url, id)
if (!resolved) {
let file: string | undefined
if (url.startsWith('.')) {
file = slash(path.resolve(path.dirname(id), url))
} else {
assetResolver ??= config.createResolver({
extensions: [],
mainFields: [],
tryIndex: false,
preferRelative: true
})
file = await assetResolver(url, id)
file ??= url.startsWith('/')
? slash(path.join(config.publicDir, url))
: slash(path.resolve(path.dirname(id), url))
}

// Get final asset URL. If the file does not exist,
// we fall back to the initial URL and let it resolve in runtime
let builtUrl: string | undefined
if (file) {
try {
if (isParentDirectory(normalizedPublicDir, file)) {
const publicPath =
'/' + path.posix.relative(normalizedPublicDir, file)
builtUrl = await fileToUrl(publicPath, config, this)
} else {
builtUrl = await fileToUrl(file, config, this)
}
} catch {
// do nothing, we'll log a warning after this
}
}
if (!builtUrl) {
const rawExp = code.slice(index, index + exp.length)
config.logger.warnOnce(
`\n${rawExp} doesn't exist at build time, it will remain unchanged to be resolved at runtime`
)
builtUrl = url
}
// Get final asset URL. If the file does not exist,
// we fall back to the initial URL and let it resolve in runtime
const builtUrl = resolved
? await fileToUrl(
isParentDirectory(normalizePath(config.publicDir), resolved)
? url
: resolved,
config,
this
)
: url
s.overwrite(
index,
index + exp.length,
Expand Down
21 changes: 16 additions & 5 deletions packages/vite/src/node/plugins/workerImportMetaUrl.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import path from 'node:path'
import JSON5 from 'json5'
import MagicString from 'magic-string'
import type { RollupError } from 'rollup'
Expand All @@ -8,6 +9,7 @@ import {
cleanUrl,
injectQuery,
parseRequest,
slash,
transformStableResult
} from '../utils'
import { getDepsOptimizer } from '../optimizer'
Expand Down Expand Up @@ -113,11 +115,20 @@ export function workerImportMetaUrlPlugin(config: ResolvedConfig): Plugin {
index + allExp.length
)
const url = rawUrl.slice(1, -1)
workerResolver ??= config.createResolver({
tryIndex: false,
preferRelative: true
})
const file = (await workerResolver(url, id)) ?? url
let file: string | undefined
if (url.startsWith('.')) {
file = path.resolve(path.dirname(id), url)
} else {
workerResolver ??= config.createResolver({
extensions: [],
tryIndex: false,
preferRelative: true
})
file = await workerResolver(url, id)
file ??= url.startsWith('/')
? slash(path.join(config.publicDir, url))
: slash(path.resolve(path.dirname(id), url))
}

let builtUrl: string
if (isBuild) {
Expand Down
2 changes: 1 addition & 1 deletion playground/worker/worker/main-module.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ w.addEventListener('message', (ev) =>

// url import worker with alias path
const wResolve = new Worker(
new URL('@/url-worker', import.meta.url),
new URL('@/url-worker.js', import.meta.url),
/* @vite-ignore */ workerOptions
)
wResolve.addEventListener('message', (ev) =>
Expand Down

0 comments on commit 5aa4769

Please sign in to comment.