From de98e0b232509d5f40c135d540a70e415272ff85 Mon Sep 17 00:00:00 2001 From: Florian Dold Date: Wed, 3 May 2017 15:35:00 +0200 Subject: node_modules --- .../webpack/lib/DependenciesBlockVariable.js | 51 ++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 node_modules/webpack/lib/DependenciesBlockVariable.js (limited to 'node_modules/webpack/lib/DependenciesBlockVariable.js') diff --git a/node_modules/webpack/lib/DependenciesBlockVariable.js b/node_modules/webpack/lib/DependenciesBlockVariable.js new file mode 100644 index 000000000..0da641674 --- /dev/null +++ b/node_modules/webpack/lib/DependenciesBlockVariable.js @@ -0,0 +1,51 @@ +/* + MIT License http://www.opensource.org/licenses/mit-license.php + Author Tobias Koppers @sokra +*/ +"use strict"; + +const ReplaceSource = require("webpack-sources").ReplaceSource; +const RawSource = require("webpack-sources").RawSource; + +class DependenciesBlockVariable { + constructor(name, expression, dependencies) { + this.name = name; + this.expression = expression; + this.dependencies = dependencies || []; + } + + updateHash(hash) { + hash.update(this.name); + hash.update(this.expression); + this.dependencies.forEach(d => { + d.updateHash(hash); + }); + } + + expressionSource(dependencyTemplates, outputOptions, requestShortener) { + const source = new ReplaceSource(new RawSource(this.expression)); + this.dependencies.forEach(dep => { + const template = dependencyTemplates.get(dep.constructor); + if(!template) throw new Error(`No template for dependency: ${dep.constructor.name}`); + template.apply(dep, source, outputOptions, requestShortener, dependencyTemplates); + }); + return source; + } + + disconnect() { + this.dependencies.forEach(d => { + d.disconnect(); + }); + } + + hasDependencies(filter) { + if(filter) { + if(this.dependencies.some(filter)) return true; + } else { + if(this.dependencies.length > 0) return true; + } + return false; + } +} + +module.exports = DependenciesBlockVariable; -- cgit v1.2.3