aboutsummaryrefslogtreecommitdiff
path: root/node_modules/webpack/lib/CaseSensitiveModulesWarning.js
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2017-05-03 15:35:00 +0200
committerFlorian Dold <florian.dold@gmail.com>2017-05-03 15:35:00 +0200
commitde98e0b232509d5f40c135d540a70e415272ff85 (patch)
treea79222a5b58484ab3b80d18efcaaa7ccc4769b33 /node_modules/webpack/lib/CaseSensitiveModulesWarning.js
parente0c9d480a73fa629c1e4a47d3e721f1d2d345406 (diff)
node_modules
Diffstat (limited to 'node_modules/webpack/lib/CaseSensitiveModulesWarning.js')
-rw-r--r--node_modules/webpack/lib/CaseSensitiveModulesWarning.js49
1 files changed, 49 insertions, 0 deletions
diff --git a/node_modules/webpack/lib/CaseSensitiveModulesWarning.js b/node_modules/webpack/lib/CaseSensitiveModulesWarning.js
new file mode 100644
index 000000000..0cba12ca6
--- /dev/null
+++ b/node_modules/webpack/lib/CaseSensitiveModulesWarning.js
@@ -0,0 +1,49 @@
+/*
+ MIT License http://www.opensource.org/licenses/mit-license.php
+ Author Tobias Koppers @sokra
+*/
+"use strict";
+
+const WebpackError = require("./WebpackError");
+
+module.exports = class CaseSensitiveModulesWarning extends WebpackError {
+ constructor(modules) {
+ super();
+
+ this.name = "CaseSensitiveModulesWarning";
+ const sortedModules = this._sort(modules);
+ const modulesList = this._moduleMessages(sortedModules);
+ this.message = "There are multiple modules with names that only differ in casing.\n" +
+ "This can lead to unexpected behavior when compiling on a filesystem with other case-semantic.\n" +
+ `Use equal casing. Compare these module identifiers:\n${modulesList}`;
+ this.origin = this.module = sortedModules[0];
+
+ Error.captureStackTrace(this, this.constructor);
+ }
+
+ _sort(modules) {
+ return modules.slice().sort((a, b) => {
+ a = a.identifier();
+ b = b.identifier();
+ /* istanbul ignore next */
+ if(a < b) return -1;
+ /* istanbul ignore next */
+ if(a > b) return 1;
+ /* istanbul ignore next */
+ return 0;
+ });
+ }
+
+ _moduleMessages(modules) {
+ return modules.map((m) => {
+ let message = `* ${m.identifier()}`;
+ const validReasons = m.reasons.filter((reason) => reason.module);
+
+ if(validReasons.length > 0) {
+ message += `\n Used by ${validReasons.length} module(s), i. e.`;
+ message += `\n ${validReasons[0].module.identifier()}`;
+ }
+ return message;
+ }).join("\n");
+ }
+};