webpack 4.9.1 → 4.10.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (279) hide show
  1. package/README.md +755 -755
  2. package/SECURITY.md +9 -9
  3. package/buildin/global.js +20 -20
  4. package/buildin/harmony-module.js +24 -24
  5. package/buildin/module.js +22 -22
  6. package/hot/dev-server.js +61 -61
  7. package/hot/log-apply-result.js +44 -44
  8. package/hot/log.js +45 -45
  9. package/hot/only-dev-server.js +105 -105
  10. package/hot/poll.js +37 -37
  11. package/hot/signal.js +62 -62
  12. package/lib/APIPlugin.js +84 -84
  13. package/lib/AmdMainTemplatePlugin.js +87 -75
  14. package/lib/AsyncDependenciesBlock.js +66 -66
  15. package/lib/AsyncDependencyToInitialChunkError.js +31 -21
  16. package/lib/AutomaticPrefetchPlugin.js +50 -50
  17. package/lib/BannerPlugin.js +3 -1
  18. package/lib/BasicEvaluatedExpression.js +211 -208
  19. package/lib/CachePlugin.js +102 -95
  20. package/lib/CaseSensitiveModulesWarning.js +71 -53
  21. package/lib/Chunk.js +750 -722
  22. package/lib/ChunkGroup.js +13 -5
  23. package/lib/ChunkRenderError.js +32 -32
  24. package/lib/CompatibilityPlugin.js +63 -63
  25. package/lib/Compilation.js +1947 -1905
  26. package/lib/Compiler.js +508 -496
  27. package/lib/ConcurrentCompilationError.js +19 -19
  28. package/lib/ConstPlugin.js +258 -242
  29. package/lib/ContextExclusionPlugin.js +17 -17
  30. package/lib/ContextModule.js +749 -710
  31. package/lib/ContextModuleFactory.js +256 -245
  32. package/lib/ContextReplacementPlugin.js +133 -126
  33. package/lib/DefinePlugin.js +206 -197
  34. package/lib/DelegatedModule.js +101 -101
  35. package/lib/DelegatedModuleFactoryPlugin.js +89 -89
  36. package/lib/DelegatedPlugin.js +39 -39
  37. package/lib/DependenciesBlock.js +89 -87
  38. package/lib/DependenciesBlockVariable.js +52 -51
  39. package/lib/Dependency.js +51 -51
  40. package/lib/DllEntryPlugin.js +51 -51
  41. package/lib/DllModule.js +54 -54
  42. package/lib/DllModuleFactory.js +29 -29
  43. package/lib/DllPlugin.js +44 -42
  44. package/lib/DllReferencePlugin.js +84 -84
  45. package/lib/DynamicEntryPlugin.js +73 -71
  46. package/lib/EntryOptionPlugin.js +33 -33
  47. package/lib/EnvironmentPlugin.js +65 -65
  48. package/lib/ErrorHelpers.js +60 -57
  49. package/lib/EvalDevToolModulePlugin.js +27 -27
  50. package/lib/EvalDevToolModuleTemplatePlugin.js +61 -61
  51. package/lib/EvalSourceMapDevToolPlugin.js +41 -40
  52. package/lib/ExportPropertyMainTemplatePlugin.js +53 -40
  53. package/lib/ExtendedAPIPlugin.js +84 -84
  54. package/lib/ExternalModule.js +159 -159
  55. package/lib/ExternalModuleFactoryPlugin.js +110 -110
  56. package/lib/ExternalsPlugin.js +23 -23
  57. package/lib/FlagDependencyExportsPlugin.js +146 -146
  58. package/lib/FlagDependencyUsagePlugin.js +110 -104
  59. package/lib/FlagInitialModulesAsUsedPlugin.js +36 -36
  60. package/lib/FunctionModulePlugin.js +19 -19
  61. package/lib/FunctionModuleTemplatePlugin.js +100 -98
  62. package/lib/GraphHelpers.js +64 -64
  63. package/lib/HarmonyLinkingError.js +18 -18
  64. package/lib/HashedModuleIdsPlugin.js +53 -53
  65. package/lib/HotModuleReplacement.runtime.js +7 -3
  66. package/lib/HotModuleReplacementPlugin.js +413 -406
  67. package/lib/HotUpdateChunk.js +16 -16
  68. package/lib/HotUpdateChunkTemplate.js +78 -78
  69. package/lib/IgnorePlugin.js +71 -71
  70. package/lib/JavascriptGenerator.js +229 -228
  71. package/lib/JavascriptModulesPlugin.js +179 -184
  72. package/lib/JsonGenerator.js +42 -42
  73. package/lib/JsonModulesPlugin.js +30 -30
  74. package/lib/JsonParser.js +27 -26
  75. package/lib/LibManifestPlugin.js +86 -86
  76. package/lib/LibraryTemplatePlugin.js +153 -119
  77. package/lib/LoaderOptionsPlugin.js +53 -52
  78. package/lib/LoaderTargetPlugin.js +24 -24
  79. package/lib/MainTemplate.js +34 -9
  80. package/lib/Module.js +381 -377
  81. package/lib/ModuleBuildError.js +42 -42
  82. package/lib/ModuleDependencyError.js +35 -25
  83. package/lib/ModuleDependencyWarning.js +25 -25
  84. package/lib/ModuleError.js +28 -28
  85. package/lib/ModuleFilenameHelpers.js +178 -166
  86. package/lib/ModuleParseError.js +44 -44
  87. package/lib/ModuleReason.js +40 -40
  88. package/lib/ModuleTemplate.js +84 -84
  89. package/lib/ModuleWarning.js +30 -30
  90. package/lib/MultiCompiler.js +283 -271
  91. package/lib/MultiEntryPlugin.js +58 -58
  92. package/lib/MultiModule.js +81 -78
  93. package/lib/MultiModuleFactory.js +23 -23
  94. package/lib/MultiStats.js +92 -92
  95. package/lib/MultiWatching.js +38 -38
  96. package/lib/NamedChunksPlugin.js +29 -29
  97. package/lib/NamedModulesPlugin.js +57 -57
  98. package/lib/NoEmitOnErrorsPlugin.js +20 -20
  99. package/lib/NoModeWarning.js +23 -23
  100. package/lib/NodeStuffPlugin.js +179 -178
  101. package/lib/NormalModule.js +497 -490
  102. package/lib/NormalModuleFactory.js +501 -483
  103. package/lib/NormalModuleReplacementPlugin.js +51 -51
  104. package/lib/OptionsDefaulter.js +84 -80
  105. package/lib/Parser.js +2164 -2086
  106. package/lib/ParserHelpers.js +103 -100
  107. package/lib/PrefetchPlugin.js +37 -37
  108. package/lib/ProgressPlugin.js +231 -231
  109. package/lib/ProvidePlugin.js +86 -86
  110. package/lib/RawModule.js +56 -54
  111. package/lib/RecordIdsPlugin.js +166 -162
  112. package/lib/RemovedPluginError.js +13 -13
  113. package/lib/RequestShortener.js +81 -74
  114. package/lib/RequireJsStuffPlugin.js +69 -69
  115. package/lib/ResolverFactory.js +64 -64
  116. package/lib/RuleSet.js +555 -534
  117. package/lib/RuntimeTemplate.js +320 -277
  118. package/lib/SetVarMainTemplatePlugin.js +69 -57
  119. package/lib/SingleEntryPlugin.js +44 -44
  120. package/lib/SizeFormatHelpers.js +24 -24
  121. package/lib/SourceMapDevToolModuleOptionsPlugin.js +49 -49
  122. package/lib/SourceMapDevToolPlugin.js +301 -300
  123. package/lib/Stats.js +1408 -1367
  124. package/lib/Template.js +4 -2
  125. package/lib/TemplatedPathPlugin.js +173 -170
  126. package/lib/UmdMainTemplatePlugin.js +304 -264
  127. package/lib/UseStrictPlugin.js +48 -48
  128. package/lib/WarnCaseSensitiveModulesPlugin.js +37 -36
  129. package/lib/WarnNoModeSetPlugin.js +17 -17
  130. package/lib/WatchIgnorePlugin.js +100 -100
  131. package/lib/Watching.js +194 -193
  132. package/lib/WebpackError.js +25 -19
  133. package/lib/WebpackOptionsApply.js +421 -405
  134. package/lib/WebpackOptionsDefaulter.js +347 -344
  135. package/lib/WebpackOptionsValidationError.js +345 -316
  136. package/lib/compareLocations.js +56 -56
  137. package/lib/dependencies/AMDDefineDependency.js +137 -137
  138. package/lib/dependencies/AMDDefineDependencyParserPlugin.js +336 -327
  139. package/lib/dependencies/AMDPlugin.js +250 -250
  140. package/lib/dependencies/AMDRequireArrayDependency.js +49 -49
  141. package/lib/dependencies/AMDRequireContextDependency.js +20 -20
  142. package/lib/dependencies/AMDRequireDependenciesBlock.js +43 -43
  143. package/lib/dependencies/AMDRequireDependenciesBlockParserPlugin.js +273 -270
  144. package/lib/dependencies/AMDRequireDependency.js +135 -135
  145. package/lib/dependencies/CommonJsPlugin.js +161 -161
  146. package/lib/dependencies/CommonJsRequireContextDependency.js +23 -23
  147. package/lib/dependencies/CommonJsRequireDependencyParserPlugin.js +130 -130
  148. package/lib/dependencies/ConstDependency.js +33 -33
  149. package/lib/dependencies/ContextDependency.js +68 -68
  150. package/lib/dependencies/ContextDependencyTemplateAsId.js +42 -42
  151. package/lib/dependencies/ContextDependencyTemplateAsRequireCall.js +38 -38
  152. package/lib/dependencies/ContextElementDependency.js +21 -21
  153. package/lib/dependencies/DelegatedExportsDependency.js +33 -33
  154. package/lib/dependencies/DependencyReference.js +18 -18
  155. package/lib/dependencies/HarmonyAcceptDependency.js +45 -45
  156. package/lib/dependencies/HarmonyAcceptImportDependency.js +23 -23
  157. package/lib/dependencies/HarmonyCompatibilityDependency.js +31 -31
  158. package/lib/dependencies/HarmonyDetectionParserPlugin.js +92 -90
  159. package/lib/dependencies/HarmonyExportDependencyParserPlugin.js +139 -139
  160. package/lib/dependencies/HarmonyExportExpressionDependency.js +53 -53
  161. package/lib/dependencies/HarmonyExportHeaderDependency.js +30 -30
  162. package/lib/dependencies/HarmonyExportImportedSpecifierDependency.js +620 -603
  163. package/lib/dependencies/HarmonyExportSpecifierDependency.js +54 -54
  164. package/lib/dependencies/HarmonyImportDependency.js +104 -94
  165. package/lib/dependencies/HarmonyImportDependencyParserPlugin.js +217 -214
  166. package/lib/dependencies/HarmonyImportSideEffectDependency.js +31 -31
  167. package/lib/dependencies/HarmonyImportSpecifierDependency.js +166 -156
  168. package/lib/dependencies/HarmonyInitDependency.js +60 -60
  169. package/lib/dependencies/HarmonyModulesPlugin.js +146 -146
  170. package/lib/dependencies/HarmonyTopLevelThisParserPlugin.js +26 -26
  171. package/lib/dependencies/ImportContextDependency.js +23 -23
  172. package/lib/dependencies/ImportDependenciesBlock.js +18 -18
  173. package/lib/dependencies/ImportDependency.js +34 -34
  174. package/lib/dependencies/ImportEagerDependency.js +32 -32
  175. package/lib/dependencies/ImportParserPlugin.js +233 -232
  176. package/lib/dependencies/ImportPlugin.js +82 -82
  177. package/lib/dependencies/ImportWeakDependency.js +34 -34
  178. package/lib/dependencies/JsonExportsDependency.js +26 -26
  179. package/lib/dependencies/LoaderPlugin.js +98 -93
  180. package/lib/dependencies/LocalModuleDependency.js +28 -28
  181. package/lib/dependencies/LocalModulesHelpers.js +52 -45
  182. package/lib/dependencies/ModuleDependency.js +20 -20
  183. package/lib/dependencies/ModuleDependencyTemplateAsId.js +17 -17
  184. package/lib/dependencies/ModuleDependencyTemplateAsRequireId.js +17 -17
  185. package/lib/dependencies/MultiEntryDependency.js +20 -20
  186. package/lib/dependencies/NullDependency.js +20 -20
  187. package/lib/dependencies/RequireContextDependency.js +22 -22
  188. package/lib/dependencies/RequireContextDependencyParserPlugin.js +56 -56
  189. package/lib/dependencies/RequireContextPlugin.js +143 -141
  190. package/lib/dependencies/RequireEnsureDependenciesBlock.js +33 -33
  191. package/lib/dependencies/RequireEnsureDependenciesBlockParserPlugin.js +116 -112
  192. package/lib/dependencies/RequireEnsureDependency.js +58 -58
  193. package/lib/dependencies/RequireEnsurePlugin.js +74 -74
  194. package/lib/dependencies/RequireHeaderDependency.js +26 -26
  195. package/lib/dependencies/RequireIncludeDependency.js +39 -39
  196. package/lib/dependencies/RequireIncludeDependencyParserPlugin.js +23 -23
  197. package/lib/dependencies/RequireIncludePlugin.js +61 -61
  198. package/lib/dependencies/RequireResolveContextDependency.js +23 -23
  199. package/lib/dependencies/RequireResolveDependencyParserPlugin.js +85 -85
  200. package/lib/dependencies/RequireResolveHeaderDependency.js +26 -26
  201. package/lib/dependencies/SingleEntryDependency.js +18 -18
  202. package/lib/dependencies/SystemPlugin.js +125 -125
  203. package/lib/dependencies/UnsupportedDependency.js +27 -27
  204. package/lib/dependencies/WebAssemblyImportDependency.js +48 -44
  205. package/lib/dependencies/WebpackMissingModule.js +20 -20
  206. package/lib/dependencies/getFunctionExpression.js +52 -52
  207. package/lib/formatLocation.js +61 -53
  208. package/lib/node/NodeChunkTemplatePlugin.js +31 -31
  209. package/lib/node/NodeEnvironmentPlugin.js +28 -28
  210. package/lib/node/NodeHotUpdateChunkTemplatePlugin.js +36 -36
  211. package/lib/node/NodeMainTemplate.runtime.js +27 -27
  212. package/lib/node/NodeMainTemplateAsync.runtime.js +44 -44
  213. package/lib/node/NodeMainTemplatePlugin.js +323 -320
  214. package/lib/node/NodeSourcePlugin.js +144 -140
  215. package/lib/node/NodeTargetPlugin.js +18 -18
  216. package/lib/node/NodeTemplatePlugin.js +31 -31
  217. package/lib/node/NodeWatchFileSystem.js +99 -82
  218. package/lib/node/ReadFileCompileWasmTemplatePlugin.js +52 -52
  219. package/lib/optimize/AggressiveMergingPlugin.js +87 -87
  220. package/lib/optimize/AggressiveSplittingPlugin.js +287 -281
  221. package/lib/optimize/ChunkModuleIdRangePlugin.js +68 -68
  222. package/lib/optimize/ConcatenatedModule.js +1420 -1413
  223. package/lib/optimize/EnsureChunkConditionsPlugin.js +70 -70
  224. package/lib/optimize/FlagIncludedChunksPlugin.js +99 -99
  225. package/lib/optimize/LimitChunkCountPlugin.js +66 -66
  226. package/lib/optimize/MergeDuplicateChunksPlugin.js +78 -75
  227. package/lib/optimize/MinChunkSizePlugin.js +77 -77
  228. package/lib/optimize/ModuleConcatenationPlugin.js +470 -457
  229. package/lib/optimize/OccurrenceOrderPlugin.js +133 -126
  230. package/lib/optimize/RemoveParentModulesPlugin.js +127 -117
  231. package/lib/optimize/RuntimeChunkPlugin.js +41 -41
  232. package/lib/optimize/SideEffectsFlagPlugin.js +158 -156
  233. package/lib/optimize/SplitChunksPlugin.js +709 -696
  234. package/lib/performance/AssetsOverSizeLimitWarning.js +30 -30
  235. package/lib/performance/EntrypointsOverSizeLimitWarning.js +31 -31
  236. package/lib/performance/NoAsyncChunksWarning.js +21 -21
  237. package/lib/performance/SizeLimitsPlugin.js +105 -105
  238. package/lib/util/Semaphore.js +41 -41
  239. package/lib/util/SortableSet.js +5 -2
  240. package/lib/util/StackedSetMap.js +12 -5
  241. package/lib/util/TrackingSet.js +35 -35
  242. package/lib/util/cachedMerge.js +35 -35
  243. package/lib/util/createHash.js +77 -77
  244. package/lib/util/identifier.js +76 -76
  245. package/lib/validateSchema.js +67 -67
  246. package/lib/wasm/UnsupportedWebAssemblyFeatureError.js +18 -18
  247. package/lib/wasm/WasmMainTemplatePlugin.js +310 -304
  248. package/lib/wasm/WebAssemblyGenerator.js +143 -19
  249. package/lib/wasm/WebAssemblyJavascriptGenerator.js +90 -107
  250. package/lib/wasm/WebAssemblyModulesPlugin.js +80 -80
  251. package/lib/wasm/WebAssemblyParser.js +28 -5
  252. package/lib/wasm/WebAssemblyUtils.js +48 -0
  253. package/lib/web/FetchCompileWasmTemplatePlugin.js +25 -25
  254. package/lib/web/JsonpChunkTemplatePlugin.js +47 -47
  255. package/lib/web/JsonpExportMainTemplatePlugin.js +47 -47
  256. package/lib/web/JsonpHotUpdateChunkTemplatePlugin.js +39 -39
  257. package/lib/web/JsonpMainTemplate.runtime.js +65 -64
  258. package/lib/web/JsonpMainTemplatePlugin.js +576 -574
  259. package/lib/web/JsonpTemplatePlugin.js +23 -23
  260. package/lib/webpack.js +183 -182
  261. package/lib/webpack.web.js +31 -31
  262. package/lib/webworker/WebWorkerChunkTemplatePlugin.js +35 -35
  263. package/lib/webworker/WebWorkerHotUpdateChunkTemplatePlugin.js +40 -40
  264. package/lib/webworker/WebWorkerMainTemplate.runtime.js +65 -64
  265. package/lib/webworker/WebWorkerMainTemplatePlugin.js +179 -179
  266. package/lib/webworker/WebWorkerTemplatePlugin.js +25 -25
  267. package/package.json +9 -8
  268. package/schemas/WebpackOptions.json +1988 -1988
  269. package/schemas/ajv.absolutePath.js +55 -55
  270. package/schemas/plugins/DllPlugin.json +32 -32
  271. package/schemas/plugins/DllReferencePlugin.json +99 -99
  272. package/schemas/plugins/HashedModuleIdsPlugin.json +24 -24
  273. package/schemas/plugins/LoaderOptionsPlugin.json +26 -26
  274. package/schemas/plugins/SourceMapDevToolPlugin.json +187 -187
  275. package/schemas/plugins/WatchIgnorePlugin.json +16 -16
  276. package/schemas/plugins/debug/ProfilingPlugin.json +12 -12
  277. package/schemas/plugins/optimize/AggressiveSplittingPlugin.json +22 -22
  278. package/schemas/plugins/optimize/LimitChunkCountPlugin.json +15 -15
  279. package/schemas/plugins/optimize/MinChunkSizePlugin.json +13 -13
package/lib/RuleSet.js CHANGED
@@ -1,534 +1,555 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- /*
6
- <rules>: <rule>
7
- <rules>: [<rule>]
8
- <rule>: {
9
- resource: {
10
- test: <condition>,
11
- include: <condition>,
12
- exclude: <condition>,
13
- },
14
- resource: <condition>, -> resource.test
15
- test: <condition>, -> resource.test
16
- include: <condition>, -> resource.include
17
- exclude: <condition>, -> resource.exclude
18
- resourceQuery: <condition>,
19
- compiler: <condition>,
20
- issuer: <condition>,
21
- use: "loader", -> use[0].loader
22
- loader: <>, -> use[0].loader
23
- loaders: <>, -> use
24
- options: {}, -> use[0].options,
25
- query: {}, -> options
26
- parser: {},
27
- use: [
28
- "loader" -> use[x].loader
29
- ],
30
- use: [
31
- {
32
- loader: "loader",
33
- options: {}
34
- }
35
- ],
36
- rules: [
37
- <rule>
38
- ],
39
- oneOf: [
40
- <rule>
41
- ]
42
- }
43
-
44
- <condition>: /regExp/
45
- <condition>: function(arg) {}
46
- <condition>: "starting"
47
- <condition>: [<condition>] // or
48
- <condition>: { and: [<condition>] }
49
- <condition>: { or: [<condition>] }
50
- <condition>: { not: [<condition>] }
51
- <condition>: { test: <condition>, include: <condition>, exclude: <condition> }
52
-
53
-
54
- normalized:
55
-
56
- {
57
- resource: function(),
58
- resourceQuery: function(),
59
- compiler: function(),
60
- issuer: function(),
61
- use: [
62
- {
63
- loader: string,
64
- options: string,
65
- <any>: <any>
66
- }
67
- ],
68
- rules: [<rule>],
69
- oneOf: [<rule>],
70
- <any>: <any>,
71
- }
72
-
73
- */
74
-
75
- "use strict";
76
-
77
- const notMatcher = matcher => {
78
- return function(str) {
79
- return !matcher(str);
80
- };
81
- };
82
-
83
- const orMatcher = items => {
84
- return function(str) {
85
- for (let i = 0; i < items.length; i++) {
86
- if (items[i](str)) return true;
87
- }
88
- return false;
89
- };
90
- };
91
-
92
- const andMatcher = items => {
93
- return function(str) {
94
- for (let i = 0; i < items.length; i++) {
95
- if (!items[i](str)) return false;
96
- }
97
- return true;
98
- };
99
- };
100
-
101
- module.exports = class RuleSet {
102
- constructor(rules) {
103
- this.references = Object.create(null);
104
- this.rules = RuleSet.normalizeRules(rules, this.references, "ref-");
105
- }
106
-
107
- static normalizeRules(rules, refs, ident) {
108
- if (Array.isArray(rules)) {
109
- return rules.map((rule, idx) => {
110
- return RuleSet.normalizeRule(rule, refs, `${ident}-${idx}`);
111
- });
112
- } else if (rules) {
113
- return [RuleSet.normalizeRule(rules, refs, ident)];
114
- } else {
115
- return [];
116
- }
117
- }
118
-
119
- static normalizeRule(rule, refs, ident) {
120
- if (typeof rule === "string")
121
- return {
122
- use: [
123
- {
124
- loader: rule
125
- }
126
- ]
127
- };
128
- if (!rule)
129
- throw new Error("Unexcepted null when object was expected as rule");
130
- if (typeof rule !== "object")
131
- throw new Error(
132
- "Unexcepted " +
133
- typeof rule +
134
- " when object was expected as rule (" +
135
- rule +
136
- ")"
137
- );
138
-
139
- const newRule = {};
140
- let useSource;
141
- let resourceSource;
142
- let condition;
143
-
144
- const checkUseSource = newSource => {
145
- if (useSource && useSource !== newSource)
146
- throw new Error(
147
- RuleSet.buildErrorMessage(
148
- rule,
149
- new Error(
150
- "Rule can only have one result source (provided " +
151
- newSource +
152
- " and " +
153
- useSource +
154
- ")"
155
- )
156
- )
157
- );
158
- useSource = newSource;
159
- };
160
-
161
- const checkResourceSource = newSource => {
162
- if (resourceSource && resourceSource !== newSource)
163
- throw new Error(
164
- RuleSet.buildErrorMessage(
165
- rule,
166
- new Error(
167
- "Rule can only have one resource source (provided " +
168
- newSource +
169
- " and " +
170
- resourceSource +
171
- ")"
172
- )
173
- )
174
- );
175
- resourceSource = newSource;
176
- };
177
-
178
- if (rule.test || rule.include || rule.exclude) {
179
- checkResourceSource("test + include + exclude");
180
- condition = {
181
- test: rule.test,
182
- include: rule.include,
183
- exclude: rule.exclude
184
- };
185
- try {
186
- newRule.resource = RuleSet.normalizeCondition(condition);
187
- } catch (error) {
188
- throw new Error(RuleSet.buildErrorMessage(condition, error));
189
- }
190
- }
191
-
192
- if (rule.resource) {
193
- checkResourceSource("resource");
194
- try {
195
- newRule.resource = RuleSet.normalizeCondition(rule.resource);
196
- } catch (error) {
197
- throw new Error(RuleSet.buildErrorMessage(rule.resource, error));
198
- }
199
- }
200
-
201
- if (rule.resourceQuery) {
202
- try {
203
- newRule.resourceQuery = RuleSet.normalizeCondition(rule.resourceQuery);
204
- } catch (error) {
205
- throw new Error(RuleSet.buildErrorMessage(rule.resourceQuery, error));
206
- }
207
- }
208
-
209
- if (rule.compiler) {
210
- try {
211
- newRule.compiler = RuleSet.normalizeCondition(rule.compiler);
212
- } catch (error) {
213
- throw new Error(RuleSet.buildErrorMessage(rule.compiler, error));
214
- }
215
- }
216
-
217
- if (rule.issuer) {
218
- try {
219
- newRule.issuer = RuleSet.normalizeCondition(rule.issuer);
220
- } catch (error) {
221
- throw new Error(RuleSet.buildErrorMessage(rule.issuer, error));
222
- }
223
- }
224
-
225
- if (rule.loader && rule.loaders)
226
- throw new Error(
227
- RuleSet.buildErrorMessage(
228
- rule,
229
- new Error(
230
- "Provided loader and loaders for rule (use only one of them)"
231
- )
232
- )
233
- );
234
-
235
- const loader = rule.loaders || rule.loader;
236
- if (typeof loader === "string" && !rule.options && !rule.query) {
237
- checkUseSource("loader");
238
- newRule.use = RuleSet.normalizeUse(loader.split("!"), ident);
239
- } else if (typeof loader === "string" && (rule.options || rule.query)) {
240
- checkUseSource("loader + options/query");
241
- newRule.use = RuleSet.normalizeUse(
242
- {
243
- loader: loader,
244
- options: rule.options,
245
- query: rule.query
246
- },
247
- ident
248
- );
249
- } else if (loader && (rule.options || rule.query)) {
250
- throw new Error(
251
- RuleSet.buildErrorMessage(
252
- rule,
253
- new Error(
254
- "options/query cannot be used with loaders (use options for each array item)"
255
- )
256
- )
257
- );
258
- } else if (loader) {
259
- checkUseSource("loaders");
260
- newRule.use = RuleSet.normalizeUse(loader, ident);
261
- } else if (rule.options || rule.query) {
262
- throw new Error(
263
- RuleSet.buildErrorMessage(
264
- rule,
265
- new Error(
266
- "options/query provided without loader (use loader + options)"
267
- )
268
- )
269
- );
270
- }
271
-
272
- if (rule.use) {
273
- checkUseSource("use");
274
- newRule.use = RuleSet.normalizeUse(rule.use, ident);
275
- }
276
-
277
- if (rule.rules)
278
- newRule.rules = RuleSet.normalizeRules(
279
- rule.rules,
280
- refs,
281
- `${ident}-rules`
282
- );
283
-
284
- if (rule.oneOf)
285
- newRule.oneOf = RuleSet.normalizeRules(
286
- rule.oneOf,
287
- refs,
288
- `${ident}-oneOf`
289
- );
290
-
291
- const keys = Object.keys(rule).filter(key => {
292
- return ![
293
- "resource",
294
- "resourceQuery",
295
- "compiler",
296
- "test",
297
- "include",
298
- "exclude",
299
- "issuer",
300
- "loader",
301
- "options",
302
- "query",
303
- "loaders",
304
- "use",
305
- "rules",
306
- "oneOf"
307
- ].includes(key);
308
- });
309
- for (const key of keys) {
310
- newRule[key] = rule[key];
311
- }
312
-
313
- if (Array.isArray(newRule.use)) {
314
- for (const item of newRule.use) {
315
- if (item.ident) {
316
- refs[item.ident] = item.options;
317
- }
318
- }
319
- }
320
-
321
- return newRule;
322
- }
323
-
324
- static buildErrorMessage(condition, error) {
325
- const conditionAsText = JSON.stringify(
326
- condition,
327
- (key, value) => {
328
- return value === undefined ? "undefined" : value;
329
- },
330
- 2
331
- );
332
- return error.message + " in " + conditionAsText;
333
- }
334
-
335
- static normalizeUse(use, ident) {
336
- if (typeof use === "function") {
337
- return data => RuleSet.normalizeUse(use(data), ident);
338
- }
339
- if (Array.isArray(use)) {
340
- return use
341
- .map((item, idx) => RuleSet.normalizeUse(item, `${ident}-${idx}`))
342
- .reduce((arr, items) => arr.concat(items), []);
343
- }
344
- return [RuleSet.normalizeUseItem(use, ident)];
345
- }
346
-
347
- static normalizeUseItemString(useItemString) {
348
- const idx = useItemString.indexOf("?");
349
- if (idx >= 0) {
350
- return {
351
- loader: useItemString.substr(0, idx),
352
- options: useItemString.substr(idx + 1)
353
- };
354
- }
355
- return {
356
- loader: useItemString,
357
- options: undefined
358
- };
359
- }
360
-
361
- static normalizeUseItem(item, ident) {
362
- if (typeof item === "string") {
363
- return RuleSet.normalizeUseItemString(item);
364
- }
365
-
366
- const newItem = {};
367
-
368
- if (item.options && item.query)
369
- throw new Error("Provided options and query in use");
370
-
371
- if (!item.loader) throw new Error("No loader specified");
372
-
373
- newItem.options = item.options || item.query;
374
-
375
- if (typeof newItem.options === "object" && newItem.options) {
376
- if (newItem.options.ident) newItem.ident = newItem.options.ident;
377
- else newItem.ident = ident;
378
- }
379
-
380
- const keys = Object.keys(item).filter(function(key) {
381
- return !["options", "query"].includes(key);
382
- });
383
-
384
- for (const key of keys) {
385
- newItem[key] = item[key];
386
- }
387
-
388
- return newItem;
389
- }
390
-
391
- static normalizeCondition(condition) {
392
- if (!condition) throw new Error("Expected condition but got falsy value");
393
- if (typeof condition === "string") {
394
- return str => str.indexOf(condition) === 0;
395
- }
396
- if (typeof condition === "function") {
397
- return condition;
398
- }
399
- if (condition instanceof RegExp) {
400
- return condition.test.bind(condition);
401
- }
402
- if (Array.isArray(condition)) {
403
- const items = condition.map(c => RuleSet.normalizeCondition(c));
404
- return orMatcher(items);
405
- }
406
- if (typeof condition !== "object")
407
- throw Error(
408
- "Unexcepted " +
409
- typeof condition +
410
- " when condition was expected (" +
411
- condition +
412
- ")"
413
- );
414
-
415
- const matchers = [];
416
- Object.keys(condition).forEach(key => {
417
- const value = condition[key];
418
- switch (key) {
419
- case "or":
420
- case "include":
421
- case "test":
422
- if (value) matchers.push(RuleSet.normalizeCondition(value));
423
- break;
424
- case "and":
425
- if (value) {
426
- const items = value.map(c => RuleSet.normalizeCondition(c));
427
- matchers.push(andMatcher(items));
428
- }
429
- break;
430
- case "not":
431
- case "exclude":
432
- if (value) {
433
- const matcher = RuleSet.normalizeCondition(value);
434
- matchers.push(notMatcher(matcher));
435
- }
436
- break;
437
- default:
438
- throw new Error("Unexcepted property " + key + " in condition");
439
- }
440
- });
441
- if (matchers.length === 0)
442
- throw new Error("Excepted condition but got " + condition);
443
- if (matchers.length === 1) return matchers[0];
444
- return andMatcher(matchers);
445
- }
446
-
447
- exec(data) {
448
- const result = [];
449
- this._run(
450
- data,
451
- {
452
- rules: this.rules
453
- },
454
- result
455
- );
456
- return result;
457
- }
458
-
459
- _run(data, rule, result) {
460
- // test conditions
461
- if (rule.resource && !data.resource) return false;
462
- if (rule.resourceQuery && !data.resourceQuery) return false;
463
- if (rule.compiler && !data.compiler) return false;
464
- if (rule.issuer && !data.issuer) return false;
465
- if (rule.resource && !rule.resource(data.resource)) return false;
466
- if (data.issuer && rule.issuer && !rule.issuer(data.issuer)) return false;
467
- if (
468
- data.resourceQuery &&
469
- rule.resourceQuery &&
470
- !rule.resourceQuery(data.resourceQuery)
471
- )
472
- return false;
473
- if (data.compiler && rule.compiler && !rule.compiler(data.compiler))
474
- return false;
475
-
476
- // apply
477
- const keys = Object.keys(rule).filter(key => {
478
- return ![
479
- "resource",
480
- "resourceQuery",
481
- "compiler",
482
- "issuer",
483
- "rules",
484
- "oneOf",
485
- "use",
486
- "enforce"
487
- ].includes(key);
488
- });
489
- for (const key of keys) {
490
- result.push({
491
- type: key,
492
- value: rule[key]
493
- });
494
- }
495
-
496
- if (rule.use) {
497
- const process = use => {
498
- if (typeof use === "function") {
499
- process(use(data));
500
- } else if (Array.isArray(use)) {
501
- use.forEach(process);
502
- } else {
503
- result.push({
504
- type: "use",
505
- value: use,
506
- enforce: rule.enforce
507
- });
508
- }
509
- };
510
- process(rule.use);
511
- }
512
-
513
- if (rule.rules) {
514
- for (let i = 0; i < rule.rules.length; i++) {
515
- this._run(data, rule.rules[i], result);
516
- }
517
- }
518
-
519
- if (rule.oneOf) {
520
- for (let i = 0; i < rule.oneOf.length; i++) {
521
- if (this._run(data, rule.oneOf[i], result)) break;
522
- }
523
- }
524
-
525
- return true;
526
- }
527
-
528
- findOptionsByIdent(ident) {
529
- const options = this.references[ident];
530
- if (!options)
531
- throw new Error("Can't find options with ident '" + ident + "'");
532
- return options;
533
- }
534
- };
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ /*
6
+ <rules>: <rule>
7
+ <rules>: [<rule>]
8
+ <rule>: {
9
+ resource: {
10
+ test: <condition>,
11
+ include: <condition>,
12
+ exclude: <condition>,
13
+ },
14
+ resource: <condition>, -> resource.test
15
+ test: <condition>, -> resource.test
16
+ include: <condition>, -> resource.include
17
+ exclude: <condition>, -> resource.exclude
18
+ resourceQuery: <condition>,
19
+ compiler: <condition>,
20
+ issuer: <condition>,
21
+ use: "loader", -> use[0].loader
22
+ loader: <>, -> use[0].loader
23
+ loaders: <>, -> use
24
+ options: {}, -> use[0].options,
25
+ query: {}, -> options
26
+ parser: {},
27
+ use: [
28
+ "loader" -> use[x].loader
29
+ ],
30
+ use: [
31
+ {
32
+ loader: "loader",
33
+ options: {}
34
+ }
35
+ ],
36
+ rules: [
37
+ <rule>
38
+ ],
39
+ oneOf: [
40
+ <rule>
41
+ ]
42
+ }
43
+
44
+ <condition>: /regExp/
45
+ <condition>: function(arg) {}
46
+ <condition>: "starting"
47
+ <condition>: [<condition>] // or
48
+ <condition>: { and: [<condition>] }
49
+ <condition>: { or: [<condition>] }
50
+ <condition>: { not: [<condition>] }
51
+ <condition>: { test: <condition>, include: <condition>, exclude: <condition> }
52
+
53
+
54
+ normalized:
55
+
56
+ {
57
+ resource: function(),
58
+ resourceQuery: function(),
59
+ compiler: function(),
60
+ issuer: function(),
61
+ use: [
62
+ {
63
+ loader: string,
64
+ options: string,
65
+ <any>: <any>
66
+ }
67
+ ],
68
+ rules: [<rule>],
69
+ oneOf: [<rule>],
70
+ <any>: <any>,
71
+ }
72
+
73
+ */
74
+
75
+ "use strict";
76
+
77
+ const notMatcher = matcher => {
78
+ return function(str) {
79
+ return !matcher(str);
80
+ };
81
+ };
82
+
83
+ const orMatcher = items => {
84
+ return function(str) {
85
+ for (let i = 0; i < items.length; i++) {
86
+ if (items[i](str)) return true;
87
+ }
88
+ return false;
89
+ };
90
+ };
91
+
92
+ const andMatcher = items => {
93
+ return function(str) {
94
+ for (let i = 0; i < items.length; i++) {
95
+ if (!items[i](str)) return false;
96
+ }
97
+ return true;
98
+ };
99
+ };
100
+
101
+ module.exports = class RuleSet {
102
+ constructor(rules) {
103
+ this.references = Object.create(null);
104
+ this.rules = RuleSet.normalizeRules(rules, this.references, "ref-");
105
+ }
106
+
107
+ static normalizeRules(rules, refs, ident) {
108
+ if (Array.isArray(rules)) {
109
+ return rules.map((rule, idx) => {
110
+ return RuleSet.normalizeRule(rule, refs, `${ident}-${idx}`);
111
+ });
112
+ } else if (rules) {
113
+ return [RuleSet.normalizeRule(rules, refs, ident)];
114
+ } else {
115
+ return [];
116
+ }
117
+ }
118
+
119
+ static normalizeRule(rule, refs, ident) {
120
+ if (typeof rule === "string") {
121
+ return {
122
+ use: [
123
+ {
124
+ loader: rule
125
+ }
126
+ ]
127
+ };
128
+ }
129
+ if (!rule) {
130
+ throw new Error("Unexcepted null when object was expected as rule");
131
+ }
132
+ if (typeof rule !== "object") {
133
+ throw new Error(
134
+ "Unexcepted " +
135
+ typeof rule +
136
+ " when object was expected as rule (" +
137
+ rule +
138
+ ")"
139
+ );
140
+ }
141
+
142
+ const newRule = {};
143
+ let useSource;
144
+ let resourceSource;
145
+ let condition;
146
+
147
+ const checkUseSource = newSource => {
148
+ if (useSource && useSource !== newSource) {
149
+ throw new Error(
150
+ RuleSet.buildErrorMessage(
151
+ rule,
152
+ new Error(
153
+ "Rule can only have one result source (provided " +
154
+ newSource +
155
+ " and " +
156
+ useSource +
157
+ ")"
158
+ )
159
+ )
160
+ );
161
+ }
162
+ useSource = newSource;
163
+ };
164
+
165
+ const checkResourceSource = newSource => {
166
+ if (resourceSource && resourceSource !== newSource) {
167
+ throw new Error(
168
+ RuleSet.buildErrorMessage(
169
+ rule,
170
+ new Error(
171
+ "Rule can only have one resource source (provided " +
172
+ newSource +
173
+ " and " +
174
+ resourceSource +
175
+ ")"
176
+ )
177
+ )
178
+ );
179
+ }
180
+ resourceSource = newSource;
181
+ };
182
+
183
+ if (rule.test || rule.include || rule.exclude) {
184
+ checkResourceSource("test + include + exclude");
185
+ condition = {
186
+ test: rule.test,
187
+ include: rule.include,
188
+ exclude: rule.exclude
189
+ };
190
+ try {
191
+ newRule.resource = RuleSet.normalizeCondition(condition);
192
+ } catch (error) {
193
+ throw new Error(RuleSet.buildErrorMessage(condition, error));
194
+ }
195
+ }
196
+
197
+ if (rule.resource) {
198
+ checkResourceSource("resource");
199
+ try {
200
+ newRule.resource = RuleSet.normalizeCondition(rule.resource);
201
+ } catch (error) {
202
+ throw new Error(RuleSet.buildErrorMessage(rule.resource, error));
203
+ }
204
+ }
205
+
206
+ if (rule.resourceQuery) {
207
+ try {
208
+ newRule.resourceQuery = RuleSet.normalizeCondition(rule.resourceQuery);
209
+ } catch (error) {
210
+ throw new Error(RuleSet.buildErrorMessage(rule.resourceQuery, error));
211
+ }
212
+ }
213
+
214
+ if (rule.compiler) {
215
+ try {
216
+ newRule.compiler = RuleSet.normalizeCondition(rule.compiler);
217
+ } catch (error) {
218
+ throw new Error(RuleSet.buildErrorMessage(rule.compiler, error));
219
+ }
220
+ }
221
+
222
+ if (rule.issuer) {
223
+ try {
224
+ newRule.issuer = RuleSet.normalizeCondition(rule.issuer);
225
+ } catch (error) {
226
+ throw new Error(RuleSet.buildErrorMessage(rule.issuer, error));
227
+ }
228
+ }
229
+
230
+ if (rule.loader && rule.loaders) {
231
+ throw new Error(
232
+ RuleSet.buildErrorMessage(
233
+ rule,
234
+ new Error(
235
+ "Provided loader and loaders for rule (use only one of them)"
236
+ )
237
+ )
238
+ );
239
+ }
240
+
241
+ const loader = rule.loaders || rule.loader;
242
+ if (typeof loader === "string" && !rule.options && !rule.query) {
243
+ checkUseSource("loader");
244
+ newRule.use = RuleSet.normalizeUse(loader.split("!"), ident);
245
+ } else if (typeof loader === "string" && (rule.options || rule.query)) {
246
+ checkUseSource("loader + options/query");
247
+ newRule.use = RuleSet.normalizeUse(
248
+ {
249
+ loader: loader,
250
+ options: rule.options,
251
+ query: rule.query
252
+ },
253
+ ident
254
+ );
255
+ } else if (loader && (rule.options || rule.query)) {
256
+ throw new Error(
257
+ RuleSet.buildErrorMessage(
258
+ rule,
259
+ new Error(
260
+ "options/query cannot be used with loaders (use options for each array item)"
261
+ )
262
+ )
263
+ );
264
+ } else if (loader) {
265
+ checkUseSource("loaders");
266
+ newRule.use = RuleSet.normalizeUse(loader, ident);
267
+ } else if (rule.options || rule.query) {
268
+ throw new Error(
269
+ RuleSet.buildErrorMessage(
270
+ rule,
271
+ new Error(
272
+ "options/query provided without loader (use loader + options)"
273
+ )
274
+ )
275
+ );
276
+ }
277
+
278
+ if (rule.use) {
279
+ checkUseSource("use");
280
+ newRule.use = RuleSet.normalizeUse(rule.use, ident);
281
+ }
282
+
283
+ if (rule.rules) {
284
+ newRule.rules = RuleSet.normalizeRules(
285
+ rule.rules,
286
+ refs,
287
+ `${ident}-rules`
288
+ );
289
+ }
290
+
291
+ if (rule.oneOf) {
292
+ newRule.oneOf = RuleSet.normalizeRules(
293
+ rule.oneOf,
294
+ refs,
295
+ `${ident}-oneOf`
296
+ );
297
+ }
298
+
299
+ const keys = Object.keys(rule).filter(key => {
300
+ return ![
301
+ "resource",
302
+ "resourceQuery",
303
+ "compiler",
304
+ "test",
305
+ "include",
306
+ "exclude",
307
+ "issuer",
308
+ "loader",
309
+ "options",
310
+ "query",
311
+ "loaders",
312
+ "use",
313
+ "rules",
314
+ "oneOf"
315
+ ].includes(key);
316
+ });
317
+ for (const key of keys) {
318
+ newRule[key] = rule[key];
319
+ }
320
+
321
+ if (Array.isArray(newRule.use)) {
322
+ for (const item of newRule.use) {
323
+ if (item.ident) {
324
+ refs[item.ident] = item.options;
325
+ }
326
+ }
327
+ }
328
+
329
+ return newRule;
330
+ }
331
+
332
+ static buildErrorMessage(condition, error) {
333
+ const conditionAsText = JSON.stringify(
334
+ condition,
335
+ (key, value) => {
336
+ return value === undefined ? "undefined" : value;
337
+ },
338
+ 2
339
+ );
340
+ return error.message + " in " + conditionAsText;
341
+ }
342
+
343
+ static normalizeUse(use, ident) {
344
+ if (typeof use === "function") {
345
+ return data => RuleSet.normalizeUse(use(data), ident);
346
+ }
347
+ if (Array.isArray(use)) {
348
+ return use
349
+ .map((item, idx) => RuleSet.normalizeUse(item, `${ident}-${idx}`))
350
+ .reduce((arr, items) => arr.concat(items), []);
351
+ }
352
+ return [RuleSet.normalizeUseItem(use, ident)];
353
+ }
354
+
355
+ static normalizeUseItemString(useItemString) {
356
+ const idx = useItemString.indexOf("?");
357
+ if (idx >= 0) {
358
+ return {
359
+ loader: useItemString.substr(0, idx),
360
+ options: useItemString.substr(idx + 1)
361
+ };
362
+ }
363
+ return {
364
+ loader: useItemString,
365
+ options: undefined
366
+ };
367
+ }
368
+
369
+ static normalizeUseItem(item, ident) {
370
+ if (typeof item === "string") {
371
+ return RuleSet.normalizeUseItemString(item);
372
+ }
373
+
374
+ const newItem = {};
375
+
376
+ if (item.options && item.query) {
377
+ throw new Error("Provided options and query in use");
378
+ }
379
+
380
+ if (!item.loader) {
381
+ throw new Error("No loader specified");
382
+ }
383
+
384
+ newItem.options = item.options || item.query;
385
+
386
+ if (typeof newItem.options === "object" && newItem.options) {
387
+ if (newItem.options.ident) {
388
+ newItem.ident = newItem.options.ident;
389
+ } else {
390
+ newItem.ident = ident;
391
+ }
392
+ }
393
+
394
+ const keys = Object.keys(item).filter(function(key) {
395
+ return !["options", "query"].includes(key);
396
+ });
397
+
398
+ for (const key of keys) {
399
+ newItem[key] = item[key];
400
+ }
401
+
402
+ return newItem;
403
+ }
404
+
405
+ static normalizeCondition(condition) {
406
+ if (!condition) throw new Error("Expected condition but got falsy value");
407
+ if (typeof condition === "string") {
408
+ return str => str.indexOf(condition) === 0;
409
+ }
410
+ if (typeof condition === "function") {
411
+ return condition;
412
+ }
413
+ if (condition instanceof RegExp) {
414
+ return condition.test.bind(condition);
415
+ }
416
+ if (Array.isArray(condition)) {
417
+ const items = condition.map(c => RuleSet.normalizeCondition(c));
418
+ return orMatcher(items);
419
+ }
420
+ if (typeof condition !== "object") {
421
+ throw Error(
422
+ "Unexcepted " +
423
+ typeof condition +
424
+ " when condition was expected (" +
425
+ condition +
426
+ ")"
427
+ );
428
+ }
429
+
430
+ const matchers = [];
431
+ Object.keys(condition).forEach(key => {
432
+ const value = condition[key];
433
+ switch (key) {
434
+ case "or":
435
+ case "include":
436
+ case "test":
437
+ if (value) matchers.push(RuleSet.normalizeCondition(value));
438
+ break;
439
+ case "and":
440
+ if (value) {
441
+ const items = value.map(c => RuleSet.normalizeCondition(c));
442
+ matchers.push(andMatcher(items));
443
+ }
444
+ break;
445
+ case "not":
446
+ case "exclude":
447
+ if (value) {
448
+ const matcher = RuleSet.normalizeCondition(value);
449
+ matchers.push(notMatcher(matcher));
450
+ }
451
+ break;
452
+ default:
453
+ throw new Error("Unexcepted property " + key + " in condition");
454
+ }
455
+ });
456
+ if (matchers.length === 0) {
457
+ throw new Error("Excepted condition but got " + condition);
458
+ }
459
+ if (matchers.length === 1) {
460
+ return matchers[0];
461
+ }
462
+ return andMatcher(matchers);
463
+ }
464
+
465
+ exec(data) {
466
+ const result = [];
467
+ this._run(
468
+ data,
469
+ {
470
+ rules: this.rules
471
+ },
472
+ result
473
+ );
474
+ return result;
475
+ }
476
+
477
+ _run(data, rule, result) {
478
+ // test conditions
479
+ if (rule.resource && !data.resource) return false;
480
+ if (rule.resourceQuery && !data.resourceQuery) return false;
481
+ if (rule.compiler && !data.compiler) return false;
482
+ if (rule.issuer && !data.issuer) return false;
483
+ if (rule.resource && !rule.resource(data.resource)) return false;
484
+ if (data.issuer && rule.issuer && !rule.issuer(data.issuer)) return false;
485
+ if (
486
+ data.resourceQuery &&
487
+ rule.resourceQuery &&
488
+ !rule.resourceQuery(data.resourceQuery)
489
+ ) {
490
+ return false;
491
+ }
492
+ if (data.compiler && rule.compiler && !rule.compiler(data.compiler)) {
493
+ return false;
494
+ }
495
+
496
+ // apply
497
+ const keys = Object.keys(rule).filter(key => {
498
+ return ![
499
+ "resource",
500
+ "resourceQuery",
501
+ "compiler",
502
+ "issuer",
503
+ "rules",
504
+ "oneOf",
505
+ "use",
506
+ "enforce"
507
+ ].includes(key);
508
+ });
509
+ for (const key of keys) {
510
+ result.push({
511
+ type: key,
512
+ value: rule[key]
513
+ });
514
+ }
515
+
516
+ if (rule.use) {
517
+ const process = use => {
518
+ if (typeof use === "function") {
519
+ process(use(data));
520
+ } else if (Array.isArray(use)) {
521
+ use.forEach(process);
522
+ } else {
523
+ result.push({
524
+ type: "use",
525
+ value: use,
526
+ enforce: rule.enforce
527
+ });
528
+ }
529
+ };
530
+ process(rule.use);
531
+ }
532
+
533
+ if (rule.rules) {
534
+ for (let i = 0; i < rule.rules.length; i++) {
535
+ this._run(data, rule.rules[i], result);
536
+ }
537
+ }
538
+
539
+ if (rule.oneOf) {
540
+ for (let i = 0; i < rule.oneOf.length; i++) {
541
+ if (this._run(data, rule.oneOf[i], result)) break;
542
+ }
543
+ }
544
+
545
+ return true;
546
+ }
547
+
548
+ findOptionsByIdent(ident) {
549
+ const options = this.references[ident];
550
+ if (!options) {
551
+ throw new Error("Can't find options with ident '" + ident + "'");
552
+ }
553
+ return options;
554
+ }
555
+ };