parent
bbe71d89cb
commit
5b08ab51c3
|
@ -0,0 +1,114 @@
|
||||||
|
/*
|
||||||
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
||||||
|
Author Tobias Koppers @sokra
|
||||||
|
*/
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
const path = require("path");
|
||||||
|
const ParserHelpers = require("./ParserHelpers");
|
||||||
|
|
||||||
|
class CommonJsStuffPlugin {
|
||||||
|
apply(compiler) {
|
||||||
|
compiler.hooks.compilation.tap(
|
||||||
|
"CommonJsStuffPlugin",
|
||||||
|
(compilation, { normalModuleFactory }) => {
|
||||||
|
const handler = (parser, parserOptions) => {
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("require.main.require")
|
||||||
|
.tap(
|
||||||
|
"CommonJsStuffPlugin",
|
||||||
|
ParserHelpers.expressionIsUnsupported(
|
||||||
|
parser,
|
||||||
|
"require.main.require is not supported by webpack."
|
||||||
|
)
|
||||||
|
);
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("module.parent.require")
|
||||||
|
.tap(
|
||||||
|
"CommonJsStuffPlugin",
|
||||||
|
ParserHelpers.expressionIsUnsupported(
|
||||||
|
parser,
|
||||||
|
"module.parent.require is not supported by webpack."
|
||||||
|
)
|
||||||
|
);
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("require.main")
|
||||||
|
.tap(
|
||||||
|
"CommonJsStuffPlugin",
|
||||||
|
ParserHelpers.toConstantDependencyWithWebpackRequire(
|
||||||
|
parser,
|
||||||
|
"__webpack_require__.c[__webpack_require__.s]"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("module.loaded")
|
||||||
|
.tap("CommonJsStuffPlugin", expr => {
|
||||||
|
parser.state.module.buildMeta.moduleConcatenationBailout =
|
||||||
|
"module.loaded";
|
||||||
|
return ParserHelpers.toConstantDependency(parser, "module.l")(
|
||||||
|
expr
|
||||||
|
);
|
||||||
|
});
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("module.id")
|
||||||
|
.tap("CommonJsStuffPlugin", expr => {
|
||||||
|
parser.state.module.buildMeta.moduleConcatenationBailout =
|
||||||
|
"module.id";
|
||||||
|
return ParserHelpers.toConstantDependency(parser, "module.i")(
|
||||||
|
expr
|
||||||
|
);
|
||||||
|
});
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("module.exports")
|
||||||
|
.tap("CommonJsStuffPlugin", () => {
|
||||||
|
const module = parser.state.module;
|
||||||
|
const isHarmony =
|
||||||
|
module.buildMeta && module.buildMeta.exportsType;
|
||||||
|
if (!isHarmony) return true;
|
||||||
|
});
|
||||||
|
parser.hooks.evaluateIdentifier
|
||||||
|
.for("module.hot")
|
||||||
|
.tap(
|
||||||
|
"CommonJsStuffPlugin",
|
||||||
|
ParserHelpers.evaluateToIdentifier("module.hot", false)
|
||||||
|
);
|
||||||
|
parser.hooks.expression
|
||||||
|
.for("module")
|
||||||
|
.tap("CommonJsStuffPlugin", () => {
|
||||||
|
const module = parser.state.module;
|
||||||
|
const isHarmony =
|
||||||
|
module.buildMeta && module.buildMeta.exportsType;
|
||||||
|
let moduleJsPath = path.join(
|
||||||
|
__dirname,
|
||||||
|
"..",
|
||||||
|
"buildin",
|
||||||
|
isHarmony ? "harmony-module.js" : "module.js"
|
||||||
|
);
|
||||||
|
if (module.context) {
|
||||||
|
moduleJsPath = path.relative(
|
||||||
|
parser.state.module.context,
|
||||||
|
moduleJsPath
|
||||||
|
);
|
||||||
|
if (!/^[A-Z]:/i.test(moduleJsPath)) {
|
||||||
|
moduleJsPath = `./${moduleJsPath.replace(/\\/g, "/")}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ParserHelpers.addParsedVariableToModule(
|
||||||
|
parser,
|
||||||
|
"module",
|
||||||
|
`require(${JSON.stringify(moduleJsPath)})(module)`
|
||||||
|
);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
normalModuleFactory.hooks.parser
|
||||||
|
.for("javascript/auto")
|
||||||
|
.tap("CommonJsStuffPlugin", handler);
|
||||||
|
normalModuleFactory.hooks.parser
|
||||||
|
.for("javascript/dynamic")
|
||||||
|
.tap("CommonJsStuffPlugin", handler);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
module.exports = CommonJsStuffPlugin;
|
|
@ -94,15 +94,6 @@ class NodeStuffPlugin {
|
||||||
)(expr);
|
)(expr);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
parser.hooks.expression
|
|
||||||
.for("require.main")
|
|
||||||
.tap(
|
|
||||||
"NodeStuffPlugin",
|
|
||||||
ParserHelpers.toConstantDependencyWithWebpackRequire(
|
|
||||||
parser,
|
|
||||||
"__webpack_require__.c[__webpack_require__.s]"
|
|
||||||
)
|
|
||||||
);
|
|
||||||
parser.hooks.expression
|
parser.hooks.expression
|
||||||
.for("require.extensions")
|
.for("require.extensions")
|
||||||
.tap(
|
.tap(
|
||||||
|
@ -112,80 +103,6 @@ class NodeStuffPlugin {
|
||||||
"require.extensions is not supported by webpack. Use a loader instead."
|
"require.extensions is not supported by webpack. Use a loader instead."
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
parser.hooks.expression
|
|
||||||
.for("require.main.require")
|
|
||||||
.tap(
|
|
||||||
"NodeStuffPlugin",
|
|
||||||
ParserHelpers.expressionIsUnsupported(
|
|
||||||
parser,
|
|
||||||
"require.main.require is not supported by webpack."
|
|
||||||
)
|
|
||||||
);
|
|
||||||
parser.hooks.expression
|
|
||||||
.for("module.parent.require")
|
|
||||||
.tap(
|
|
||||||
"NodeStuffPlugin",
|
|
||||||
ParserHelpers.expressionIsUnsupported(
|
|
||||||
parser,
|
|
||||||
"module.parent.require is not supported by webpack."
|
|
||||||
)
|
|
||||||
);
|
|
||||||
parser.hooks.expression
|
|
||||||
.for("module.loaded")
|
|
||||||
.tap("NodeStuffPlugin", expr => {
|
|
||||||
parser.state.module.buildMeta.moduleConcatenationBailout =
|
|
||||||
"module.loaded";
|
|
||||||
return ParserHelpers.toConstantDependency(parser, "module.l")(
|
|
||||||
expr
|
|
||||||
);
|
|
||||||
});
|
|
||||||
parser.hooks.expression
|
|
||||||
.for("module.id")
|
|
||||||
.tap("NodeStuffPlugin", expr => {
|
|
||||||
parser.state.module.buildMeta.moduleConcatenationBailout =
|
|
||||||
"module.id";
|
|
||||||
return ParserHelpers.toConstantDependency(parser, "module.i")(
|
|
||||||
expr
|
|
||||||
);
|
|
||||||
});
|
|
||||||
parser.hooks.expression
|
|
||||||
.for("module.exports")
|
|
||||||
.tap("NodeStuffPlugin", () => {
|
|
||||||
const module = parser.state.module;
|
|
||||||
const isHarmony =
|
|
||||||
module.buildMeta && module.buildMeta.exportsType;
|
|
||||||
if (!isHarmony) return true;
|
|
||||||
});
|
|
||||||
parser.hooks.evaluateIdentifier
|
|
||||||
.for("module.hot")
|
|
||||||
.tap(
|
|
||||||
"NodeStuffPlugin",
|
|
||||||
ParserHelpers.evaluateToIdentifier("module.hot", false)
|
|
||||||
);
|
|
||||||
parser.hooks.expression.for("module").tap("NodeStuffPlugin", () => {
|
|
||||||
const module = parser.state.module;
|
|
||||||
const isHarmony = module.buildMeta && module.buildMeta.exportsType;
|
|
||||||
let moduleJsPath = path.join(
|
|
||||||
__dirname,
|
|
||||||
"..",
|
|
||||||
"buildin",
|
|
||||||
isHarmony ? "harmony-module.js" : "module.js"
|
|
||||||
);
|
|
||||||
if (module.context) {
|
|
||||||
moduleJsPath = path.relative(
|
|
||||||
parser.state.module.context,
|
|
||||||
moduleJsPath
|
|
||||||
);
|
|
||||||
if (!/^[A-Z]:/i.test(moduleJsPath)) {
|
|
||||||
moduleJsPath = `./${moduleJsPath.replace(/\\/g, "/")}`;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ParserHelpers.addParsedVariableToModule(
|
|
||||||
parser,
|
|
||||||
"module",
|
|
||||||
`require(${JSON.stringify(moduleJsPath)})(module)`
|
|
||||||
);
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
normalModuleFactory.hooks.parser
|
normalModuleFactory.hooks.parser
|
||||||
|
|
|
@ -21,6 +21,7 @@ const RecordIdsPlugin = require("./RecordIdsPlugin");
|
||||||
|
|
||||||
const APIPlugin = require("./APIPlugin");
|
const APIPlugin = require("./APIPlugin");
|
||||||
const ConstPlugin = require("./ConstPlugin");
|
const ConstPlugin = require("./ConstPlugin");
|
||||||
|
const CommonJsStuffPlugin = require("./CommonJsStuffPlugin");
|
||||||
const CompatibilityPlugin = require("./CompatibilityPlugin");
|
const CompatibilityPlugin = require("./CompatibilityPlugin");
|
||||||
|
|
||||||
const TemplatedPathPlugin = require("./TemplatedPathPlugin");
|
const TemplatedPathPlugin = require("./TemplatedPathPlugin");
|
||||||
|
@ -293,6 +294,7 @@ class WebpackOptionsApply extends OptionsApply {
|
||||||
const NodeStuffPlugin = require("./NodeStuffPlugin");
|
const NodeStuffPlugin = require("./NodeStuffPlugin");
|
||||||
new NodeStuffPlugin(options.node).apply(compiler);
|
new NodeStuffPlugin(options.node).apply(compiler);
|
||||||
}
|
}
|
||||||
|
new CommonJsStuffPlugin().apply(compiler);
|
||||||
new APIPlugin().apply(compiler);
|
new APIPlugin().apply(compiler);
|
||||||
new ConstPlugin().apply(compiler);
|
new ConstPlugin().apply(compiler);
|
||||||
new UseStrictPlugin().apply(compiler);
|
new UseStrictPlugin().apply(compiler);
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
it("should allow to access module.id when node option is set to false", function() {
|
||||||
|
expect(module.id).toBeDefined();
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should allow to access module.loaded when node option is set to false", function() {
|
||||||
|
expect(module.loaded).toBeDefined();
|
||||||
|
});
|
|
@ -0,0 +1,4 @@
|
||||||
|
module.exports = {
|
||||||
|
target: "web",
|
||||||
|
node: false
|
||||||
|
};
|
Loading…
Reference in New Issue