@kontur.candy/tools 2.160.0-linux-compat.1 → 2.160.0-linux-compat.3

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 (41) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/distr/Common/AutoValidationUtils.js +9 -0
  3. package/distr/Common/CandyApiClient/CandyApiClient.js +29 -14
  4. package/distr/Common/CandyApiClient/DigestApiClient/Decorators/DigestApiClientWithCache.js +8 -20
  5. package/distr/Common/CandyApiClient/DigestApiClient/Decorators/DigestApiClientWithDebouncedBatching.js +4 -9
  6. package/distr/Common/CandyApiClient/DigestApiClient/DigestApiClient.js +8 -27
  7. package/distr/Common/CandyApiClient/DigestApiClient/Fakes/FakeDigestApiClient.js +8 -10
  8. package/distr/Common/CandyApiClient/DigestApiClient/IDigestApiClient.js +1 -1
  9. package/distr/Common/CandyApiClient/DigestApiClient/TestDigestApiClient.js +4 -8
  10. package/distr/Common/CandyApiClient/FakeCandyApiClient.js +18 -14
  11. package/distr/Common/CandyApiClient/ICandyApiClient.js +1 -1
  12. package/distr/Common/CandyApiClient/Types/ChangeSet/ServerChangeSet.js +1 -1
  13. package/distr/Common/CandyApiClient/Types/DraftActions/FileProperties.js +1 -1
  14. package/distr/Common/EndPoints.js +4 -2
  15. package/distr/Common/FSPrinterClient/FSPrinterClient.js +136 -0
  16. package/distr/Common/FSPrinterClient/FakeFSPrinterClient.js +19 -0
  17. package/distr/Common/FSPrinterClient/IFSPrinterClient.js +44 -0
  18. package/distr/Common/ModelPath/AbsoluteModelFieldPath.js +53 -0
  19. package/distr/Common/ModelPath/BuildIterationSequence.js +20 -1
  20. package/distr/Common/ModelPath/Map/Map2.js +14 -1
  21. package/distr/Common/ModelPath/ModelPath.js +41 -69
  22. package/distr/Common/ModelPath/ModelPathHelper.js +23 -1
  23. package/distr/Common/ModelPath/Set/Set2.js +7 -2
  24. package/distr/Common/PicklistApiClient/IPicklistApiClient.js +6 -0
  25. package/distr/Common/PicklistApiClient/PicklistApiClient.js +30 -0
  26. package/distr/Common/PicklistApiClient/PicklistRequestV2Builder.js +34 -0
  27. package/distr/Common/PicklistApiClient/Serializers/DigestFilterColumnSerializer.js +53 -0
  28. package/distr/Common/PicklistApiClient/Serializers/DigestLogicalFilterSerializer.js +37 -0
  29. package/distr/Common/PicklistApiClient/Types/PicklistRequestV2.js +6 -0
  30. package/distr/Common/PicklistApiClient/Types/PicklistResultV2.js +6 -0
  31. package/distr/Common/StringArrayKey.js +4 -2
  32. package/distr/Common/getRngSchemaFilename.js +10 -4
  33. package/distr/Tools/src/FormWebpackConfiguration/CacheAssetsPlugin.js +3 -2
  34. package/distr/Tools/src/LocalServerFrontEndDist/index.js +1 -1
  35. package/distr/Tools/src/LocalServerFrontEndDist/index.js.map +1 -1
  36. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js +182 -171
  37. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.js.map +1 -1
  38. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js +192 -192
  39. package/distr/Tools/src/StaticFilesForProductionResourcesDir/client.min.js.map +1 -1
  40. package/package.json +2 -2
  41. package/distr/Common/CandyApiClient/DigestApiClient/Types/DigestResponse.js +0 -6
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.PathTokens = exports.ModelPathImpl = exports.AbsoluteModelFieldPath = void 0;
6
+ exports.PathTokens = exports.ModelPathImpl = void 0;
7
7
  exports.convertToAbsoluteModelPath = convertToAbsoluteModelPath;
8
8
  exports.convertToLegacyPath = convertToLegacyPath;
9
9
  exports.createAbsolute = createAbsolute;
@@ -20,7 +20,6 @@ exports.isModelPath = isModelPath;
20
20
  exports.joinModelPaths = joinModelPaths;
21
21
  var _IterableUtils = require("../IterableUtils");
22
22
  var _TypingUtils = require("../TypingUtils");
23
- var _hashUtils = require("../hashUtils");
24
23
  var _EachCurrentCollision = require("./EachCurrentCollision");
25
24
  var _ModelPathBuilder = require("./ModelPathBuilder");
26
25
  var _PathMatcher = require("./PathMatcher");
@@ -36,6 +35,9 @@ class PathTokens {
36
35
  static isInstanceToken(part) {
37
36
  return typeof part === "string" && /^\d+$/i.test(part);
38
37
  }
38
+ static isInstanceTokenOrInstancesSpec(part) {
39
+ return typeof part === "string" && (/^\d+$/i.test(part) || /^\[(\d+\,?)+\]$/i.test(part));
40
+ }
39
41
  }
40
42
  exports.PathTokens = PathTokens;
41
43
  PathTokens.each = EachSymbol;
@@ -140,48 +142,6 @@ function joinModelPaths(...parts) {
140
142
  }
141
143
  return new ModelPathImpl(resultParts, absolute);
142
144
  }
143
- class AbsoluteModelFieldPath {
144
- constructor(path, fieldName) {
145
- this.path = void 0;
146
- this.field = void 0;
147
- this.path = path;
148
- this.field = fieldName;
149
- }
150
- getHash() {
151
- return this.path.getHash() + (0, _hashUtils.getSimpleHashByString)(this.field);
152
- }
153
- isEquals(modelPath, eachCurrentCollision = _EachCurrentCollision.EachCurrentCollision.AreSame) {
154
- return this.path.isEquals(modelPath.path, eachCurrentCollision) && this.field === modelPath.field;
155
- }
156
- static createFromString(pathWithFieldName) {
157
- if (pathWithFieldName.endsWith(".$errorCount")) {
158
- return new AbsoluteModelFieldPath(createAbsolute(pathWithFieldName.replace(".$errorCount", "")), "$errorCount");
159
- }
160
- if (pathWithFieldName.endsWith(".$warningCount")) {
161
- return new AbsoluteModelFieldPath(createAbsolute(pathWithFieldName.replace(".$warningCount", "")), "$warningCount");
162
- }
163
- return new AbsoluteModelFieldPath(createAbsolute(pathWithFieldName), "value");
164
- }
165
- static createFromMask(pathWithFieldName, multiplicitySymbol) {
166
- if (pathWithFieldName.endsWith(".$errorCount")) {
167
- return new AbsoluteModelFieldPath(createAbsoluteFromMask(pathWithFieldName.replace(".$errorCount", ""), multiplicitySymbol), "$errorCount");
168
- }
169
- if (pathWithFieldName.endsWith(".$warningCount")) {
170
- return new AbsoluteModelFieldPath(createAbsoluteFromMask(pathWithFieldName.replace(".$warningCount", ""), multiplicitySymbol), "$warningCount");
171
- }
172
- if (pathWithFieldName.endsWith(".errorsCount")) {
173
- return new AbsoluteModelFieldPath(createAbsoluteFromMask(pathWithFieldName.replace(".errorsCount", ""), multiplicitySymbol), "errorsCount");
174
- }
175
- if (pathWithFieldName.endsWith(".warningsCount")) {
176
- return new AbsoluteModelFieldPath(createAbsoluteFromMask(pathWithFieldName.replace(".warningsCount", ""), multiplicitySymbol), "warningsCount");
177
- }
178
- return new AbsoluteModelFieldPath(createAbsoluteFromMask(pathWithFieldName, multiplicitySymbol), "value");
179
- }
180
- toString() {
181
- return `${this.path.toLegacyPath()}.${this.field}`;
182
- }
183
- }
184
- exports.AbsoluteModelFieldPath = AbsoluteModelFieldPath;
185
145
  function isAllTokensResolved(tokens) {
186
146
  // Я что-то немогу сообразить как тут всё строго написать...
187
147
  // @ts-expect-error
@@ -192,6 +152,7 @@ class ModelPathImpl {
192
152
  this.tokens = void 0;
193
153
  this.absolute = void 0;
194
154
  this.legacyPath = void 0;
155
+ this.cachedHash = void 0;
195
156
  this.tokens = pathParts.filter(x => x !== "");
196
157
  this.absolute = absolute;
197
158
  }
@@ -245,6 +206,9 @@ class ModelPathImpl {
245
206
  isContainCurrentIteration() {
246
207
  return this.tokens.some(x => x === PathTokens.current);
247
208
  }
209
+ isContainCurrentOrEachIteration() {
210
+ return this.tokens.some(x => x === PathTokens.current || x === PathTokens.each);
211
+ }
248
212
  getLastListPath() {
249
213
  if (!this.isContainIteration()) {
250
214
  throw new Error("Path must contain iteration");
@@ -259,6 +223,10 @@ class ModelPathImpl {
259
223
  const lastItem = _IterableUtils.IterUtils.last(this.tokens);
260
224
  return lastItem == PathTokens.each;
261
225
  }
226
+ isEndsWithCurrentIteration() {
227
+ const lastItem = _IterableUtils.IterUtils.last(this.tokens);
228
+ return lastItem == PathTokens.current;
229
+ }
262
230
  isAbsolute() {
263
231
  return this.absolute;
264
232
  }
@@ -284,32 +252,35 @@ class ModelPathImpl {
284
252
  * Всегда целое положительное беззнаковое 32-битное число
285
253
  */
286
254
  getHash(eachCurrentCollision = _EachCurrentCollision.EachCurrentCollision.AreSame) {
287
- let hash = 5381;
288
- for (const token of (0, _IterableUtils.reverseArray)(this.tokens)) {
289
- let currentStr;
290
- if (PathTokens.isSimpleToken(token)) {
291
- currentStr = token;
292
- } else {
293
- if (eachCurrentCollision === _EachCurrentCollision.EachCurrentCollision.AreDifferent) {
294
- currentStr = token === PathTokens.each ? "*" : "!";
255
+ if (this.cachedHash == undefined) {
256
+ let hash = 5381;
257
+ for (const token of (0, _IterableUtils.reverseArray)(this.tokens)) {
258
+ let currentStr;
259
+ if (PathTokens.isSimpleToken(token)) {
260
+ currentStr = token;
295
261
  } else {
296
- currentStr = "*";
262
+ if (eachCurrentCollision === _EachCurrentCollision.EachCurrentCollision.AreDifferent) {
263
+ currentStr = token === PathTokens.each ? "*" : "!";
264
+ } else {
265
+ currentStr = "*";
266
+ }
267
+ }
268
+ let stringIndex = currentStr.length;
269
+ while (stringIndex) {
270
+ // tslint:disable-next-line:no-bitwise
271
+ hash = hash * 33 ^ currentStr.charCodeAt(--stringIndex);
297
272
  }
298
273
  }
299
- let stringIndex = currentStr.length;
300
- while (stringIndex) {
301
- // tslint:disable-next-line:no-bitwise
302
- hash = hash * 33 ^ currentStr.charCodeAt(--stringIndex);
303
- }
304
- }
305
274
 
306
- /*
307
- tslint:disable-next-line:no-bitwise
308
- JavaScript does bitwise operations (like XOR, above) on 32-bit signed
309
- integers. Since we want the results to be always positive, convert the
310
- signed int to an unsigned by doing an unsigned bitshift.
311
- */
312
- return hash >>> 0;
275
+ /*
276
+ tslint:disable-next-line:no-bitwise
277
+ JavaScript does bitwise operations (like XOR, above) on 32-bit signed
278
+ integers. Since we want the results to be always positive, convert the
279
+ signed int to an unsigned by doing an unsigned bitshift.
280
+ */
281
+ this.cachedHash = hash >>> 0;
282
+ }
283
+ return this.cachedHash;
313
284
  }
314
285
  isIncludes(modelPath) {
315
286
  const targetTokens = modelPath.getPathPartsAsArray();
@@ -449,7 +420,7 @@ class ModelPathImpl {
449
420
  // @ts-expect-error
450
421
  return result.toPath();
451
422
  }
452
- applyInstancesDirty(instances) {
423
+ applyInstancesDirty(instances, fillWithMultiplicityIfHasNoInstance) {
453
424
  if (this.isResolved() || instances.length === 0) {
454
425
  return this;
455
426
  }
@@ -458,7 +429,8 @@ class ModelPathImpl {
458
429
  for (const token of this.getPathParts()) {
459
430
  if (PathTokens.isMultiToken(token) && instanceCounter < instances.length) {
460
431
  var _instances$instanceCo;
461
- result.append((_instances$instanceCo = instances[instanceCounter]) !== null && _instances$instanceCo !== void 0 ? _instances$instanceCo : (0, _TypingUtils.reject)());
432
+ const instanceOrEach = (_instances$instanceCo = instances[instanceCounter]) !== null && _instances$instanceCo !== void 0 ? _instances$instanceCo : fillWithMultiplicityIfHasNoInstance == true ? PathTokens.each : (0, _TypingUtils.reject)();
433
+ result.append(instanceOrEach);
462
434
  instanceCounter++;
463
435
  } else {
464
436
  result.append(token);
@@ -482,4 +454,4 @@ class ModelPathImpl {
482
454
  }
483
455
  }
484
456
  exports.ModelPathImpl = ModelPathImpl;
485
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_IterableUtils","require","_TypingUtils","_hashUtils","_EachCurrentCollision","_ModelPathBuilder","_PathMatcher","EachSymbol","Symbol","for","CurrentSymbol","PathTokens","isMultiToken","part","each","current","isSimpleToken","isInstanceToken","test","exports","isModelPath","path","ModelPathImpl","convertToLegacyPath","toLegacyPath","convertToAbsoluteModelPath","createAbsoluteFromMask","emptyModelPath","emptyAbsoluteModelPath","createModelPath","absolute","partPartStrings","split","ensurePlainPathPartsDoesNotContainMultiplicity","startsWith","slice","createFromMask","multiplicitySymbol","map","x","parts","some","Error","createAbsolute","createRelativeResolvedModelPath","createAbsoluteFromTokens","tokens","createAbsoluteResolvedFromTokens","createRelativeFromTokens","joinModelPaths","resultParts","joinItem","push","isAbsolute","getPathPartsAsArray","Array","isArray","AbsoluteModelFieldPath","constructor","fieldName","field","getHash","getSimpleHashByString","isEquals","modelPath","eachCurrentCollision","EachCurrentCollision","AreSame","createFromString","pathWithFieldName","endsWith","replace","toString","isAllTokensResolved","every","pathParts","legacyPath","filter","resolved","getPathParts","getSimpleTokensStrict","token","getSimpleTokensAsArrayStrict","joinWith","isResolved","resolveAll","instance","isContainIteration","isContainCurrentIteration","getLastListPath","lastIterationIndex","lastIndexOf","isEndsWithIteration","lastItem","IterUtils","last","length","pathPartToString","join","_this$legacyPath","Iterator","from","zip","t1","t2","hash","reverseArray","currentStr","AreDifferent","stringIndex","charCodeAt","isIncludes","targetTokens","i","leftPart","rightPart","isFinite","Number","getIterationRank","count","isEmpty","matchFor","PathMatcher","match","splitByMultiplicity","lastSimpleParts","ModelPathBuilder","append","empty","toResolvedPath","normalize","resultTokens","pathPart","pop","toCurrentIteration","toEachIteration","toAbsolute","getAllParentPaths","result","skipLast","toPath","trimLastStarIfLastToken","undefined","getParentPath","applyInstancesDirty","instances","instanceCounter","_instances$instanceCo","reject","ensureAndGetString"],"sources":["../../../../Common/ModelPath/ModelPath.ts"],"sourcesContent":["import { BindingPath, ViewModelFieldName } from \"../../Engine/src/Engine/Core/CoreTypes\";\nimport { count, IterUtils, reverseArray } from \"../IterableUtils\";\nimport { ensureAndGetString, reject } from \"../TypingUtils\";\nimport { getSimpleHashByString } from \"../hashUtils\";\n\nimport { EachCurrentCollision } from \"./EachCurrentCollision\";\nimport { ModelPathBuilder } from \"./ModelPathBuilder\";\nimport { PathMatcher, PathMatching } from \"./PathMatcher\";\nimport { IEquatable } from \"./IEquatable\";\n\nconst EachSymbol = Symbol.for(\"__EACH__\");\nconst CurrentSymbol = Symbol.for(\"__CURRENT__\");\n\nexport class PathTokens {\n    public static each: typeof EachSymbol = EachSymbol;\n    public static current: typeof CurrentSymbol = CurrentSymbol;\n\n    public static isMultiToken(part: undefined | PathToken): part is typeof EachSymbol | typeof CurrentSymbol {\n        return part === PathTokens.each || part === PathTokens.current;\n    }\n\n    public static isSimpleToken(part: undefined | PathToken): part is string {\n        return typeof part === \"string\";\n    }\n\n    public static isInstanceToken(part: undefined | PathToken): part is string {\n        return typeof part === \"string\" && /^\\d+$/i.test(part);\n    }\n}\n\nexport type SimplePathToken = string;\n\nexport type PathToken = SimplePathToken | typeof EachSymbol | typeof CurrentSymbol;\n\nexport function isModelPath(path: BindingPath | ModelPath | unknown): path is ModelPath {\n    return typeof path !== \"string\" && path instanceof ModelPathImpl;\n}\n\nexport function convertToLegacyPath(path: BindingPath | ModelPath): BindingPath {\n    return isModelPath(path) ? path.toLegacyPath() : path;\n}\n\nexport function convertToAbsoluteModelPath<R extends boolean, A extends boolean>(\n    path: BindingPath | IModelPath<R, A>\n): IModelPath<R, true>;\nexport function convertToAbsoluteModelPath(path: BindingPath | AbsoluteModelPath): AbsoluteModelPath {\n    return isModelPath(path) ? path : createAbsoluteFromMask(path, PathTokens.each);\n}\n\nexport function emptyModelPath(): RelativeResolvedModelPath {\n    return new ModelPathImpl<true, false>([], false);\n}\n\nexport function emptyAbsoluteModelPath(): AbsoluteResolvedModelPath {\n    return new ModelPathImpl<true, true>([], true);\n}\n\nexport function createModelPath(path: string, absolute: true): AbsoluteResolvedModelPath;\nexport function createModelPath(path: string, absolute: false): RelativeResolvedModelPath;\nexport function createModelPath(path: string, absolute: \"auto\"): ResolvedModelPath;\nexport function createModelPath(path: string, absolute: boolean | \"auto\"): ResolvedModelPath {\n    const partPartStrings = path.split(\"/\");\n    ensurePlainPathPartsDoesNotContainMultiplicity(partPartStrings);\n    if (absolute === \"auto\") {\n        if (path.startsWith(\"/\")) {\n            return new ModelPathImpl<true, true>(partPartStrings.slice(1), true);\n        } else {\n            return new ModelPathImpl<true, false>(partPartStrings, false);\n        }\n    }\n    if (absolute && path.startsWith(\"/\")) {\n        return new ModelPathImpl<true, true>(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl<true, boolean>(partPartStrings, absolute);\n}\n\nexport function createFromMask(path: string, absolute: true, multiplicitySymbol: PathToken): AbsoluteModelPath;\nexport function createFromMask(path: string, absolute: false, multiplicitySymbol: PathToken): ResolvedModelPath;\nexport function createFromMask(path: string, absolute: \"auto\", multiplicitySymbol: PathToken): ModelPath;\nexport function createFromMask(path: string, absolute: boolean | \"auto\", multiplicitySymbol: PathToken): ModelPath {\n    const partPartStrings = path.split(\"/\").map(x => (x === \"*\" ? multiplicitySymbol : x));\n    if (absolute === \"auto\") {\n        if (path.startsWith(\"/\")) {\n            return new ModelPathImpl(partPartStrings.slice(1), true);\n        } else {\n            return new ModelPathImpl(partPartStrings, false);\n        }\n    }\n    if (absolute && path.startsWith(\"/\")) {\n        return new ModelPathImpl(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl(partPartStrings, absolute);\n}\n\nexport function createAbsoluteFromMask(path: string, multiplicitySymbol: PathToken): AbsoluteModelPath {\n    const partPartStrings = path.split(\"/\").map(x => (x === \"*\" ? multiplicitySymbol : x));\n    if (path.startsWith(\"/\")) {\n        return new ModelPathImpl(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl(partPartStrings, true);\n}\n\nfunction ensurePlainPathPartsDoesNotContainMultiplicity(parts: string[]): void {\n    if (parts.some(x => x === \"*\")) {\n        throw new Error(\"Path must not contain * symbol\");\n    }\n}\n\nexport function createAbsolute(path: string): AbsoluteResolvedModelPath {\n    const partPartStrings = path.split(\"/\");\n    ensurePlainPathPartsDoesNotContainMultiplicity(partPartStrings);\n    if (path.startsWith(\"/\")) {\n        return new ModelPathImpl<true, true>(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl<true, true>(partPartStrings, true);\n}\n\nexport function createRelativeResolvedModelPath(path: string): RelativeResolvedModelPath {\n    const partPartStrings = path.split(\"/\");\n    ensurePlainPathPartsDoesNotContainMultiplicity(partPartStrings);\n    return new ModelPathImpl<true, false>(partPartStrings, false);\n}\n\nexport function createAbsoluteFromTokens(tokens: PathToken[]): AbsoluteModelPath {\n    return new ModelPathImpl<false, true>(tokens, true);\n}\n\nexport function createAbsoluteResolvedFromTokens(tokens: string[]): AbsoluteResolvedModelPath {\n    ensurePlainPathPartsDoesNotContainMultiplicity(tokens);\n    return new ModelPathImpl<true, true>(tokens, true);\n}\n\nexport function createRelativeFromTokens(tokens: readonly string[]): RelativeResolvedModelPath;\nexport function createRelativeFromTokens(tokens: readonly PathToken[]): RelativeModelPath;\nexport function createRelativeFromTokens(tokens: readonly PathToken[]): RelativeModelPath {\n    return new ModelPathImpl<false, false>(tokens, false);\n}\n\nexport function joinModelPaths(...parts: Array<ModelPath | PathToken | PathToken[]>): ModelPath {\n    let absolute = false;\n    let resultParts: PathToken[] = [];\n    for (const joinItem of parts) {\n        if (typeof joinItem === \"string\") {\n            resultParts.push(joinItem);\n        } else if (isModelPath(joinItem)) {\n            if (joinItem.isAbsolute()) {\n                absolute = true;\n                resultParts = [...joinItem.getPathPartsAsArray()];\n            } else {\n                resultParts.push(...joinItem.getPathPartsAsArray());\n            }\n        } else if (Array.isArray(joinItem)) {\n            resultParts.push(...joinItem);\n        } else if (PathTokens.isMultiToken(joinItem)) {\n            resultParts.push(joinItem);\n        }\n    }\n\n    return new ModelPathImpl(resultParts, absolute);\n}\n\nexport class AbsoluteModelFieldPath implements IEquatable<AbsoluteModelFieldPath> {\n    public readonly path: AbsoluteModelPath;\n    public readonly field: ViewModelFieldName | \"$errorCount\" | \"$warningCount\";\n\n    public constructor(path: AbsoluteModelPath, fieldName: ViewModelFieldName | \"$errorCount\" | \"$warningCount\") {\n        this.path = path;\n        this.field = fieldName;\n    }\n\n    public getHash(): number {\n        return this.path.getHash() + getSimpleHashByString(this.field);\n    }\n\n    public isEquals(\n        modelPath: AbsoluteModelFieldPath,\n        eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreSame\n    ): boolean {\n        return this.path.isEquals(modelPath.path, eachCurrentCollision) && this.field === modelPath.field;\n    }\n\n    public static createFromString(pathWithFieldName: string): AbsoluteModelFieldPath {\n        if (pathWithFieldName.endsWith(\".$errorCount\")) {\n            return new AbsoluteModelFieldPath(\n                createAbsolute(pathWithFieldName.replace(\".$errorCount\", \"\")),\n                \"$errorCount\"\n            );\n        }\n        if (pathWithFieldName.endsWith(\".$warningCount\")) {\n            return new AbsoluteModelFieldPath(\n                createAbsolute(pathWithFieldName.replace(\".$warningCount\", \"\")),\n                \"$warningCount\"\n            );\n        }\n        return new AbsoluteModelFieldPath(createAbsolute(pathWithFieldName), \"value\");\n    }\n\n    public static createFromMask(pathWithFieldName: string, multiplicitySymbol: PathToken): AbsoluteModelFieldPath {\n        if (pathWithFieldName.endsWith(\".$errorCount\")) {\n            return new AbsoluteModelFieldPath(\n                createAbsoluteFromMask(pathWithFieldName.replace(\".$errorCount\", \"\"), multiplicitySymbol),\n                \"$errorCount\"\n            );\n        }\n        if (pathWithFieldName.endsWith(\".$warningCount\")) {\n            return new AbsoluteModelFieldPath(\n                createAbsoluteFromMask(pathWithFieldName.replace(\".$warningCount\", \"\"), multiplicitySymbol),\n                \"$warningCount\"\n            );\n        }\n        if (pathWithFieldName.endsWith(\".errorsCount\")) {\n            return new AbsoluteModelFieldPath(\n                createAbsoluteFromMask(pathWithFieldName.replace(\".errorsCount\", \"\"), multiplicitySymbol),\n                \"errorsCount\"\n            );\n        }\n        if (pathWithFieldName.endsWith(\".warningsCount\")) {\n            return new AbsoluteModelFieldPath(\n                createAbsoluteFromMask(pathWithFieldName.replace(\".warningsCount\", \"\"), multiplicitySymbol),\n                \"warningsCount\"\n            );\n        }\n        return new AbsoluteModelFieldPath(createAbsoluteFromMask(pathWithFieldName, multiplicitySymbol), \"value\");\n    }\n\n    public toString(): string {\n        return `${this.path.toLegacyPath()}.${this.field}`;\n    }\n}\n\nexport interface IModelPath<TResolved extends boolean, TAbsolute extends boolean>\n    extends IEquatable<IModelPath<boolean, boolean>> {\n    readonly resolved: TResolved;\n    readonly absolute: TAbsolute;\n\n    isEquals(modelPath: ModelPath, eachCurrentCollision?: EachCurrentCollision): boolean;\n    getHash(eachCurrentCollision?: EachCurrentCollision): number;\n\n    isResolved(): this is IModelPath<true, TAbsolute>;\n    isAbsolute(): this is IModelPath<TResolved, true>;\n    toAbsolute(): IModelPath<TResolved, true>;\n\n    joinWith(...path: string[]): IModelPath<TResolved, TAbsolute>;\n    joinWith(...path: PathToken[]): IModelPath<boolean, TAbsolute>;\n    joinWith(...path: Array<ResolvedModelPath | string>): IModelPath<TResolved, TAbsolute>;\n    joinWith(...path: Array<AbsoluteResolvedModelPath | string>): IModelPath<TResolved, true>;\n    joinWith(...path: Array<ModelPath | PathToken>): IModelPath<boolean, TAbsolute>;\n\n    getPathParts(): Iterable<PathTokenSpec<TResolved>>;\n    getPathPartsAsArray(): ReadonlyArray<PathTokenSpec<TResolved>>;\n    getSimpleTokensStrict(): Iterable<SimplePathToken>;\n    getSimpleTokensAsArrayStrict(): readonly SimplePathToken[];\n\n    resolveAll(instance: string): ModelPath;\n    isContainIteration(): boolean;\n    isContainCurrentIteration(): boolean;\n    getLastListPath(): PathToken[];\n    isEndsWithIteration(): boolean;\n    isIncludes(modelPath: ModelPath): boolean;\n    getIterationRank(eachCurrentCollision?: EachCurrentCollision): number;\n    isEmpty(): boolean;\n    matchFor(modelPath: ModelPath): PathMatching;\n    splitByMultiplicity(): Iterable<ResolvedModelPath | typeof EachSymbol | typeof CurrentSymbol>;\n    normalize(): IModelPath<TResolved, TAbsolute>;\n    toCurrentIteration(): IModelPath<TResolved, TAbsolute>;\n    toEachIteration(): IModelPath<TResolved, TAbsolute>;\n    getAllParentPaths(): Iterable<ModelPath>;\n    trimLastStarIfLastToken(): IModelPath<TResolved, TAbsolute>;\n    getParentPath(): IModelPath<TResolved, TAbsolute>;\n    applyInstancesDirty(instances: SimplePathToken[]): IModelPath<TResolved, TAbsolute>;\n\n    toString(): string;\n    toLegacyPath(): string;\n}\n\nexport type ModelPath = IModelPath<boolean, boolean>;\nexport type ResolvedModelPath = IModelPath<true, boolean>;\nexport type AbsoluteModelPath = IModelPath<boolean, true>;\nexport type AbsoluteResolvedModelPath = IModelPath<true, true>;\n\nexport type RelativeModelPath = IModelPath<boolean, false>;\nexport type RelativeResolvedModelPath = IModelPath<true, false>;\n\ntype PathTokenSpec<TResolved extends boolean> = TResolved extends true ? string : PathToken;\n\ntype PathTokensSpec<TResolved extends boolean> = Array<PathTokenSpec<TResolved>>;\n\ntype ReadonlyPathTokensSpec<TResolved extends boolean> = ReadonlyArray<PathTokenSpec<TResolved>>;\n\nfunction isAllTokensResolved<TResolved extends boolean>(tokens: ReadonlyPathTokensSpec<TResolved>): TResolved {\n    // Я что-то немогу сообразить как тут всё строго написать...\n    // @ts-expect-error\n    return tokens.every(PathTokens.isSimpleToken);\n}\n\nexport class ModelPathImpl<TResolved extends boolean, TAbsolute extends boolean>\n    implements IEquatable<ModelPath>, IModelPath<TResolved, TAbsolute>\n{\n    private readonly tokens: ReadonlyPathTokensSpec<TResolved>;\n    public readonly absolute: TAbsolute;\n    private legacyPath: undefined | string;\n\n    public constructor(pathParts: ReadonlyPathTokensSpec<TResolved>, absolute: TAbsolute) {\n        this.tokens = pathParts.filter(x => x !== \"\");\n        this.absolute = absolute;\n    }\n\n    public get resolved(): TResolved {\n        return isAllTokensResolved(this.tokens);\n    }\n\n    public getPathParts(): Iterable<PathTokenSpec<TResolved>> {\n        return this.tokens;\n    }\n\n    public getPathPartsAsArray(): ReadonlyArray<PathTokenSpec<TResolved>> {\n        return this.tokens;\n    }\n\n    public *getSimpleTokensStrict(): Iterable<SimplePathToken> {\n        for (const token of this.tokens) {\n            if (!PathTokens.isSimpleToken(token)) {\n                throw new Error(\"Path must not contain spec tokens\");\n            }\n            yield token;\n        }\n    }\n\n    public getSimpleTokensAsArrayStrict(): readonly SimplePathToken[] {\n        for (const token of this.tokens) {\n            if (!PathTokens.isSimpleToken(token)) {\n                throw new Error(\"Path must not contain spec tokens\");\n            }\n        }\n        // Проверка выше гараентирует что будут только SimplePathToken.\n        // Все map и filter убраны для производительности\n        // @ts-ignore\n        return this.tokens;\n    }\n\n    public joinWith(...path: string[]): IModelPath<TResolved, TAbsolute>;\n    public joinWith(...path: PathToken[]): IModelPath<boolean, TAbsolute>;\n    public joinWith(...path: Array<ResolvedModelPath | string>): IModelPath<TResolved, TAbsolute>;\n    public joinWith(...path: Array<AbsoluteResolvedModelPath | string>): IModelPath<TResolved, true>;\n    public joinWith(...path: Array<ModelPath | PathToken>): IModelPath<boolean, TAbsolute>;\n    public joinWith(...path: Array<ModelPath | PathToken>): IModelPath<boolean, boolean> {\n        return joinModelPaths(this, ...path);\n    }\n\n    public isResolved(): this is IModelPath<true, TAbsolute> {\n        return isAllTokensResolved(this.tokens);\n    }\n\n    public resolveAll(instance: string): ModelPath {\n        const tokens = this.tokens.map(token => {\n            if (PathTokens.isSimpleToken(token)) {\n                return token;\n            } else {\n                return instance;\n            }\n        });\n\n        return new ModelPathImpl(tokens, this.absolute);\n    }\n\n    public isContainIteration(): boolean {\n        return this.tokens.some(x => x === PathTokens.each);\n    }\n\n    public isContainCurrentIteration(): boolean {\n        return this.tokens.some(x => x === PathTokens.current);\n    }\n\n    public getLastListPath(): PathToken[] {\n        if (!this.isContainIteration()) {\n            throw new Error(\"Path must contain iteration\");\n        }\n\n        // Проверка выше гарантирует, что будет PathTokens.each\n        // @ts-ignore\n        const lastIterationIndex = this.tokens.lastIndexOf(PathTokens.each);\n        return this.tokens.slice(0, lastIterationIndex);\n    }\n\n    public isEndsWithIteration(): boolean {\n        const lastItem = IterUtils.last(this.tokens);\n        return lastItem == PathTokens.each;\n    }\n\n    public isAbsolute(): this is IModelPath<TResolved, true> {\n        return this.absolute;\n    }\n\n    public toString(): string {\n        if (this.tokens.length === 0) {\n            return \"\";\n        }\n        return (this.absolute ? \"/\" : \"\") + this.tokens.map(x => this.pathPartToString(x)).join(\"/\");\n    }\n\n    public toLegacyPath(): string {\n        return this.legacyPath ?? (this.legacyPath = this.tokens.map(x => this.pathPartToString(x)).join(\"/\"));\n    }\n\n    public isEquals(\n        modelPath: ModelPath,\n        eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreSame\n    ): boolean {\n        if (eachCurrentCollision === EachCurrentCollision.AreSame) {\n            return this.toLegacyPath() === modelPath.toLegacyPath();\n        } else {\n            return (\n                this.isAbsolute() === modelPath.isAbsolute() &&\n                Iterator.from(IterUtils.zip(this.getPathParts(), modelPath.getPathParts())).every(\n                    ([t1, t2]) => t1 === t2\n                )\n            );\n        }\n    }\n\n    /**\n     * Всегда целое положительное беззнаковое 32-битное число\n     */\n    public getHash(eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreSame): number {\n        let hash = 5381;\n        for (const token of reverseArray(this.tokens)) {\n            let currentStr: string;\n            if (PathTokens.isSimpleToken(token)) {\n                currentStr = token;\n            } else {\n                if (eachCurrentCollision === EachCurrentCollision.AreDifferent) {\n                    currentStr = token === PathTokens.each ? \"*\" : \"!\";\n                } else {\n                    currentStr = \"*\";\n                }\n            }\n            let stringIndex = currentStr.length;\n            while (stringIndex) {\n                // tslint:disable-next-line:no-bitwise\n                hash = (hash * 33) ^ currentStr.charCodeAt(--stringIndex);\n            }\n        }\n\n        /*\n            tslint:disable-next-line:no-bitwise\n            JavaScript does bitwise operations (like XOR, above) on 32-bit signed\n            integers. Since we want the results to be always positive, convert the\n            signed int to an unsigned by doing an unsigned bitshift.\n      */\n        return hash >>> 0;\n    }\n\n    public isIncludes(modelPath: ModelPath): boolean {\n        const targetTokens = modelPath.getPathPartsAsArray();\n        if (this.tokens.length !== targetTokens.length) {\n            return false;\n        }\n        for (let i = 0; i < this.tokens.length; i++) {\n            const leftPart = this.tokens[i];\n            const rightPart = targetTokens[i];\n            if (typeof leftPart === \"string\") {\n                if (typeof rightPart === \"string\") {\n                    if (leftPart !== rightPart) {\n                        return false;\n                    }\n                    continue;\n                } else {\n                    return false;\n                }\n            } else if (leftPart === PathTokens.current || leftPart === PathTokens.each) {\n                if (typeof rightPart === \"string\") {\n                    if (!isFinite(Number(rightPart))) {\n                        return false;\n                    }\n                    continue;\n                } else {\n                    if (rightPart !== PathTokens.current && rightPart !== PathTokens.each) {\n                        return false;\n                    }\n                    continue;\n                }\n            }\n        }\n        return true;\n    }\n\n    public getIterationRank(eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreDifferent): number {\n        return count(\n            Iterator.from(this.tokens).filter(x =>\n                eachCurrentCollision == EachCurrentCollision.AreDifferent\n                    ? x === PathTokens.each\n                    : PathTokens.isMultiToken(x)\n            )\n        );\n    }\n\n    public isEmpty(): boolean {\n        return this.tokens.length === 0;\n    }\n\n    public matchFor(modelPath: ModelPath): PathMatching {\n        if (!this.isAbsolute()) {\n            throw new Error(`Cannot match non absolute path '${this.toString()}'`);\n        }\n        if (!modelPath.isAbsolute()) {\n            throw new Error(`Cannot match non absolute path '${modelPath.toString()}'`);\n        }\n        return PathMatcher.match(this.tokens, modelPath.getPathPartsAsArray());\n    }\n\n    public *splitByMultiplicity(): Iterable<ResolvedModelPath | typeof EachSymbol | typeof CurrentSymbol> {\n        let lastSimpleParts = new ModelPathBuilder(this.isAbsolute());\n        for (const token of this.tokens) {\n            if (PathTokens.isSimpleToken(token)) {\n                lastSimpleParts.append(token);\n            } else {\n                if (!lastSimpleParts.empty) {\n                    yield lastSimpleParts.toResolvedPath();\n                    lastSimpleParts = new ModelPathBuilder(false);\n                }\n                yield token;\n            }\n        }\n        if (!lastSimpleParts.empty) {\n            yield lastSimpleParts.toResolvedPath();\n        }\n    }\n\n    public normalize(): IModelPath<TResolved, TAbsolute> {\n        const resultTokens: PathTokensSpec<TResolved> = [];\n        for (const pathPart of this.tokens) {\n            if (pathPart === \"..\") {\n                if (!resultTokens.pop()) {\n                    if (this.isAbsolute()) {\n                        throw new Error(`Path is invalid '${this.toString()}'`);\n                    } else {\n                        resultTokens.push(\"..\");\n                    }\n                }\n                continue;\n            }\n\n            if (pathPart === \".\") {\n                continue;\n            }\n            resultTokens.push(pathPart);\n        }\n        return new ModelPathImpl<TResolved, TAbsolute>(resultTokens, this.absolute);\n    }\n\n    /**\n     * @summary Спецификаторы множественности Each заменяет на Current\n     */\n    public toCurrentIteration(): IModelPath<TResolved, TAbsolute> {\n        if (this.isResolved()) {\n            return this;\n        } else {\n            // NOTE Тут не получается наложить дискриминатор\n            // @ts-expect-error\n            const pathParts: PathTokensSpec<TResolved> = this.tokens.map(x =>\n                x === PathTokens.each ? PathTokens.current : x\n            );\n            return new ModelPathImpl<TResolved, TAbsolute>(pathParts, this.absolute);\n        }\n    }\n\n    public toEachIteration(): IModelPath<TResolved, TAbsolute> {\n        if (this.isResolved()) {\n            return this;\n        } else {\n            // NOTE Тут не получается наложить дискриминатор\n            // @ts-expect-error\n            const pathParts: PathTokensSpec<TResolved> = this.tokens.map(x =>\n                x === PathTokens.current ? PathTokens.each : x\n            );\n            return new ModelPathImpl<TResolved, TAbsolute>(pathParts, this.absolute);\n        }\n    }\n\n    public toAbsolute(): IModelPath<TResolved, true> {\n        if (!this.absolute) {\n            throw new Error(`Path '${this.toLegacyPath()} is not absolute'`);\n        }\n        return new ModelPathImpl<TResolved, true>(this.tokens, true);\n    }\n\n    public *getAllParentPaths(): Iterable<ModelPath> {\n        const result = new ModelPathBuilder(this.isAbsolute());\n        for (const token of IterUtils.skipLast(this.getPathParts(), 1)) {\n            result.append(token);\n            yield result.toPath();\n        }\n    }\n\n    public trimLastStarIfLastToken(): IModelPath<TResolved, TAbsolute> {\n        const lastItem = IterUtils.last(this.tokens);\n        if (lastItem != undefined && PathTokens.isMultiToken(lastItem)) {\n            return new ModelPathImpl(this.tokens.slice(0, -1), this.absolute);\n        }\n        return this;\n    }\n\n    public getParentPath(): IModelPath<TResolved, TAbsolute> {\n        const result = new ModelPathBuilder(this.absolute);\n        for (const token of IterUtils.skipLast(this.getPathParts(), 1)) {\n            result.append(token);\n        }\n        // Тут получается так, что по другому никак\n        // @ts-expect-error\n        return result.toPath();\n    }\n\n    public applyInstancesDirty(instances: SimplePathToken[]): IModelPath<TResolved, TAbsolute> {\n        if (this.isResolved() || instances.length === 0) {\n            return this;\n        }\n        let instanceCounter = 0;\n        const result = new ModelPathBuilder(true);\n        for (const token of this.getPathParts()) {\n            if (PathTokens.isMultiToken(token) && instanceCounter < instances.length) {\n                result.append(instances[instanceCounter] ?? reject());\n                instanceCounter++;\n            } else {\n                result.append(token);\n            }\n        }\n        // Тут получается так, что по другому никак\n        // @ts-expect-error\n        return result.toPath();\n    }\n\n    private pathPartToString(pathPart: PathToken): string {\n        if (typeof pathPart === \"string\") {\n            return pathPart;\n        }\n        if (pathPart === PathTokens.each) {\n            return \"*\";\n        }\n        if (pathPart === PathTokens.current) {\n            return \"*\";\n        }\n        throw new Error(`Unknown path part specified: ${ensureAndGetString(pathPart)}`);\n    }\n}\n"],"mappings":"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"}
457
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_IterableUtils","require","_TypingUtils","_EachCurrentCollision","_ModelPathBuilder","_PathMatcher","EachSymbol","Symbol","for","CurrentSymbol","PathTokens","isMultiToken","part","each","current","isSimpleToken","isInstanceToken","test","isInstanceTokenOrInstancesSpec","exports","isModelPath","path","ModelPathImpl","convertToLegacyPath","toLegacyPath","convertToAbsoluteModelPath","createAbsoluteFromMask","emptyModelPath","emptyAbsoluteModelPath","createModelPath","absolute","partPartStrings","split","ensurePlainPathPartsDoesNotContainMultiplicity","startsWith","slice","createFromMask","multiplicitySymbol","map","x","parts","some","Error","createAbsolute","createRelativeResolvedModelPath","createAbsoluteFromTokens","tokens","createAbsoluteResolvedFromTokens","createRelativeFromTokens","joinModelPaths","resultParts","joinItem","push","isAbsolute","getPathPartsAsArray","Array","isArray","isAllTokensResolved","every","constructor","pathParts","legacyPath","cachedHash","filter","resolved","getPathParts","getSimpleTokensStrict","token","getSimpleTokensAsArrayStrict","joinWith","isResolved","resolveAll","instance","isContainIteration","isContainCurrentIteration","isContainCurrentOrEachIteration","getLastListPath","lastIterationIndex","lastIndexOf","isEndsWithIteration","lastItem","IterUtils","last","isEndsWithCurrentIteration","toString","length","pathPartToString","join","_this$legacyPath","isEquals","modelPath","eachCurrentCollision","EachCurrentCollision","AreSame","Iterator","from","zip","t1","t2","getHash","undefined","hash","reverseArray","currentStr","AreDifferent","stringIndex","charCodeAt","isIncludes","targetTokens","i","leftPart","rightPart","isFinite","Number","getIterationRank","count","isEmpty","matchFor","PathMatcher","match","splitByMultiplicity","lastSimpleParts","ModelPathBuilder","append","empty","toResolvedPath","normalize","resultTokens","pathPart","pop","toCurrentIteration","toEachIteration","toAbsolute","getAllParentPaths","result","skipLast","toPath","trimLastStarIfLastToken","getParentPath","applyInstancesDirty","instances","fillWithMultiplicityIfHasNoInstance","instanceCounter","_instances$instanceCo","instanceOrEach","reject","ensureAndGetString"],"sources":["../../../../Common/ModelPath/ModelPath.ts"],"sourcesContent":["import { BindingPath } from \"../../Engine/src/Engine/Core/CoreTypes\";\nimport { count, IterUtils, reverseArray } from \"../IterableUtils\";\nimport { ensureAndGetString, reject } from \"../TypingUtils\";\n\nimport { EachCurrentCollision } from \"./EachCurrentCollision\";\nimport { ModelPathBuilder } from \"./ModelPathBuilder\";\nimport { PathMatcher, PathMatching } from \"./PathMatcher\";\nimport { IEquatable } from \"./IEquatable\";\n\nconst EachSymbol = Symbol.for(\"__EACH__\");\nconst CurrentSymbol = Symbol.for(\"__CURRENT__\");\n\nexport class PathTokens {\n    public static each: typeof EachSymbol = EachSymbol;\n    public static current: typeof CurrentSymbol = CurrentSymbol;\n\n    public static isMultiToken(part: undefined | PathToken): part is typeof EachSymbol | typeof CurrentSymbol {\n        return part === PathTokens.each || part === PathTokens.current;\n    }\n\n    public static isSimpleToken(part: undefined | PathToken): part is string {\n        return typeof part === \"string\";\n    }\n\n    public static isInstanceToken(part: undefined | PathToken): part is string {\n        return typeof part === \"string\" && /^\\d+$/i.test(part);\n    }\n\n    public static isInstanceTokenOrInstancesSpec(part: undefined | PathToken): part is string {\n        return typeof part === \"string\" && (/^\\d+$/i.test(part) || /^\\[(\\d+\\,?)+\\]$/i.test(part));\n    }\n}\n\nexport type SimplePathToken = string;\n\nexport type PathToken = SimplePathToken | typeof EachSymbol | typeof CurrentSymbol;\n\nexport function isModelPath(path: BindingPath | ModelPath | unknown): path is ModelPath {\n    return typeof path !== \"string\" && path instanceof ModelPathImpl;\n}\n\nexport function convertToLegacyPath(path: BindingPath | ModelPath): BindingPath {\n    return isModelPath(path) ? path.toLegacyPath() : path;\n}\n\nexport function convertToAbsoluteModelPath<R extends boolean, A extends boolean>(\n    path: BindingPath | IModelPath<R, A>\n): IModelPath<R, true>;\nexport function convertToAbsoluteModelPath(path: BindingPath | AbsoluteModelPath): AbsoluteModelPath {\n    return isModelPath(path) ? path : createAbsoluteFromMask(path, PathTokens.each);\n}\n\nexport function emptyModelPath(): RelativeResolvedModelPath {\n    return new ModelPathImpl<true, false>([], false);\n}\n\nexport function emptyAbsoluteModelPath(): AbsoluteResolvedModelPath {\n    return new ModelPathImpl<true, true>([], true);\n}\n\nexport function createModelPath(path: string, absolute: true): AbsoluteResolvedModelPath;\nexport function createModelPath(path: string, absolute: false): RelativeResolvedModelPath;\nexport function createModelPath(path: string, absolute: \"auto\"): ResolvedModelPath;\nexport function createModelPath(path: string, absolute: boolean | \"auto\"): ResolvedModelPath {\n    const partPartStrings = path.split(\"/\");\n    ensurePlainPathPartsDoesNotContainMultiplicity(partPartStrings);\n    if (absolute === \"auto\") {\n        if (path.startsWith(\"/\")) {\n            return new ModelPathImpl<true, true>(partPartStrings.slice(1), true);\n        } else {\n            return new ModelPathImpl<true, false>(partPartStrings, false);\n        }\n    }\n    if (absolute && path.startsWith(\"/\")) {\n        return new ModelPathImpl<true, true>(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl<true, boolean>(partPartStrings, absolute);\n}\n\nexport function createFromMask(path: string, absolute: true, multiplicitySymbol: PathToken): AbsoluteModelPath;\nexport function createFromMask(path: string, absolute: false, multiplicitySymbol: PathToken): ResolvedModelPath;\nexport function createFromMask(path: string, absolute: \"auto\", multiplicitySymbol: PathToken): ModelPath;\nexport function createFromMask(path: string, absolute: boolean | \"auto\", multiplicitySymbol: PathToken): ModelPath {\n    const partPartStrings = path.split(\"/\").map(x => (x === \"*\" ? multiplicitySymbol : x));\n    if (absolute === \"auto\") {\n        if (path.startsWith(\"/\")) {\n            return new ModelPathImpl(partPartStrings.slice(1), true);\n        } else {\n            return new ModelPathImpl(partPartStrings, false);\n        }\n    }\n    if (absolute && path.startsWith(\"/\")) {\n        return new ModelPathImpl(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl(partPartStrings, absolute);\n}\n\nexport function createAbsoluteFromMask(path: string, multiplicitySymbol: PathToken): AbsoluteModelPath {\n    const partPartStrings = path.split(\"/\").map(x => (x === \"*\" ? multiplicitySymbol : x));\n    if (path.startsWith(\"/\")) {\n        return new ModelPathImpl(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl(partPartStrings, true);\n}\n\nfunction ensurePlainPathPartsDoesNotContainMultiplicity(parts: string[]): void {\n    if (parts.some(x => x === \"*\")) {\n        throw new Error(\"Path must not contain * symbol\");\n    }\n}\n\nexport function createAbsolute(path: string): AbsoluteResolvedModelPath {\n    const partPartStrings = path.split(\"/\");\n    ensurePlainPathPartsDoesNotContainMultiplicity(partPartStrings);\n    if (path.startsWith(\"/\")) {\n        return new ModelPathImpl<true, true>(partPartStrings.slice(1), true);\n    }\n    return new ModelPathImpl<true, true>(partPartStrings, true);\n}\n\nexport function createRelativeResolvedModelPath(path: string): RelativeResolvedModelPath {\n    const partPartStrings = path.split(\"/\");\n    ensurePlainPathPartsDoesNotContainMultiplicity(partPartStrings);\n    return new ModelPathImpl<true, false>(partPartStrings, false);\n}\n\nexport function createAbsoluteFromTokens(tokens: PathToken[]): AbsoluteModelPath {\n    return new ModelPathImpl<false, true>(tokens, true);\n}\n\nexport function createAbsoluteResolvedFromTokens(tokens: string[]): AbsoluteResolvedModelPath {\n    ensurePlainPathPartsDoesNotContainMultiplicity(tokens);\n    return new ModelPathImpl<true, true>(tokens, true);\n}\n\nexport function createRelativeFromTokens(tokens: readonly string[]): RelativeResolvedModelPath;\nexport function createRelativeFromTokens(tokens: readonly PathToken[]): RelativeModelPath;\nexport function createRelativeFromTokens(tokens: readonly PathToken[]): RelativeModelPath {\n    return new ModelPathImpl<false, false>(tokens, false);\n}\n\nexport function joinModelPaths(...parts: Array<ModelPath | PathToken | PathToken[]>): ModelPath {\n    let absolute = false;\n    let resultParts: PathToken[] = [];\n    for (const joinItem of parts) {\n        if (typeof joinItem === \"string\") {\n            resultParts.push(joinItem);\n        } else if (isModelPath(joinItem)) {\n            if (joinItem.isAbsolute()) {\n                absolute = true;\n                resultParts = [...joinItem.getPathPartsAsArray()];\n            } else {\n                resultParts.push(...joinItem.getPathPartsAsArray());\n            }\n        } else if (Array.isArray(joinItem)) {\n            resultParts.push(...joinItem);\n        } else if (PathTokens.isMultiToken(joinItem)) {\n            resultParts.push(joinItem);\n        }\n    }\n\n    return new ModelPathImpl(resultParts, absolute);\n}\n\nexport interface IModelPath<TResolved extends boolean, TAbsolute extends boolean>\n    extends IEquatable<IModelPath<boolean, boolean>> {\n    readonly resolved: TResolved;\n    readonly absolute: TAbsolute;\n\n    isEquals(modelPath: ModelPath, eachCurrentCollision?: EachCurrentCollision): boolean;\n    getHash(eachCurrentCollision?: EachCurrentCollision): number;\n\n    isResolved(): this is IModelPath<true, TAbsolute>;\n    isAbsolute(): this is IModelPath<TResolved, true>;\n    toAbsolute(): IModelPath<TResolved, true>;\n\n    joinWith(...path: string[]): IModelPath<TResolved, TAbsolute>;\n    joinWith(...path: PathToken[]): IModelPath<boolean, TAbsolute>;\n    joinWith(...path: Array<ResolvedModelPath | string>): IModelPath<TResolved, TAbsolute>;\n    joinWith(...path: Array<AbsoluteResolvedModelPath | string>): IModelPath<TResolved, true>;\n    joinWith(...path: Array<ModelPath | PathToken>): IModelPath<boolean, TAbsolute>;\n\n    getPathParts(): Iterable<PathTokenSpec<TResolved>>;\n    getPathPartsAsArray(): ReadonlyArray<PathTokenSpec<TResolved>>;\n    getSimpleTokensStrict(): Iterable<SimplePathToken>;\n    getSimpleTokensAsArrayStrict(): readonly SimplePathToken[];\n\n    resolveAll(instance: string): ModelPath;\n    isContainIteration(): boolean;\n    isContainCurrentIteration(): boolean;\n    isContainCurrentOrEachIteration(): boolean;\n    getLastListPath(): PathToken[];\n    isEndsWithIteration(): boolean;\n    isEndsWithCurrentIteration(): boolean;\n    isIncludes(modelPath: ModelPath): boolean;\n    getIterationRank(eachCurrentCollision?: EachCurrentCollision): number;\n    isEmpty(): boolean;\n    matchFor(modelPath: ModelPath): PathMatching;\n    splitByMultiplicity(): Iterable<ResolvedModelPath | typeof EachSymbol | typeof CurrentSymbol>;\n    normalize(): IModelPath<TResolved, TAbsolute>;\n    toCurrentIteration(): IModelPath<TResolved, TAbsolute>;\n    toEachIteration(): IModelPath<TResolved, TAbsolute>;\n    getAllParentPaths(): Iterable<ModelPath>;\n    trimLastStarIfLastToken(): IModelPath<TResolved, TAbsolute>;\n    getParentPath(): IModelPath<TResolved, TAbsolute>;\n    applyInstancesDirty(\n        instances: SimplePathToken[],\n        fillWithMultiplicityIfHasNoInstance?: boolean\n    ): IModelPath<TResolved, TAbsolute>;\n\n    toString(): string;\n    toLegacyPath(): string;\n}\n\nexport type ModelPath = IModelPath<boolean, boolean>;\nexport type ResolvedModelPath = IModelPath<true, boolean>;\nexport type AbsoluteModelPath = IModelPath<boolean, true>;\nexport type AbsoluteResolvedModelPath = IModelPath<true, true>;\n\nexport type RelativeModelPath = IModelPath<boolean, false>;\nexport type RelativeResolvedModelPath = IModelPath<true, false>;\n\ntype PathTokenSpec<TResolved extends boolean> = TResolved extends true ? string : PathToken;\n\ntype PathTokensSpec<TResolved extends boolean> = Array<PathTokenSpec<TResolved>>;\n\ntype ReadonlyPathTokensSpec<TResolved extends boolean> = ReadonlyArray<PathTokenSpec<TResolved>>;\n\nfunction isAllTokensResolved<TResolved extends boolean>(tokens: ReadonlyPathTokensSpec<TResolved>): TResolved {\n    // Я что-то немогу сообразить как тут всё строго написать...\n    // @ts-expect-error\n    return tokens.every(PathTokens.isSimpleToken);\n}\n\nexport class ModelPathImpl<TResolved extends boolean, TAbsolute extends boolean>\n    implements IEquatable<ModelPath>, IModelPath<TResolved, TAbsolute>\n{\n    private readonly tokens: ReadonlyPathTokensSpec<TResolved>;\n    public readonly absolute: TAbsolute;\n    private legacyPath: undefined | string;\n    private cachedHash: number | undefined;\n\n    public constructor(pathParts: ReadonlyPathTokensSpec<TResolved>, absolute: TAbsolute) {\n        this.tokens = pathParts.filter(x => x !== \"\");\n        this.absolute = absolute;\n    }\n\n    public get resolved(): TResolved {\n        return isAllTokensResolved(this.tokens);\n    }\n\n    public getPathParts(): Iterable<PathTokenSpec<TResolved>> {\n        return this.tokens;\n    }\n\n    public getPathPartsAsArray(): ReadonlyArray<PathTokenSpec<TResolved>> {\n        return this.tokens;\n    }\n\n    public *getSimpleTokensStrict(): Iterable<SimplePathToken> {\n        for (const token of this.tokens) {\n            if (!PathTokens.isSimpleToken(token)) {\n                throw new Error(\"Path must not contain spec tokens\");\n            }\n            yield token;\n        }\n    }\n\n    public getSimpleTokensAsArrayStrict(): readonly SimplePathToken[] {\n        for (const token of this.tokens) {\n            if (!PathTokens.isSimpleToken(token)) {\n                throw new Error(\"Path must not contain spec tokens\");\n            }\n        }\n        // Проверка выше гараентирует что будут только SimplePathToken.\n        // Все map и filter убраны для производительности\n        // @ts-ignore\n        return this.tokens;\n    }\n\n    public joinWith(...path: string[]): IModelPath<TResolved, TAbsolute>;\n    public joinWith(...path: PathToken[]): IModelPath<boolean, TAbsolute>;\n    public joinWith(...path: Array<ResolvedModelPath | string>): IModelPath<TResolved, TAbsolute>;\n    public joinWith(...path: Array<AbsoluteResolvedModelPath | string>): IModelPath<TResolved, true>;\n    public joinWith(...path: Array<ModelPath | PathToken>): IModelPath<boolean, TAbsolute>;\n    public joinWith(...path: Array<ModelPath | PathToken>): IModelPath<boolean, boolean> {\n        return joinModelPaths(this, ...path);\n    }\n\n    public isResolved(): this is IModelPath<true, TAbsolute> {\n        return isAllTokensResolved(this.tokens);\n    }\n\n    public resolveAll(instance: string): ModelPath {\n        const tokens = this.tokens.map(token => {\n            if (PathTokens.isSimpleToken(token)) {\n                return token;\n            } else {\n                return instance;\n            }\n        });\n\n        return new ModelPathImpl(tokens, this.absolute);\n    }\n\n    public isContainIteration(): boolean {\n        return this.tokens.some(x => x === PathTokens.each);\n    }\n\n    public isContainCurrentIteration(): boolean {\n        return this.tokens.some(x => x === PathTokens.current);\n    }\n\n    public isContainCurrentOrEachIteration(): boolean {\n        return this.tokens.some(x => x === PathTokens.current || x === PathTokens.each);\n    }\n\n    public getLastListPath(): PathToken[] {\n        if (!this.isContainIteration()) {\n            throw new Error(\"Path must contain iteration\");\n        }\n\n        // Проверка выше гарантирует, что будет PathTokens.each\n        // @ts-ignore\n        const lastIterationIndex = this.tokens.lastIndexOf(PathTokens.each);\n        return this.tokens.slice(0, lastIterationIndex);\n    }\n\n    public isEndsWithIteration(): boolean {\n        const lastItem = IterUtils.last(this.tokens);\n        return lastItem == PathTokens.each;\n    }\n\n    public isEndsWithCurrentIteration(): boolean {\n        const lastItem = IterUtils.last(this.tokens);\n        return lastItem == PathTokens.current;\n    }\n\n    public isAbsolute(): this is IModelPath<TResolved, true> {\n        return this.absolute;\n    }\n\n    public toString(): string {\n        if (this.tokens.length === 0) {\n            return \"\";\n        }\n        return (this.absolute ? \"/\" : \"\") + this.tokens.map(x => this.pathPartToString(x)).join(\"/\");\n    }\n\n    public toLegacyPath(): string {\n        return this.legacyPath ?? (this.legacyPath = this.tokens.map(x => this.pathPartToString(x)).join(\"/\"));\n    }\n\n    public isEquals(\n        modelPath: ModelPath,\n        eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreSame\n    ): boolean {\n        if (eachCurrentCollision === EachCurrentCollision.AreSame) {\n            return this.toLegacyPath() === modelPath.toLegacyPath();\n        } else {\n            return (\n                this.isAbsolute() === modelPath.isAbsolute() &&\n                Iterator.from(IterUtils.zip(this.getPathParts(), modelPath.getPathParts())).every(\n                    ([t1, t2]) => t1 === t2\n                )\n            );\n        }\n    }\n\n    /**\n     * Всегда целое положительное беззнаковое 32-битное число\n     */\n    public getHash(eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreSame): number {\n        if (this.cachedHash == undefined) {\n            let hash = 5381;\n            for (const token of reverseArray(this.tokens)) {\n                let currentStr: string;\n                if (PathTokens.isSimpleToken(token)) {\n                    currentStr = token;\n                } else {\n                    if (eachCurrentCollision === EachCurrentCollision.AreDifferent) {\n                        currentStr = token === PathTokens.each ? \"*\" : \"!\";\n                    } else {\n                        currentStr = \"*\";\n                    }\n                }\n                let stringIndex = currentStr.length;\n                while (stringIndex) {\n                    // tslint:disable-next-line:no-bitwise\n                    hash = (hash * 33) ^ currentStr.charCodeAt(--stringIndex);\n                }\n            }\n\n            /*\n                tslint:disable-next-line:no-bitwise\n                JavaScript does bitwise operations (like XOR, above) on 32-bit signed\n                integers. Since we want the results to be always positive, convert the\n                signed int to an unsigned by doing an unsigned bitshift.\n          */\n            this.cachedHash = hash >>> 0;\n        }\n        return this.cachedHash;\n    }\n\n    public isIncludes(modelPath: ModelPath): boolean {\n        const targetTokens = modelPath.getPathPartsAsArray();\n        if (this.tokens.length !== targetTokens.length) {\n            return false;\n        }\n        for (let i = 0; i < this.tokens.length; i++) {\n            const leftPart = this.tokens[i];\n            const rightPart = targetTokens[i];\n            if (typeof leftPart === \"string\") {\n                if (typeof rightPart === \"string\") {\n                    if (leftPart !== rightPart) {\n                        return false;\n                    }\n                    continue;\n                } else {\n                    return false;\n                }\n            } else if (leftPart === PathTokens.current || leftPart === PathTokens.each) {\n                if (typeof rightPart === \"string\") {\n                    if (!isFinite(Number(rightPart))) {\n                        return false;\n                    }\n                    continue;\n                } else {\n                    if (rightPart !== PathTokens.current && rightPart !== PathTokens.each) {\n                        return false;\n                    }\n                    continue;\n                }\n            }\n        }\n        return true;\n    }\n\n    public getIterationRank(eachCurrentCollision: EachCurrentCollision = EachCurrentCollision.AreDifferent): number {\n        return count(\n            Iterator.from(this.tokens).filter(x =>\n                eachCurrentCollision == EachCurrentCollision.AreDifferent\n                    ? x === PathTokens.each\n                    : PathTokens.isMultiToken(x)\n            )\n        );\n    }\n\n    public isEmpty(): boolean {\n        return this.tokens.length === 0;\n    }\n\n    public matchFor(modelPath: ModelPath): PathMatching {\n        if (!this.isAbsolute()) {\n            throw new Error(`Cannot match non absolute path '${this.toString()}'`);\n        }\n        if (!modelPath.isAbsolute()) {\n            throw new Error(`Cannot match non absolute path '${modelPath.toString()}'`);\n        }\n        return PathMatcher.match(this.tokens, modelPath.getPathPartsAsArray());\n    }\n\n    public *splitByMultiplicity(): Iterable<ResolvedModelPath | typeof EachSymbol | typeof CurrentSymbol> {\n        let lastSimpleParts = new ModelPathBuilder(this.isAbsolute());\n        for (const token of this.tokens) {\n            if (PathTokens.isSimpleToken(token)) {\n                lastSimpleParts.append(token);\n            } else {\n                if (!lastSimpleParts.empty) {\n                    yield lastSimpleParts.toResolvedPath();\n                    lastSimpleParts = new ModelPathBuilder(false);\n                }\n                yield token;\n            }\n        }\n        if (!lastSimpleParts.empty) {\n            yield lastSimpleParts.toResolvedPath();\n        }\n    }\n\n    public normalize(): IModelPath<TResolved, TAbsolute> {\n        const resultTokens: PathTokensSpec<TResolved> = [];\n        for (const pathPart of this.tokens) {\n            if (pathPart === \"..\") {\n                if (!resultTokens.pop()) {\n                    if (this.isAbsolute()) {\n                        throw new Error(`Path is invalid '${this.toString()}'`);\n                    } else {\n                        resultTokens.push(\"..\");\n                    }\n                }\n                continue;\n            }\n\n            if (pathPart === \".\") {\n                continue;\n            }\n            resultTokens.push(pathPart);\n        }\n        return new ModelPathImpl<TResolved, TAbsolute>(resultTokens, this.absolute);\n    }\n\n    /**\n     * @summary Спецификаторы множественности Each заменяет на Current\n     */\n    public toCurrentIteration(): IModelPath<TResolved, TAbsolute> {\n        if (this.isResolved()) {\n            return this;\n        } else {\n            // NOTE Тут не получается наложить дискриминатор\n            // @ts-expect-error\n            const pathParts: PathTokensSpec<TResolved> = this.tokens.map(x =>\n                x === PathTokens.each ? PathTokens.current : x\n            );\n            return new ModelPathImpl<TResolved, TAbsolute>(pathParts, this.absolute);\n        }\n    }\n\n    public toEachIteration(): IModelPath<TResolved, TAbsolute> {\n        if (this.isResolved()) {\n            return this;\n        } else {\n            // NOTE Тут не получается наложить дискриминатор\n            // @ts-expect-error\n            const pathParts: PathTokensSpec<TResolved> = this.tokens.map(x =>\n                x === PathTokens.current ? PathTokens.each : x\n            );\n            return new ModelPathImpl<TResolved, TAbsolute>(pathParts, this.absolute);\n        }\n    }\n\n    public toAbsolute(): IModelPath<TResolved, true> {\n        if (!this.absolute) {\n            throw new Error(`Path '${this.toLegacyPath()} is not absolute'`);\n        }\n        return new ModelPathImpl<TResolved, true>(this.tokens, true);\n    }\n\n    public *getAllParentPaths(): Iterable<ModelPath> {\n        const result = new ModelPathBuilder(this.isAbsolute());\n        for (const token of IterUtils.skipLast(this.getPathParts(), 1)) {\n            result.append(token);\n            yield result.toPath();\n        }\n    }\n\n    public trimLastStarIfLastToken(): IModelPath<TResolved, TAbsolute> {\n        const lastItem = IterUtils.last(this.tokens);\n        if (lastItem != undefined && PathTokens.isMultiToken(lastItem)) {\n            return new ModelPathImpl(this.tokens.slice(0, -1), this.absolute);\n        }\n        return this;\n    }\n\n    public getParentPath(): IModelPath<TResolved, TAbsolute> {\n        const result = new ModelPathBuilder(this.absolute);\n        for (const token of IterUtils.skipLast(this.getPathParts(), 1)) {\n            result.append(token);\n        }\n        // Тут получается так, что по другому никак\n        // @ts-expect-error\n        return result.toPath();\n    }\n\n    public applyInstancesDirty(\n        instances: SimplePathToken[],\n        fillWithMultiplicityIfHasNoInstance?: boolean\n    ): IModelPath<TResolved, TAbsolute> {\n        if (this.isResolved() || instances.length === 0) {\n            return this;\n        }\n        let instanceCounter = 0;\n        const result = new ModelPathBuilder(true);\n        for (const token of this.getPathParts()) {\n            if (PathTokens.isMultiToken(token) && instanceCounter < instances.length) {\n                const instanceOrEach =\n                    instances[instanceCounter] ??\n                    (fillWithMultiplicityIfHasNoInstance == true ? PathTokens.each : reject());\n                result.append(instanceOrEach);\n                instanceCounter++;\n            } else {\n                result.append(token);\n            }\n        }\n        // Тут получается так, что по другому никак\n        // @ts-expect-error\n        return result.toPath();\n    }\n\n    private pathPartToString(pathPart: PathToken): string {\n        if (typeof pathPart === \"string\") {\n            return pathPart;\n        }\n        if (pathPart === PathTokens.each) {\n            return \"*\";\n        }\n        if (pathPart === PathTokens.current) {\n            return \"*\";\n        }\n        throw new Error(`Unknown path part specified: ${ensureAndGetString(pathPart)}`);\n    }\n}\n"],"mappings":"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"}
@@ -3,10 +3,32 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ exports.getMask = getMask;
7
+ exports.getMaskWithInstances = getMaskWithInstances;
6
8
  exports.isAggregationPath = isAggregationPath;
9
+ var _ModelPath = require("./ModelPath");
7
10
  function isAggregationPath(modelPath) {
8
11
  const tokens = modelPath.getPathPartsAsArray();
9
12
  const lastToken = tokens[tokens.length - 1];
10
13
  return lastToken === "Sum" || lastToken === "Count";
11
14
  }
12
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0FnZ3JlZ2F0aW9uUGF0aCIsIm1vZGVsUGF0aCIsInRva2VucyIsImdldFBhdGhQYXJ0c0FzQXJyYXkiLCJsYXN0VG9rZW4iLCJsZW5ndGgiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9Db21tb24vTW9kZWxQYXRoL01vZGVsUGF0aEhlbHBlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNb2RlbFBhdGggfSBmcm9tIFwiLi9Nb2RlbFBhdGhcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzQWdncmVnYXRpb25QYXRoKG1vZGVsUGF0aDogTW9kZWxQYXRoKSB7XG4gICAgY29uc3QgdG9rZW5zID0gbW9kZWxQYXRoLmdldFBhdGhQYXJ0c0FzQXJyYXkoKTtcbiAgICBjb25zdCBsYXN0VG9rZW4gPSB0b2tlbnNbdG9rZW5zLmxlbmd0aCAtIDFdO1xuICAgIHJldHVybiBsYXN0VG9rZW4gPT09IFwiU3VtXCIgfHwgbGFzdFRva2VuID09PSBcIkNvdW50XCI7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUVPLFNBQVNBLGlCQUFpQkEsQ0FBQ0MsU0FBb0IsRUFBRTtFQUNwRCxNQUFNQyxNQUFNLEdBQUdELFNBQVMsQ0FBQ0UsbUJBQW1CLENBQUMsQ0FBQztFQUM5QyxNQUFNQyxTQUFTLEdBQUdGLE1BQU0sQ0FBQ0EsTUFBTSxDQUFDRyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0VBQzNDLE9BQU9ELFNBQVMsS0FBSyxLQUFLLElBQUlBLFNBQVMsS0FBSyxPQUFPO0FBQ3ZEIn0=
15
+ function getMask(exactPath) {
16
+ return (0, _ModelPath.createAbsoluteFromTokens)(Iterator.from(exactPath.getPathParts()).map(x => _ModelPath.PathTokens.isInstanceToken(x) ? _ModelPath.PathTokens.each : x).toArray());
17
+ }
18
+ function getMaskWithInstances(exactPath) {
19
+ const reduceResult = Iterator.from(exactPath.getPathParts()).reduce((result, token) => {
20
+ if (_ModelPath.PathTokens.isInstanceToken(token) || _ModelPath.PathTokens.isMultiToken(token)) {
21
+ result.instances.push(token);
22
+ }
23
+ result.tokens.push(_ModelPath.PathTokens.isInstanceToken(token) ? _ModelPath.PathTokens.each : token);
24
+ return result;
25
+ }, {
26
+ tokens: [],
27
+ instances: []
28
+ });
29
+ return {
30
+ mask: (0, _ModelPath.createAbsoluteFromTokens)(reduceResult.tokens),
31
+ instances: reduceResult.instances
32
+ };
33
+ }
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfTW9kZWxQYXRoIiwicmVxdWlyZSIsImlzQWdncmVnYXRpb25QYXRoIiwibW9kZWxQYXRoIiwidG9rZW5zIiwiZ2V0UGF0aFBhcnRzQXNBcnJheSIsImxhc3RUb2tlbiIsImxlbmd0aCIsImdldE1hc2siLCJleGFjdFBhdGgiLCJjcmVhdGVBYnNvbHV0ZUZyb21Ub2tlbnMiLCJJdGVyYXRvciIsImZyb20iLCJnZXRQYXRoUGFydHMiLCJtYXAiLCJ4IiwiUGF0aFRva2VucyIsImlzSW5zdGFuY2VUb2tlbiIsImVhY2giLCJ0b0FycmF5IiwiZ2V0TWFza1dpdGhJbnN0YW5jZXMiLCJyZWR1Y2VSZXN1bHQiLCJyZWR1Y2UiLCJyZXN1bHQiLCJ0b2tlbiIsImlzTXVsdGlUb2tlbiIsImluc3RhbmNlcyIsInB1c2giLCJtYXNrIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vQ29tbW9uL01vZGVsUGF0aC9Nb2RlbFBhdGhIZWxwZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWJzb2x1dGVNb2RlbFBhdGgsIGNyZWF0ZUFic29sdXRlRnJvbVRva2VucywgTW9kZWxQYXRoLCBQYXRoVG9rZW4sIFBhdGhUb2tlbnMgfSBmcm9tIFwiLi9Nb2RlbFBhdGhcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzQWdncmVnYXRpb25QYXRoKG1vZGVsUGF0aDogTW9kZWxQYXRoKSB7XG4gICAgY29uc3QgdG9rZW5zID0gbW9kZWxQYXRoLmdldFBhdGhQYXJ0c0FzQXJyYXkoKTtcbiAgICBjb25zdCBsYXN0VG9rZW4gPSB0b2tlbnNbdG9rZW5zLmxlbmd0aCAtIDFdO1xuICAgIHJldHVybiBsYXN0VG9rZW4gPT09IFwiU3VtXCIgfHwgbGFzdFRva2VuID09PSBcIkNvdW50XCI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRNYXNrKGV4YWN0UGF0aDogQWJzb2x1dGVNb2RlbFBhdGgpOiBBYnNvbHV0ZU1vZGVsUGF0aCB7XG4gICAgcmV0dXJuIGNyZWF0ZUFic29sdXRlRnJvbVRva2VucyhcbiAgICAgICAgSXRlcmF0b3IuZnJvbShleGFjdFBhdGguZ2V0UGF0aFBhcnRzKCkpXG4gICAgICAgICAgICAubWFwKHggPT4gKFBhdGhUb2tlbnMuaXNJbnN0YW5jZVRva2VuKHgpID8gUGF0aFRva2Vucy5lYWNoIDogeCkpXG4gICAgICAgICAgICAudG9BcnJheSgpXG4gICAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldE1hc2tXaXRoSW5zdGFuY2VzKGV4YWN0UGF0aDogQWJzb2x1dGVNb2RlbFBhdGgpOiB7XG4gICAgbWFzazogQWJzb2x1dGVNb2RlbFBhdGg7XG4gICAgaW5zdGFuY2VzOiBQYXRoVG9rZW5bXTtcbn0ge1xuICAgIGNvbnN0IHJlZHVjZVJlc3VsdCA9IEl0ZXJhdG9yLmZyb20oZXhhY3RQYXRoLmdldFBhdGhQYXJ0cygpKS5yZWR1Y2UoXG4gICAgICAgIChyZXN1bHQsIHRva2VuKSA9PiB7XG4gICAgICAgICAgICBpZiAoUGF0aFRva2Vucy5pc0luc3RhbmNlVG9rZW4odG9rZW4pIHx8IFBhdGhUb2tlbnMuaXNNdWx0aVRva2VuKHRva2VuKSkge1xuICAgICAgICAgICAgICAgIHJlc3VsdC5pbnN0YW5jZXMucHVzaCh0b2tlbik7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXN1bHQudG9rZW5zLnB1c2goUGF0aFRva2Vucy5pc0luc3RhbmNlVG9rZW4odG9rZW4pID8gUGF0aFRva2Vucy5lYWNoIDogdG9rZW4pO1xuICAgICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgdG9rZW5zOiBbXSBhcyBQYXRoVG9rZW5bXSxcbiAgICAgICAgICAgIGluc3RhbmNlczogW10gYXMgUGF0aFRva2VuW10sXG4gICAgICAgIH1cbiAgICApO1xuICAgIHJldHVybiB7XG4gICAgICAgIG1hc2s6IGNyZWF0ZUFic29sdXRlRnJvbVRva2VucyhyZWR1Y2VSZXN1bHQudG9rZW5zKSxcbiAgICAgICAgaW5zdGFuY2VzOiByZWR1Y2VSZXN1bHQuaW5zdGFuY2VzLFxuICAgIH07XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsVUFBQSxHQUFBQyxPQUFBO0FBRU8sU0FBU0MsaUJBQWlCQSxDQUFDQyxTQUFvQixFQUFFO0VBQ3BELE1BQU1DLE1BQU0sR0FBR0QsU0FBUyxDQUFDRSxtQkFBbUIsQ0FBQyxDQUFDO0VBQzlDLE1BQU1DLFNBQVMsR0FBR0YsTUFBTSxDQUFDQSxNQUFNLENBQUNHLE1BQU0sR0FBRyxDQUFDLENBQUM7RUFDM0MsT0FBT0QsU0FBUyxLQUFLLEtBQUssSUFBSUEsU0FBUyxLQUFLLE9BQU87QUFDdkQ7QUFFTyxTQUFTRSxPQUFPQSxDQUFDQyxTQUE0QixFQUFxQjtFQUNyRSxPQUFPLElBQUFDLG1DQUF3QixFQUMzQkMsUUFBUSxDQUFDQyxJQUFJLENBQUNILFNBQVMsQ0FBQ0ksWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUNsQ0MsR0FBRyxDQUFDQyxDQUFDLElBQUtDLHFCQUFVLENBQUNDLGVBQWUsQ0FBQ0YsQ0FBQyxDQUFDLEdBQUdDLHFCQUFVLENBQUNFLElBQUksR0FBR0gsQ0FBRSxDQUFDLENBQy9ESSxPQUFPLENBQUMsQ0FDakIsQ0FBQztBQUNMO0FBRU8sU0FBU0Msb0JBQW9CQSxDQUFDWCxTQUE0QixFQUcvRDtFQUNFLE1BQU1ZLFlBQVksR0FBR1YsUUFBUSxDQUFDQyxJQUFJLENBQUNILFNBQVMsQ0FBQ0ksWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDUyxNQUFNLENBQy9ELENBQUNDLE1BQU0sRUFBRUMsS0FBSyxLQUFLO0lBQ2YsSUFBSVIscUJBQVUsQ0FBQ0MsZUFBZSxDQUFDTyxLQUFLLENBQUMsSUFBSVIscUJBQVUsQ0FBQ1MsWUFBWSxDQUFDRCxLQUFLLENBQUMsRUFBRTtNQUNyRUQsTUFBTSxDQUFDRyxTQUFTLENBQUNDLElBQUksQ0FBQ0gsS0FBSyxDQUFDO0lBQ2hDO0lBQ0FELE1BQU0sQ0FBQ25CLE1BQU0sQ0FBQ3VCLElBQUksQ0FBQ1gscUJBQVUsQ0FBQ0MsZUFBZSxDQUFDTyxLQUFLLENBQUMsR0FBR1IscUJBQVUsQ0FBQ0UsSUFBSSxHQUFHTSxLQUFLLENBQUM7SUFDL0UsT0FBT0QsTUFBTTtFQUNqQixDQUFDLEVBQ0Q7SUFDSW5CLE1BQU0sRUFBRSxFQUFpQjtJQUN6QnNCLFNBQVMsRUFBRTtFQUNmLENBQ0osQ0FBQztFQUNELE9BQU87SUFDSEUsSUFBSSxFQUFFLElBQUFsQixtQ0FBd0IsRUFBQ1csWUFBWSxDQUFDakIsTUFBTSxDQUFDO0lBQ25Ec0IsU0FBUyxFQUFFTCxZQUFZLENBQUNLO0VBQzVCLENBQUM7QUFDTCJ9
@@ -5,8 +5,13 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.Set2 = void 0;
7
7
  class Set2 {
8
- constructor() {
8
+ constructor(source) {
9
9
  this.hashMap = new Map();
10
+ if (source != undefined) {
11
+ for (const sourceElement of source) {
12
+ this.add(sourceElement);
13
+ }
14
+ }
10
15
  }
11
16
  add(path) {
12
17
  const hash = this.getItemHash(path);
@@ -51,4 +56,4 @@ class Set2 {
51
56
  }
52
57
  }
53
58
  exports.Set2 = Set2;
54
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTZXQyIiwiY29uc3RydWN0b3IiLCJoYXNoTWFwIiwiTWFwIiwiYWRkIiwicGF0aCIsImhhc2giLCJnZXRJdGVtSGFzaCIsImxpc3QiLCJnZXQiLCJ1bmRlZmluZWQiLCJzZXQiLCJmaW5kIiwieCIsImFyZUl0ZW1zRXF1YWwiLCJwdXNoIiwicmVtb3ZlIiwiZmlsdGVyIiwiaGFzIiwiX3RoaXMkaGFzaE1hcCRnZXQiLCJpc0VtcHR5Iiwic2l6ZSIsInZhbHVlcyIsIkl0ZXJhdG9yIiwiZnJvbSIsImZsYXRNYXAiLCJjbGVhciIsImtleSIsImdldEhhc2giLCJsZWZ0IiwicmlnaHQiLCJpc0VxdWFscyIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9Db21tb24vTW9kZWxQYXRoL1NldC9TZXQyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElFcXVhdGFibGUgfSBmcm9tIFwiLi4vSUVxdWF0YWJsZVwiO1xuXG5leHBvcnQgY2xhc3MgU2V0MjxUSSBleHRlbmRzIElFcXVhdGFibGU8VEk+PiB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBoYXNoTWFwID0gbmV3IE1hcDxudW1iZXIsIFRJW10+KCk7XG5cbiAgICBwdWJsaWMgYWRkKHBhdGg6IFRJKTogYm9vbGVhbiB7XG4gICAgICAgIGNvbnN0IGhhc2ggPSB0aGlzLmdldEl0ZW1IYXNoKHBhdGgpO1xuICAgICAgICBjb25zdCBsaXN0ID0gdGhpcy5oYXNoTWFwLmdldChoYXNoKTtcbiAgICAgICAgaWYgKGxpc3QgPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICB0aGlzLmhhc2hNYXAuc2V0KGhhc2gsIFtwYXRoXSk7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGlmIChsaXN0LmZpbmQoeCA9PiB0aGlzLmFyZUl0ZW1zRXF1YWwoeCwgcGF0aCkpID09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgICAgIGxpc3QucHVzaChwYXRoKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgcHVibGljIHJlbW92ZShwYXRoOiBUSSk6IHZvaWQge1xuICAgICAgICBjb25zdCBoYXNoID0gdGhpcy5nZXRJdGVtSGFzaChwYXRoKTtcbiAgICAgICAgY29uc3QgbGlzdCA9IHRoaXMuaGFzaE1hcC5nZXQoaGFzaCk7XG4gICAgICAgIGlmIChsaXN0ICE9IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhpcy5oYXNoTWFwLnNldChcbiAgICAgICAgICAgICAgICBoYXNoLFxuICAgICAgICAgICAgICAgIGxpc3QuZmlsdGVyKHggPT4gIXRoaXMuYXJlSXRlbXNFcXVhbCh4LCBwYXRoKSlcbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgaGFzKHBhdGg6IFRJKTogYm9vbGVhbiB7XG4gICAgICAgIGNvbnN0IGhhc2ggPSB0aGlzLmdldEl0ZW1IYXNoKHBhdGgpO1xuICAgICAgICByZXR1cm4gdGhpcy5oYXNoTWFwLmdldChoYXNoKT8uZmluZCh4ID0+IHRoaXMuYXJlSXRlbXNFcXVhbCh4LCBwYXRoKSkgIT0gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIHB1YmxpYyBpc0VtcHR5KCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5oYXNoTWFwLnNpemUgPT09IDA7XG4gICAgfVxuXG4gICAgcHVibGljIHZhbHVlcygpOiBJdGVyYWJsZTxUST4ge1xuICAgICAgICByZXR1cm4gSXRlcmF0b3IuZnJvbSh0aGlzLmhhc2hNYXAudmFsdWVzKCkpLmZsYXRNYXAoeCA9PiB4KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xlYXIoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaGFzaE1hcC5jbGVhcigpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBnZXRJdGVtSGFzaChrZXk6IFRJKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIGtleS5nZXRIYXNoKCk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGFyZUl0ZW1zRXF1YWwobGVmdDogVEksIHJpZ2h0OiBUSSk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gbGVmdC5pc0VxdWFscyhyaWdodCk7XG4gICAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFFTyxNQUFNQSxJQUFJLENBQTRCO0VBQUFDLFlBQUE7SUFBQSxLQUN4QkMsT0FBTyxHQUFHLElBQUlDLEdBQUcsQ0FBZSxDQUFDO0VBQUE7RUFFM0NDLEdBQUdBLENBQUNDLElBQVEsRUFBVztJQUMxQixNQUFNQyxJQUFJLEdBQUcsSUFBSSxDQUFDQyxXQUFXLENBQUNGLElBQUksQ0FBQztJQUNuQyxNQUFNRyxJQUFJLEdBQUcsSUFBSSxDQUFDTixPQUFPLENBQUNPLEdBQUcsQ0FBQ0gsSUFBSSxDQUFDO0lBQ25DLElBQUlFLElBQUksSUFBSUUsU0FBUyxFQUFFO01BQ25CLElBQUksQ0FBQ1IsT0FBTyxDQUFDUyxHQUFHLENBQUNMLElBQUksRUFBRSxDQUFDRCxJQUFJLENBQUMsQ0FBQztNQUM5QixPQUFPLElBQUk7SUFDZixDQUFDLE1BQU07TUFDSCxJQUFJRyxJQUFJLENBQUNJLElBQUksQ0FBQ0MsQ0FBQyxJQUFJLElBQUksQ0FBQ0MsYUFBYSxDQUFDRCxDQUFDLEVBQUVSLElBQUksQ0FBQyxDQUFDLElBQUlLLFNBQVMsRUFBRTtRQUMxREYsSUFBSSxDQUFDTyxJQUFJLENBQUNWLElBQUksQ0FBQztRQUNmLE9BQU8sSUFBSTtNQUNmO0lBQ0o7SUFDQSxPQUFPLEtBQUs7RUFDaEI7RUFFT1csTUFBTUEsQ0FBQ1gsSUFBUSxFQUFRO0lBQzFCLE1BQU1DLElBQUksR0FBRyxJQUFJLENBQUNDLFdBQVcsQ0FBQ0YsSUFBSSxDQUFDO0lBQ25DLE1BQU1HLElBQUksR0FBRyxJQUFJLENBQUNOLE9BQU8sQ0FBQ08sR0FBRyxDQUFDSCxJQUFJLENBQUM7SUFDbkMsSUFBSUUsSUFBSSxJQUFJRSxTQUFTLEVBQUU7TUFDbkIsSUFBSSxDQUFDUixPQUFPLENBQUNTLEdBQUcsQ0FDWkwsSUFBSSxFQUNKRSxJQUFJLENBQUNTLE1BQU0sQ0FBQ0osQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDQyxhQUFhLENBQUNELENBQUMsRUFBRVIsSUFBSSxDQUFDLENBQ2pELENBQUM7SUFDTDtFQUNKO0VBRU9hLEdBQUdBLENBQUNiLElBQVEsRUFBVztJQUFBLElBQUFjLGlCQUFBO0lBQzFCLE1BQU1iLElBQUksR0FBRyxJQUFJLENBQUNDLFdBQVcsQ0FBQ0YsSUFBSSxDQUFDO0lBQ25DLE9BQU8sRUFBQWMsaUJBQUEsT0FBSSxDQUFDakIsT0FBTyxDQUFDTyxHQUFHLENBQUNILElBQUksQ0FBQyxjQUFBYSxpQkFBQSx1QkFBdEJBLGlCQUFBLENBQXdCUCxJQUFJLENBQUNDLENBQUMsSUFBSSxJQUFJLENBQUNDLGFBQWEsQ0FBQ0QsQ0FBQyxFQUFFUixJQUFJLENBQUMsQ0FBQyxLQUFJSyxTQUFTO0VBQ3RGO0VBRU9VLE9BQU9BLENBQUEsRUFBWTtJQUN0QixPQUFPLElBQUksQ0FBQ2xCLE9BQU8sQ0FBQ21CLElBQUksS0FBSyxDQUFDO0VBQ2xDO0VBRU9DLE1BQU1BLENBQUEsRUFBaUI7SUFDMUIsT0FBT0MsUUFBUSxDQUFDQyxJQUFJLENBQUMsSUFBSSxDQUFDdEIsT0FBTyxDQUFDb0IsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDRyxPQUFPLENBQUNaLENBQUMsSUFBSUEsQ0FBQyxDQUFDO0VBQy9EO0VBRU9hLEtBQUtBLENBQUEsRUFBUztJQUNqQixJQUFJLENBQUN4QixPQUFPLENBQUN3QixLQUFLLENBQUMsQ0FBQztFQUN4QjtFQUVVbkIsV0FBV0EsQ0FBQ29CLEdBQU8sRUFBVTtJQUNuQyxPQUFPQSxHQUFHLENBQUNDLE9BQU8sQ0FBQyxDQUFDO0VBQ3hCO0VBRVVkLGFBQWFBLENBQUNlLElBQVEsRUFBRUMsS0FBUyxFQUFXO0lBQ2xELE9BQU9ELElBQUksQ0FBQ0UsUUFBUSxDQUFDRCxLQUFLLENBQUM7RUFDL0I7QUFDSjtBQUFDRSxPQUFBLENBQUFoQyxJQUFBLEdBQUFBLElBQUEifQ==
59
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTZXQyIiwiY29uc3RydWN0b3IiLCJzb3VyY2UiLCJoYXNoTWFwIiwiTWFwIiwidW5kZWZpbmVkIiwic291cmNlRWxlbWVudCIsImFkZCIsInBhdGgiLCJoYXNoIiwiZ2V0SXRlbUhhc2giLCJsaXN0IiwiZ2V0Iiwic2V0IiwiZmluZCIsIngiLCJhcmVJdGVtc0VxdWFsIiwicHVzaCIsInJlbW92ZSIsImZpbHRlciIsImhhcyIsIl90aGlzJGhhc2hNYXAkZ2V0IiwiaXNFbXB0eSIsInNpemUiLCJ2YWx1ZXMiLCJJdGVyYXRvciIsImZyb20iLCJmbGF0TWFwIiwiY2xlYXIiLCJrZXkiLCJnZXRIYXNoIiwibGVmdCIsInJpZ2h0IiwiaXNFcXVhbHMiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vQ29tbW9uL01vZGVsUGF0aC9TZXQvU2V0Mi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJRXF1YXRhYmxlIH0gZnJvbSBcIi4uL0lFcXVhdGFibGVcIjtcblxuZXhwb3J0IGNsYXNzIFNldDI8VEkgZXh0ZW5kcyBJRXF1YXRhYmxlPFRJPj4ge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgaGFzaE1hcCA9IG5ldyBNYXA8bnVtYmVyLCBUSVtdPigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKHNvdXJjZT86IEl0ZXJhYmxlPFRJPikge1xuICAgICAgICBpZiAoc291cmNlICE9IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgZm9yIChjb25zdCBzb3VyY2VFbGVtZW50IG9mIHNvdXJjZSkge1xuICAgICAgICAgICAgICAgIHRoaXMuYWRkKHNvdXJjZUVsZW1lbnQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGFkZChwYXRoOiBUSSk6IGJvb2xlYW4ge1xuICAgICAgICBjb25zdCBoYXNoID0gdGhpcy5nZXRJdGVtSGFzaChwYXRoKTtcbiAgICAgICAgY29uc3QgbGlzdCA9IHRoaXMuaGFzaE1hcC5nZXQoaGFzaCk7XG4gICAgICAgIGlmIChsaXN0ID09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhpcy5oYXNoTWFwLnNldChoYXNoLCBbcGF0aF0pO1xuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBpZiAobGlzdC5maW5kKHggPT4gdGhpcy5hcmVJdGVtc0VxdWFsKHgsIHBhdGgpKSA9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgICAgICBsaXN0LnB1c2gocGF0aCk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIHB1YmxpYyByZW1vdmUocGF0aDogVEkpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgaGFzaCA9IHRoaXMuZ2V0SXRlbUhhc2gocGF0aCk7XG4gICAgICAgIGNvbnN0IGxpc3QgPSB0aGlzLmhhc2hNYXAuZ2V0KGhhc2gpO1xuICAgICAgICBpZiAobGlzdCAhPSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRoaXMuaGFzaE1hcC5zZXQoXG4gICAgICAgICAgICAgICAgaGFzaCxcbiAgICAgICAgICAgICAgICBsaXN0LmZpbHRlcih4ID0+ICF0aGlzLmFyZUl0ZW1zRXF1YWwoeCwgcGF0aCkpXG4gICAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGhhcyhwYXRoOiBUSSk6IGJvb2xlYW4ge1xuICAgICAgICBjb25zdCBoYXNoID0gdGhpcy5nZXRJdGVtSGFzaChwYXRoKTtcbiAgICAgICAgcmV0dXJuIHRoaXMuaGFzaE1hcC5nZXQoaGFzaCk/LmZpbmQoeCA9PiB0aGlzLmFyZUl0ZW1zRXF1YWwoeCwgcGF0aCkpICE9IHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBwdWJsaWMgaXNFbXB0eSgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaGFzaE1hcC5zaXplID09PSAwO1xuICAgIH1cblxuICAgIHB1YmxpYyB2YWx1ZXMoKTogSXRlcmFibGU8VEk+IHtcbiAgICAgICAgcmV0dXJuIEl0ZXJhdG9yLmZyb20odGhpcy5oYXNoTWFwLnZhbHVlcygpKS5mbGF0TWFwKHggPT4geCk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsZWFyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmhhc2hNYXAuY2xlYXIoKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgZ2V0SXRlbUhhc2goa2V5OiBUSSk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiBrZXkuZ2V0SGFzaCgpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBhcmVJdGVtc0VxdWFsKGxlZnQ6IFRJLCByaWdodDogVEkpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIGxlZnQuaXNFcXVhbHMocmlnaHQpO1xuICAgIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRU8sTUFBTUEsSUFBSSxDQUE0QjtFQUdsQ0MsV0FBV0EsQ0FBQ0MsTUFBcUIsRUFBRTtJQUFBLEtBRnpCQyxPQUFPLEdBQUcsSUFBSUMsR0FBRyxDQUFlLENBQUM7SUFHOUMsSUFBSUYsTUFBTSxJQUFJRyxTQUFTLEVBQUU7TUFDckIsS0FBSyxNQUFNQyxhQUFhLElBQUlKLE1BQU0sRUFBRTtRQUNoQyxJQUFJLENBQUNLLEdBQUcsQ0FBQ0QsYUFBYSxDQUFDO01BQzNCO0lBQ0o7RUFDSjtFQUVPQyxHQUFHQSxDQUFDQyxJQUFRLEVBQVc7SUFDMUIsTUFBTUMsSUFBSSxHQUFHLElBQUksQ0FBQ0MsV0FBVyxDQUFDRixJQUFJLENBQUM7SUFDbkMsTUFBTUcsSUFBSSxHQUFHLElBQUksQ0FBQ1IsT0FBTyxDQUFDUyxHQUFHLENBQUNILElBQUksQ0FBQztJQUNuQyxJQUFJRSxJQUFJLElBQUlOLFNBQVMsRUFBRTtNQUNuQixJQUFJLENBQUNGLE9BQU8sQ0FBQ1UsR0FBRyxDQUFDSixJQUFJLEVBQUUsQ0FBQ0QsSUFBSSxDQUFDLENBQUM7TUFDOUIsT0FBTyxJQUFJO0lBQ2YsQ0FBQyxNQUFNO01BQ0gsSUFBSUcsSUFBSSxDQUFDRyxJQUFJLENBQUNDLENBQUMsSUFBSSxJQUFJLENBQUNDLGFBQWEsQ0FBQ0QsQ0FBQyxFQUFFUCxJQUFJLENBQUMsQ0FBQyxJQUFJSCxTQUFTLEVBQUU7UUFDMURNLElBQUksQ0FBQ00sSUFBSSxDQUFDVCxJQUFJLENBQUM7UUFDZixPQUFPLElBQUk7TUFDZjtJQUNKO0lBQ0EsT0FBTyxLQUFLO0VBQ2hCO0VBRU9VLE1BQU1BLENBQUNWLElBQVEsRUFBUTtJQUMxQixNQUFNQyxJQUFJLEdBQUcsSUFBSSxDQUFDQyxXQUFXLENBQUNGLElBQUksQ0FBQztJQUNuQyxNQUFNRyxJQUFJLEdBQUcsSUFBSSxDQUFDUixPQUFPLENBQUNTLEdBQUcsQ0FBQ0gsSUFBSSxDQUFDO0lBQ25DLElBQUlFLElBQUksSUFBSU4sU0FBUyxFQUFFO01BQ25CLElBQUksQ0FBQ0YsT0FBTyxDQUFDVSxHQUFHLENBQ1pKLElBQUksRUFDSkUsSUFBSSxDQUFDUSxNQUFNLENBQUNKLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQ0MsYUFBYSxDQUFDRCxDQUFDLEVBQUVQLElBQUksQ0FBQyxDQUNqRCxDQUFDO0lBQ0w7RUFDSjtFQUVPWSxHQUFHQSxDQUFDWixJQUFRLEVBQVc7SUFBQSxJQUFBYSxpQkFBQTtJQUMxQixNQUFNWixJQUFJLEdBQUcsSUFBSSxDQUFDQyxXQUFXLENBQUNGLElBQUksQ0FBQztJQUNuQyxPQUFPLEVBQUFhLGlCQUFBLE9BQUksQ0FBQ2xCLE9BQU8sQ0FBQ1MsR0FBRyxDQUFDSCxJQUFJLENBQUMsY0FBQVksaUJBQUEsdUJBQXRCQSxpQkFBQSxDQUF3QlAsSUFBSSxDQUFDQyxDQUFDLElBQUksSUFBSSxDQUFDQyxhQUFhLENBQUNELENBQUMsRUFBRVAsSUFBSSxDQUFDLENBQUMsS0FBSUgsU0FBUztFQUN0RjtFQUVPaUIsT0FBT0EsQ0FBQSxFQUFZO0lBQ3RCLE9BQU8sSUFBSSxDQUFDbkIsT0FBTyxDQUFDb0IsSUFBSSxLQUFLLENBQUM7RUFDbEM7RUFFT0MsTUFBTUEsQ0FBQSxFQUFpQjtJQUMxQixPQUFPQyxRQUFRLENBQUNDLElBQUksQ0FBQyxJQUFJLENBQUN2QixPQUFPLENBQUNxQixNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUNHLE9BQU8sQ0FBQ1osQ0FBQyxJQUFJQSxDQUFDLENBQUM7RUFDL0Q7RUFFT2EsS0FBS0EsQ0FBQSxFQUFTO0lBQ2pCLElBQUksQ0FBQ3pCLE9BQU8sQ0FBQ3lCLEtBQUssQ0FBQyxDQUFDO0VBQ3hCO0VBRVVsQixXQUFXQSxDQUFDbUIsR0FBTyxFQUFVO0lBQ25DLE9BQU9BLEdBQUcsQ0FBQ0MsT0FBTyxDQUFDLENBQUM7RUFDeEI7RUFFVWQsYUFBYUEsQ0FBQ2UsSUFBUSxFQUFFQyxLQUFTLEVBQVc7SUFDbEQsT0FBT0QsSUFBSSxDQUFDRSxRQUFRLENBQUNELEtBQUssQ0FBQztFQUMvQjtBQUNKO0FBQUNFLE9BQUEsQ0FBQWxDLElBQUEsR0FBQUEsSUFBQSJ9
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vQ29tbW9uL1BpY2tsaXN0QXBpQ2xpZW50L0lQaWNrbGlzdEFwaUNsaWVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaWNrbGlzdFJlcXVlc3RWMiB9IGZyb20gXCIuL1R5cGVzL1BpY2tsaXN0UmVxdWVzdFYyXCI7XG5pbXBvcnQgeyBQaWNrbGlzdFJlc3VsdFYyIH0gZnJvbSBcIi4vVHlwZXMvUGlja2xpc3RSZXN1bHRWMlwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIElQaWNrbGlzdEFwaUNsaWVudCB7XG4gICAgc2VhcmNoQXN5bmMoZ2lkOiBzdHJpbmcsIHJlcXVlc3Q6IFJlYWRvbmx5PFBpY2tsaXN0UmVxdWVzdFYyPik6IFByb21pc2U8UGlja2xpc3RSZXN1bHRWMj47XG59XG4iXSwibWFwcGluZ3MiOiIifQ==
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.PicklistApiClient = void 0;
7
+ var _AuthenticationMode = require("../HttpClient/AuthenticationMode");
8
+ var _HttpClient = require("../HttpClient/HttpClient");
9
+ class PicklistApiClient {
10
+ constructor(fetchImpl, baseUrl, resourceZone, authentication) {
11
+ this.httpClient = void 0;
12
+ this.httpClient = new _HttpClient.HttpClient(fetchImpl, baseUrl, (0, _AuthenticationMode.createAuthenticationProvider)(authentication), {
13
+ resourceZone: resourceZone
14
+ });
15
+ }
16
+ searchAsync(gid, request) {
17
+ const {
18
+ filter,
19
+ take,
20
+ skip
21
+ } = request;
22
+ return this.httpClient.get(`v2/${gid}/`).withQueryParams({
23
+ filter: filter,
24
+ take: take,
25
+ skip: skip
26
+ }).json();
27
+ }
28
+ }
29
+ exports.PicklistApiClient = PicklistApiClient;
30
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQXV0aGVudGljYXRpb25Nb2RlIiwicmVxdWlyZSIsIl9IdHRwQ2xpZW50IiwiUGlja2xpc3RBcGlDbGllbnQiLCJjb25zdHJ1Y3RvciIsImZldGNoSW1wbCIsImJhc2VVcmwiLCJyZXNvdXJjZVpvbmUiLCJhdXRoZW50aWNhdGlvbiIsImh0dHBDbGllbnQiLCJIdHRwQ2xpZW50IiwiY3JlYXRlQXV0aGVudGljYXRpb25Qcm92aWRlciIsInNlYXJjaEFzeW5jIiwiZ2lkIiwicmVxdWVzdCIsImZpbHRlciIsInRha2UiLCJza2lwIiwiZ2V0Iiwid2l0aFF1ZXJ5UGFyYW1zIiwianNvbiIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9Db21tb24vUGlja2xpc3RBcGlDbGllbnQvUGlja2xpc3RBcGlDbGllbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUh0dHBDbGllbnQgfSBmcm9tIFwiLi4vSHR0cENsaWVudC9JSHR0cENsaWVudFwiO1xuaW1wb3J0IHsgRmV0Y2ggfSBmcm9tIFwiLi4vSHR0cENsaWVudC9GZXRjaEltcGxlbWVudGF0aW9uL0ZldGNoXCI7XG5pbXBvcnQgeyBBdXRoZW50aWNhdGlvbk1vZGUsIGNyZWF0ZUF1dGhlbnRpY2F0aW9uUHJvdmlkZXIgfSBmcm9tIFwiLi4vSHR0cENsaWVudC9BdXRoZW50aWNhdGlvbk1vZGVcIjtcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tIFwiLi4vSHR0cENsaWVudC9IdHRwQ2xpZW50XCI7XG5cbmltcG9ydCB7IElQaWNrbGlzdEFwaUNsaWVudCB9IGZyb20gXCIuL0lQaWNrbGlzdEFwaUNsaWVudFwiO1xuaW1wb3J0IHsgUGlja2xpc3RSZXF1ZXN0VjIgfSBmcm9tIFwiLi9UeXBlcy9QaWNrbGlzdFJlcXVlc3RWMlwiO1xuaW1wb3J0IHsgUGlja2xpc3RSZXN1bHRWMiB9IGZyb20gXCIuL1R5cGVzL1BpY2tsaXN0UmVzdWx0VjJcIjtcblxuZXhwb3J0IGNsYXNzIFBpY2tsaXN0QXBpQ2xpZW50IGltcGxlbWVudHMgSVBpY2tsaXN0QXBpQ2xpZW50IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGh0dHBDbGllbnQ6IElIdHRwQ2xpZW50O1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBmZXRjaEltcGw6IEZldGNoLFxuICAgICAgICBiYXNlVXJsOiBzdHJpbmcsXG4gICAgICAgIHJlc291cmNlWm9uZTogdW5kZWZpbmVkIHwgc3RyaW5nLFxuICAgICAgICBhdXRoZW50aWNhdGlvbjogdW5kZWZpbmVkIHwgQXV0aGVudGljYXRpb25Nb2RlXG4gICAgKSB7XG4gICAgICAgIHRoaXMuaHR0cENsaWVudCA9IG5ldyBIdHRwQ2xpZW50KGZldGNoSW1wbCwgYmFzZVVybCwgY3JlYXRlQXV0aGVudGljYXRpb25Qcm92aWRlcihhdXRoZW50aWNhdGlvbiksIHtcbiAgICAgICAgICAgIHJlc291cmNlWm9uZTogcmVzb3VyY2Vab25lLFxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgc2VhcmNoQXN5bmMoZ2lkOiBzdHJpbmcsIHJlcXVlc3Q6IFJlYWRvbmx5PFBpY2tsaXN0UmVxdWVzdFYyPik6IFByb21pc2U8UGlja2xpc3RSZXN1bHRWMj4ge1xuICAgICAgICBjb25zdCB7IGZpbHRlciwgdGFrZSwgc2tpcCB9ID0gcmVxdWVzdDtcbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudFxuICAgICAgICAgICAgLmdldChgdjIvJHtnaWR9L2ApXG4gICAgICAgICAgICAud2l0aFF1ZXJ5UGFyYW1zKHsgZmlsdGVyOiBmaWx0ZXIsIHRha2U6IHRha2UsIHNraXA6IHNraXAgfSlcbiAgICAgICAgICAgIC5qc29uPFBpY2tsaXN0UmVzdWx0VjI+KCk7XG4gICAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFFQSxJQUFBQSxtQkFBQSxHQUFBQyxPQUFBO0FBQ0EsSUFBQUMsV0FBQSxHQUFBRCxPQUFBO0FBTU8sTUFBTUUsaUJBQWlCLENBQStCO0VBR2xEQyxXQUFXQSxDQUNkQyxTQUFnQixFQUNoQkMsT0FBZSxFQUNmQyxZQUFnQyxFQUNoQ0MsY0FBOEMsRUFDaEQ7SUFBQSxLQVBlQyxVQUFVO0lBUXZCLElBQUksQ0FBQ0EsVUFBVSxHQUFHLElBQUlDLHNCQUFVLENBQUNMLFNBQVMsRUFBRUMsT0FBTyxFQUFFLElBQUFLLGdEQUE0QixFQUFDSCxjQUFjLENBQUMsRUFBRTtNQUMvRkQsWUFBWSxFQUFFQTtJQUNsQixDQUFDLENBQUM7RUFDTjtFQUVPSyxXQUFXQSxDQUFDQyxHQUFXLEVBQUVDLE9BQW9DLEVBQTZCO0lBQzdGLE1BQU07TUFBRUMsTUFBTTtNQUFFQyxJQUFJO01BQUVDO0lBQUssQ0FBQyxHQUFHSCxPQUFPO0lBQ3RDLE9BQU8sSUFBSSxDQUFDTCxVQUFVLENBQ2pCUyxHQUFHLENBQUUsTUFBS0wsR0FBSSxHQUFFLENBQUMsQ0FDakJNLGVBQWUsQ0FBQztNQUFFSixNQUFNLEVBQUVBLE1BQU07TUFBRUMsSUFBSSxFQUFFQSxJQUFJO01BQUVDLElBQUksRUFBRUE7SUFBSyxDQUFDLENBQUMsQ0FDM0RHLElBQUksQ0FBbUIsQ0FBQztFQUNqQztBQUNKO0FBQUNDLE9BQUEsQ0FBQWxCLGlCQUFBLEdBQUFBLGlCQUFBIn0=
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.buildPicklistRequest = void 0;
7
+ var _util = require("util");
8
+ var _DigestFilterColumnSerializer = require("./Serializers/DigestFilterColumnSerializer");
9
+ var _DigestLogicalFilterSerializer = require("./Serializers/DigestLogicalFilterSerializer");
10
+ const buildPicklistRequest = filter => {
11
+ if ((0, _util.isNullOrUndefined)(filter)) {
12
+ return {};
13
+ }
14
+ const picklistFilter = convertToPicklistFilter(filter.filter);
15
+ return {
16
+ filter: picklistFilter,
17
+ skip: filter === null || filter === void 0 ? void 0 : filter.skip,
18
+ take: filter === null || filter === void 0 ? void 0 : filter.take
19
+ };
20
+ };
21
+ exports.buildPicklistRequest = buildPicklistRequest;
22
+ const convertToPicklistFilter = filter => {
23
+ if ((0, _util.isNullOrUndefined)(filter)) {
24
+ return undefined;
25
+ }
26
+ if ("operands" in filter) {
27
+ return (0, _DigestLogicalFilterSerializer.serializeToString)(filter);
28
+ }
29
+ if ("column" in filter) {
30
+ return (0, _DigestFilterColumnSerializer.serializeToString)(filter);
31
+ }
32
+ return undefined;
33
+ };
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdXRpbCIsInJlcXVpcmUiLCJfRGlnZXN0RmlsdGVyQ29sdW1uU2VyaWFsaXplciIsIl9EaWdlc3RMb2dpY2FsRmlsdGVyU2VyaWFsaXplciIsImJ1aWxkUGlja2xpc3RSZXF1ZXN0IiwiZmlsdGVyIiwiaXNOdWxsT3JVbmRlZmluZWQiLCJwaWNrbGlzdEZpbHRlciIsImNvbnZlcnRUb1BpY2tsaXN0RmlsdGVyIiwic2tpcCIsInRha2UiLCJleHBvcnRzIiwidW5kZWZpbmVkIiwic2VyaWFsaXplRGlnZXN0TG9naWNhbEZpbHRlclRvU3RyaW5nIiwic2VyaWFsaXplRGlnZXN0RmlsdGVyQ29sdW1uVG9TdHJpbmciXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9Db21tb24vUGlja2xpc3RBcGlDbGllbnQvUGlja2xpc3RSZXF1ZXN0VjJCdWlsZGVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzTnVsbE9yVW5kZWZpbmVkIH0gZnJvbSBcInV0aWxcIjtcblxuaW1wb3J0IHsgRGlnZXN0RmlsdGVyLCBEaWdlc3RRdWVyeUZpbHRlciB9IGZyb20gXCIuLi9DYW5keUFwaUNsaWVudC9EaWdlc3RBcGlDbGllbnQvVHlwZXMvRGlnZXN0UXVlcnlGaWx0ZXJcIjtcblxuaW1wb3J0IHsgUGlja2xpc3RSZXF1ZXN0VjIgfSBmcm9tIFwiLi9UeXBlcy9QaWNrbGlzdFJlcXVlc3RWMlwiO1xuaW1wb3J0IHsgc2VyaWFsaXplVG9TdHJpbmcgYXMgc2VyaWFsaXplRGlnZXN0RmlsdGVyQ29sdW1uVG9TdHJpbmcgfSBmcm9tIFwiLi9TZXJpYWxpemVycy9EaWdlc3RGaWx0ZXJDb2x1bW5TZXJpYWxpemVyXCI7XG5pbXBvcnQgeyBzZXJpYWxpemVUb1N0cmluZyBhcyBzZXJpYWxpemVEaWdlc3RMb2dpY2FsRmlsdGVyVG9TdHJpbmcgfSBmcm9tIFwiLi9TZXJpYWxpemVycy9EaWdlc3RMb2dpY2FsRmlsdGVyU2VyaWFsaXplclwiO1xuXG5leHBvcnQgY29uc3QgYnVpbGRQaWNrbGlzdFJlcXVlc3QgPSAoZmlsdGVyPzogRGlnZXN0UXVlcnlGaWx0ZXIpOiBQaWNrbGlzdFJlcXVlc3RWMiA9PiB7XG4gICAgaWYgKGlzTnVsbE9yVW5kZWZpbmVkKGZpbHRlcikpIHtcbiAgICAgICAgcmV0dXJuIHt9O1xuICAgIH1cblxuICAgIGNvbnN0IHBpY2tsaXN0RmlsdGVyID0gY29udmVydFRvUGlja2xpc3RGaWx0ZXIoZmlsdGVyLmZpbHRlcik7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgZmlsdGVyOiBwaWNrbGlzdEZpbHRlcixcbiAgICAgICAgc2tpcDogZmlsdGVyPy5za2lwLFxuICAgICAgICB0YWtlOiBmaWx0ZXI/LnRha2UsXG4gICAgfTtcbn07XG5cbmNvbnN0IGNvbnZlcnRUb1BpY2tsaXN0RmlsdGVyID0gKGZpbHRlcj86IERpZ2VzdEZpbHRlcik6IHN0cmluZyB8IHVuZGVmaW5lZCA9PiB7XG4gICAgaWYgKGlzTnVsbE9yVW5kZWZpbmVkKGZpbHRlcikpIHtcbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBpZiAoXCJvcGVyYW5kc1wiIGluIGZpbHRlcikge1xuICAgICAgICByZXR1cm4gc2VyaWFsaXplRGlnZXN0TG9naWNhbEZpbHRlclRvU3RyaW5nKGZpbHRlcik7XG4gICAgfVxuXG4gICAgaWYgKFwiY29sdW1uXCIgaW4gZmlsdGVyKSB7XG4gICAgICAgIHJldHVybiBzZXJpYWxpemVEaWdlc3RGaWx0ZXJDb2x1bW5Ub1N0cmluZyhmaWx0ZXIpO1xuICAgIH1cblxuICAgIHJldHVybiB1bmRlZmluZWQ7XG59O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxLQUFBLEdBQUFDLE9BQUE7QUFLQSxJQUFBQyw2QkFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsOEJBQUEsR0FBQUYsT0FBQTtBQUVPLE1BQU1HLG9CQUFvQixHQUFJQyxNQUEwQixJQUF3QjtFQUNuRixJQUFJLElBQUFDLHVCQUFpQixFQUFDRCxNQUFNLENBQUMsRUFBRTtJQUMzQixPQUFPLENBQUMsQ0FBQztFQUNiO0VBRUEsTUFBTUUsY0FBYyxHQUFHQyx1QkFBdUIsQ0FBQ0gsTUFBTSxDQUFDQSxNQUFNLENBQUM7RUFDN0QsT0FBTztJQUNIQSxNQUFNLEVBQUVFLGNBQWM7SUFDdEJFLElBQUksRUFBRUosTUFBTSxhQUFOQSxNQUFNLHVCQUFOQSxNQUFNLENBQUVJLElBQUk7SUFDbEJDLElBQUksRUFBRUwsTUFBTSxhQUFOQSxNQUFNLHVCQUFOQSxNQUFNLENBQUVLO0VBQ2xCLENBQUM7QUFDTCxDQUFDO0FBQUNDLE9BQUEsQ0FBQVAsb0JBQUEsR0FBQUEsb0JBQUE7QUFFRixNQUFNSSx1QkFBdUIsR0FBSUgsTUFBcUIsSUFBeUI7RUFDM0UsSUFBSSxJQUFBQyx1QkFBaUIsRUFBQ0QsTUFBTSxDQUFDLEVBQUU7SUFDM0IsT0FBT08sU0FBUztFQUNwQjtFQUVBLElBQUksVUFBVSxJQUFJUCxNQUFNLEVBQUU7SUFDdEIsT0FBTyxJQUFBUSxnREFBb0MsRUFBQ1IsTUFBTSxDQUFDO0VBQ3ZEO0VBRUEsSUFBSSxRQUFRLElBQUlBLE1BQU0sRUFBRTtJQUNwQixPQUFPLElBQUFTLCtDQUFtQyxFQUFDVCxNQUFNLENBQUM7RUFDdEQ7RUFFQSxPQUFPTyxTQUFTO0FBQ3BCLENBQUMifQ==