89 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/*
 | 
						|
	MIT License http://www.opensource.org/licenses/mit-license.php
 | 
						|
	Author Tobias Koppers @sokra
 | 
						|
*/
 | 
						|
 | 
						|
"use strict";
 | 
						|
 | 
						|
const makeSerializable = require("../util/makeSerializable");
 | 
						|
const HarmonyImportDependency = require("./HarmonyImportDependency");
 | 
						|
 | 
						|
/** @typedef {import("webpack-sources").ReplaceSource} ReplaceSource */
 | 
						|
/** @typedef {import("../Dependency")} Dependency */
 | 
						|
/** @typedef {import("../Dependency").GetConditionFn} GetConditionFn */
 | 
						|
/** @typedef {import("../DependencyTemplate").DependencyTemplateContext} DependencyTemplateContext */
 | 
						|
/** @typedef {import("../Module")} Module */
 | 
						|
/** @typedef {import("../ModuleGraph")} ModuleGraph */
 | 
						|
/** @typedef {import("../ModuleGraphConnection")} ModuleGraphConnection */
 | 
						|
/** @typedef {import("../ModuleGraphConnection").ConnectionState} ConnectionState */
 | 
						|
/** @typedef {import("../WebpackError")} WebpackError */
 | 
						|
/** @typedef {import("../javascript/JavascriptParser").ImportAttributes} ImportAttributes */
 | 
						|
/** @typedef {import("../util/Hash")} Hash */
 | 
						|
/** @typedef {import("../util/runtime").RuntimeSpec} RuntimeSpec */
 | 
						|
 | 
						|
class HarmonyImportSideEffectDependency extends HarmonyImportDependency {
 | 
						|
	/**
 | 
						|
	 * @param {string} request the request string
 | 
						|
	 * @param {number} sourceOrder source order
 | 
						|
	 * @param {ImportAttributes=} attributes import attributes
 | 
						|
	 * @param {boolean=} defer is defer phase
 | 
						|
	 */
 | 
						|
	constructor(request, sourceOrder, attributes, defer) {
 | 
						|
		super(request, sourceOrder, attributes, defer);
 | 
						|
	}
 | 
						|
 | 
						|
	get type() {
 | 
						|
		return "harmony side effect evaluation";
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param {ModuleGraph} moduleGraph module graph
 | 
						|
	 * @returns {null | false | GetConditionFn} function to determine if the connection is active
 | 
						|
	 */
 | 
						|
	getCondition(moduleGraph) {
 | 
						|
		return (connection) => {
 | 
						|
			const refModule = connection.resolvedModule;
 | 
						|
			if (!refModule) return true;
 | 
						|
			return refModule.getSideEffectsConnectionState(moduleGraph);
 | 
						|
		};
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @param {ModuleGraph} moduleGraph the module graph
 | 
						|
	 * @returns {ConnectionState} how this dependency connects the module to referencing modules
 | 
						|
	 */
 | 
						|
	getModuleEvaluationSideEffectsState(moduleGraph) {
 | 
						|
		const refModule = moduleGraph.getModule(this);
 | 
						|
		if (!refModule) return true;
 | 
						|
		return refModule.getSideEffectsConnectionState(moduleGraph);
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
makeSerializable(
 | 
						|
	HarmonyImportSideEffectDependency,
 | 
						|
	"webpack/lib/dependencies/HarmonyImportSideEffectDependency"
 | 
						|
);
 | 
						|
 | 
						|
HarmonyImportSideEffectDependency.Template = class HarmonyImportSideEffectDependencyTemplate extends (
 | 
						|
	HarmonyImportDependency.Template
 | 
						|
) {
 | 
						|
	/**
 | 
						|
	 * @param {Dependency} dependency the dependency for which the template should be applied
 | 
						|
	 * @param {ReplaceSource} source the current replace source which can be modified
 | 
						|
	 * @param {DependencyTemplateContext} templateContext the context object
 | 
						|
	 * @returns {void}
 | 
						|
	 */
 | 
						|
	apply(dependency, source, templateContext) {
 | 
						|
		const { moduleGraph, concatenationScope } = templateContext;
 | 
						|
		if (concatenationScope) {
 | 
						|
			const module = /** @type {Module} */ (moduleGraph.getModule(dependency));
 | 
						|
			if (concatenationScope.isModuleInScope(module)) {
 | 
						|
				return;
 | 
						|
			}
 | 
						|
		}
 | 
						|
		super.apply(dependency, source, templateContext);
 | 
						|
	}
 | 
						|
};
 | 
						|
 | 
						|
module.exports = HarmonyImportSideEffectDependency;
 |