新增: - backend/venv/ - Python 虚拟环境 - backend/start.sh - 启动脚本(使用虚拟环境) - backend/requirements.txt - 依赖列表 - .gitignore - 忽略虚拟环境和缓存文件 说明: - 每个项目使用独立虚拟环境 - 避免依赖冲突 - 启动脚本自动创建和激活虚拟环境
55 lines
1.4 KiB
JavaScript
55 lines
1.4 KiB
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
const { fileURLToPath } = require("url");
|
|
const { NormalModule } = require("..");
|
|
|
|
/** @typedef {import("../Compiler")} Compiler */
|
|
|
|
const PLUGIN_NAME = "FileUriPlugin";
|
|
|
|
class FileUriPlugin {
|
|
/**
|
|
* Apply the plugin
|
|
* @param {Compiler} compiler the compiler instance
|
|
* @returns {void}
|
|
*/
|
|
apply(compiler) {
|
|
compiler.hooks.compilation.tap(
|
|
PLUGIN_NAME,
|
|
(compilation, { normalModuleFactory }) => {
|
|
normalModuleFactory.hooks.resolveForScheme
|
|
.for("file")
|
|
.tap(PLUGIN_NAME, (resourceData) => {
|
|
const url = new URL(resourceData.resource);
|
|
const path = fileURLToPath(url);
|
|
const query = url.search;
|
|
const fragment = url.hash;
|
|
resourceData.path = path;
|
|
resourceData.query = query;
|
|
resourceData.fragment = fragment;
|
|
resourceData.resource = path + query + fragment;
|
|
return true;
|
|
});
|
|
const hooks = NormalModule.getCompilationHooks(compilation);
|
|
hooks.readResource
|
|
.for(undefined)
|
|
.tapAsync(PLUGIN_NAME, (loaderContext, callback) => {
|
|
const { resourcePath } = loaderContext;
|
|
loaderContext.fs.readFile(resourcePath, (err, result) => {
|
|
if (err) return callback(err);
|
|
loaderContext.addDependency(resourcePath);
|
|
callback(null, result);
|
|
});
|
|
});
|
|
}
|
|
);
|
|
}
|
|
}
|
|
|
|
module.exports = FileUriPlugin;
|