@fgv/ts-json 1.9.6 → 2.0.2-alpha.0

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 (127) hide show
  1. package/dist/ts-json.d.ts +1826 -0
  2. package/dist/tsdoc-metadata.json +11 -0
  3. package/lib/index.d.ts +5 -0
  4. package/lib/index.d.ts.map +1 -0
  5. package/lib/index.js +42 -0
  6. package/lib/index.js.map +1 -0
  7. package/lib/packlets/context/compositeJsonMap.d.ts +60 -0
  8. package/lib/packlets/context/compositeJsonMap.d.ts.map +1 -0
  9. package/lib/packlets/context/compositeJsonMap.js +105 -0
  10. package/lib/packlets/context/compositeJsonMap.js.map +1 -0
  11. package/lib/packlets/context/contextHelpers.d.ts +116 -0
  12. package/lib/packlets/context/contextHelpers.d.ts.map +1 -0
  13. package/lib/packlets/context/contextHelpers.js +191 -0
  14. package/lib/packlets/context/contextHelpers.js.map +1 -0
  15. package/lib/packlets/context/index.d.ts +4 -0
  16. package/lib/packlets/context/index.d.ts.map +1 -0
  17. package/lib/packlets/context/index.js +31 -0
  18. package/lib/packlets/context/index.js.map +1 -0
  19. package/lib/packlets/context/jsonContext.d.ts +84 -0
  20. package/lib/packlets/context/jsonContext.d.ts.map +1 -0
  21. package/lib/packlets/context/jsonContext.js +41 -0
  22. package/lib/packlets/context/jsonContext.js.map +1 -0
  23. package/lib/packlets/converters/converters.d.ts +54 -0
  24. package/lib/packlets/converters/converters.d.ts.map +1 -0
  25. package/lib/packlets/converters/converters.js +105 -0
  26. package/lib/packlets/converters/converters.js.map +1 -0
  27. package/lib/packlets/converters/file.d.ts +83 -0
  28. package/lib/packlets/converters/file.d.ts.map +1 -0
  29. package/lib/packlets/converters/file.js +162 -0
  30. package/lib/packlets/converters/file.js.map +1 -0
  31. package/lib/packlets/converters/index.d.ts +5 -0
  32. package/lib/packlets/converters/index.d.ts.map +1 -0
  33. package/lib/packlets/converters/index.js +56 -0
  34. package/lib/packlets/converters/index.js.map +1 -0
  35. package/lib/packlets/converters/jsonConverter.d.ts +276 -0
  36. package/lib/packlets/converters/jsonConverter.d.ts.map +1 -0
  37. package/lib/packlets/converters/jsonConverter.js +310 -0
  38. package/lib/packlets/converters/jsonConverter.js.map +1 -0
  39. package/lib/packlets/editor/common.d.ts +67 -0
  40. package/lib/packlets/editor/common.d.ts.map +1 -0
  41. package/lib/packlets/editor/common.js +3 -0
  42. package/lib/packlets/editor/common.js.map +1 -0
  43. package/lib/packlets/editor/index.d.ts +8 -0
  44. package/lib/packlets/editor/index.d.ts.map +1 -0
  45. package/{jsonEditor → lib/packlets/editor}/index.js +15 -9
  46. package/lib/packlets/editor/index.js.map +1 -0
  47. package/lib/packlets/editor/jsonEditor.d.ts +155 -0
  48. package/lib/packlets/editor/jsonEditor.d.ts.map +1 -0
  49. package/lib/packlets/editor/jsonEditor.js +332 -0
  50. package/lib/packlets/editor/jsonEditor.js.map +1 -0
  51. package/lib/packlets/editor/jsonEditorRule.d.ts +64 -0
  52. package/lib/packlets/editor/jsonEditorRule.d.ts.map +1 -0
  53. package/lib/packlets/editor/jsonEditorRule.js +54 -0
  54. package/lib/packlets/editor/jsonEditorRule.js.map +1 -0
  55. package/lib/packlets/editor/jsonEditorState.d.ts +125 -0
  56. package/lib/packlets/editor/jsonEditorState.d.ts.map +1 -0
  57. package/lib/packlets/editor/jsonEditorState.js +177 -0
  58. package/lib/packlets/editor/jsonEditorState.js.map +1 -0
  59. package/lib/packlets/editor/jsonReferenceMap.d.ts +303 -0
  60. package/lib/packlets/editor/jsonReferenceMap.d.ts.map +1 -0
  61. package/lib/packlets/editor/jsonReferenceMap.js +324 -0
  62. package/lib/packlets/editor/jsonReferenceMap.js.map +1 -0
  63. package/lib/packlets/editor/rules/conditional.d.ts +107 -0
  64. package/lib/packlets/editor/rules/conditional.d.ts.map +1 -0
  65. package/lib/packlets/editor/rules/conditional.js +167 -0
  66. package/lib/packlets/editor/rules/conditional.js.map +1 -0
  67. package/{jsonEditor → lib/packlets/editor}/rules/index.d.ts +1 -0
  68. package/lib/packlets/editor/rules/index.d.ts.map +1 -0
  69. package/lib/packlets/editor/rules/index.js +42 -0
  70. package/lib/packlets/editor/rules/index.js.map +1 -0
  71. package/lib/packlets/editor/rules/multivalue.d.ts +94 -0
  72. package/lib/packlets/editor/rules/multivalue.d.ts.map +1 -0
  73. package/lib/packlets/editor/rules/multivalue.js +141 -0
  74. package/lib/packlets/editor/rules/multivalue.js.map +1 -0
  75. package/lib/packlets/editor/rules/references.d.ts +69 -0
  76. package/lib/packlets/editor/rules/references.d.ts.map +1 -0
  77. package/lib/packlets/editor/rules/references.js +159 -0
  78. package/lib/packlets/editor/rules/references.js.map +1 -0
  79. package/lib/packlets/editor/rules/templates.d.ts +74 -0
  80. package/lib/packlets/editor/rules/templates.d.ts.map +1 -0
  81. package/lib/packlets/editor/rules/templates.js +127 -0
  82. package/lib/packlets/editor/rules/templates.js.map +1 -0
  83. package/lib/packlets/json/common.d.ts +85 -0
  84. package/lib/packlets/json/common.d.ts.map +1 -0
  85. package/lib/packlets/json/common.js +123 -0
  86. package/lib/packlets/json/common.js.map +1 -0
  87. package/lib/packlets/json/index.d.ts +2 -0
  88. package/lib/packlets/json/index.d.ts.map +1 -0
  89. package/lib/packlets/json/index.js +39 -0
  90. package/lib/packlets/json/index.js.map +1 -0
  91. package/package.json +58 -49
  92. package/common.d.ts +0 -58
  93. package/common.js +0 -116
  94. package/compositeJsonMap.d.ts +0 -47
  95. package/compositeJsonMap.js +0 -97
  96. package/contextHelpers.d.ts +0 -21
  97. package/contextHelpers.js +0 -101
  98. package/converters.d.ts +0 -37
  99. package/converters.js +0 -92
  100. package/file.d.ts +0 -60
  101. package/file.js +0 -140
  102. package/index.d.ts +0 -10
  103. package/index.js +0 -62
  104. package/jsonContext.d.ts +0 -74
  105. package/jsonContext.js +0 -40
  106. package/jsonConverter.d.ts +0 -229
  107. package/jsonConverter.js +0 -292
  108. package/jsonEditor/common.d.ts +0 -36
  109. package/jsonEditor/common.js +0 -3
  110. package/jsonEditor/index.d.ts +0 -5
  111. package/jsonEditor/jsonEditor.d.ts +0 -74
  112. package/jsonEditor/jsonEditor.js +0 -259
  113. package/jsonEditor/jsonEditorRule.d.ts +0 -47
  114. package/jsonEditor/jsonEditorRule.js +0 -44
  115. package/jsonEditor/jsonEditorState.d.ts +0 -24
  116. package/jsonEditor/jsonEditorState.js +0 -86
  117. package/jsonEditor/rules/conditional.d.ts +0 -84
  118. package/jsonEditor/rules/conditional.js +0 -146
  119. package/jsonEditor/rules/index.js +0 -21
  120. package/jsonEditor/rules/multivalue.d.ts +0 -78
  121. package/jsonEditor/rules/multivalue.js +0 -129
  122. package/jsonEditor/rules/references.d.ts +0 -62
  123. package/jsonEditor/rules/references.js +0 -158
  124. package/jsonEditor/rules/templates.d.ts +0 -56
  125. package/jsonEditor/rules/templates.js +0 -115
  126. package/jsonReferenceMap.d.ts +0 -138
  127. package/jsonReferenceMap.js +0 -202
package/common.d.ts DELETED
@@ -1,58 +0,0 @@
1
- import { Result } from '@fgv/ts-utils';
2
- export type JsonPrimitive = boolean | number | string | null;
3
- export interface JsonObject {
4
- [key: string]: JsonValue;
5
- }
6
- export type JsonValue = JsonPrimitive | JsonObject | JsonArray;
7
- export interface JsonArray extends Array<JsonValue> {
8
- }
9
- /**
10
- * Classes of JSON value
11
- */
12
- export type JsonValueType = 'primitive' | 'object' | 'array';
13
- /**
14
- * Test if an unknown is a JsonValue
15
- * @param from The unknown to be tested
16
- * @returns true if the supplied parameter is a valid JSON primitive,
17
- * false otherwise.
18
- */
19
- export declare function isJsonPrimitive(from: unknown): from is JsonPrimitive;
20
- /**
21
- * Test if an unknown is potentially a JsonObject
22
- * @param from The unknown to be tested
23
- * @returns true if the supplied parameter is a non-array object,
24
- * false otherwise.
25
- */
26
- export declare function isJsonObject(from: unknown): from is JsonObject;
27
- /**
28
- * Test if an unknown is potentially a JsonArary
29
- * @param from The unknown to be tested
30
- * @returns true if the supplied parameter is an array object,
31
- * false otherwise
32
- */
33
- export declare function isJsonArray(from: unknown): from is JsonArray;
34
- /**
35
- * Identifies whether some unknown value is a primitive,
36
- * object or array. Fails for any value that cannot be
37
- * converted to JSON (e.g. a function) _but_ this is a
38
- * shallow test - it does not test the properties of an
39
- * object or elements in an array.
40
- * @param from The unknown value to be tested
41
- */
42
- export declare function classifyJsonValue(from: unknown): Result<JsonValueType>;
43
- /**
44
- * Picks a nested field from a supplied JsonObject
45
- * @param src The object from which the field is to be picked
46
- * @param path Dot-separated path of the member to be picked
47
- * @returns Success with the property if the path is valid, Failure
48
- * otherwise.
49
- */
50
- export declare function pickJsonValue(src: JsonObject, path: string): Result<JsonValue>;
51
- /**
52
- * Picks a nested JsonObject from a supplied JsonObject
53
- * @param src The object from which the field is to be picked
54
- * @param path Dot-separated path of the member to be picked
55
- * @returns Success with the property if the path is valid and the value
56
- * is an object. Returns failure with details if an error occurs.
57
- */
58
- export declare function pickJsonObject(src: JsonObject, path: string): Result<JsonObject>;
package/common.js DELETED
@@ -1,116 +0,0 @@
1
- "use strict";
2
- /*
3
- * Copyright (c) 2020 Erik Fortune
4
- *
5
- * Permission is hereby granted, free of charge, to any person obtaining a copy
6
- * of this software and associated documentation files (the "Software"), to deal
7
- * in the Software without restriction, including without limitation the rights
8
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- * copies of the Software, and to permit persons to whom the Software is
10
- * furnished to do so, subject to the following conditions:
11
- *
12
- * The above copyright notice and this permission notice shall be included in all
13
- * copies or substantial portions of the Software.
14
- *
15
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- * SOFTWARE.
22
- */
23
- Object.defineProperty(exports, "__esModule", { value: true });
24
- exports.pickJsonObject = exports.pickJsonValue = exports.classifyJsonValue = exports.isJsonArray = exports.isJsonObject = exports.isJsonPrimitive = void 0;
25
- const ts_utils_1 = require("@fgv/ts-utils");
26
- /**
27
- * Test if an unknown is a JsonValue
28
- * @param from The unknown to be tested
29
- * @returns true if the supplied parameter is a valid JSON primitive,
30
- * false otherwise.
31
- */
32
- function isJsonPrimitive(from) {
33
- return ((typeof from === 'boolean') || (typeof from === 'number') || (typeof from === 'string') || (from === null));
34
- }
35
- exports.isJsonPrimitive = isJsonPrimitive;
36
- /**
37
- * Test if an unknown is potentially a JsonObject
38
- * @param from The unknown to be tested
39
- * @returns true if the supplied parameter is a non-array object,
40
- * false otherwise.
41
- */
42
- function isJsonObject(from) {
43
- return ((typeof from === 'object') && (!Array.isArray(from)));
44
- }
45
- exports.isJsonObject = isJsonObject;
46
- /**
47
- * Test if an unknown is potentially a JsonArary
48
- * @param from The unknown to be tested
49
- * @returns true if the supplied parameter is an array object,
50
- * false otherwise
51
- */
52
- function isJsonArray(from) {
53
- return (typeof from === 'object') && Array.isArray(from);
54
- }
55
- exports.isJsonArray = isJsonArray;
56
- /**
57
- * Identifies whether some unknown value is a primitive,
58
- * object or array. Fails for any value that cannot be
59
- * converted to JSON (e.g. a function) _but_ this is a
60
- * shallow test - it does not test the properties of an
61
- * object or elements in an array.
62
- * @param from The unknown value to be tested
63
- */
64
- function classifyJsonValue(from) {
65
- if (isJsonPrimitive(from)) {
66
- return (0, ts_utils_1.succeed)('primitive');
67
- }
68
- else if (isJsonObject(from)) {
69
- return (0, ts_utils_1.succeed)('object');
70
- }
71
- else if (isJsonArray(from)) {
72
- return (0, ts_utils_1.succeed)('array');
73
- }
74
- return (0, ts_utils_1.fail)(`Invalid JSON: ${from}`);
75
- }
76
- exports.classifyJsonValue = classifyJsonValue;
77
- /**
78
- * Picks a nested field from a supplied JsonObject
79
- * @param src The object from which the field is to be picked
80
- * @param path Dot-separated path of the member to be picked
81
- * @returns Success with the property if the path is valid, Failure
82
- * otherwise.
83
- */
84
- function pickJsonValue(src, path) {
85
- let result = src;
86
- for (const part of path.split('.')) {
87
- if (result && isJsonObject(result)) {
88
- result = result[part];
89
- if (result === undefined) {
90
- return (0, ts_utils_1.fail)(`${path}: child '${part}' does not exist`);
91
- }
92
- }
93
- else {
94
- return (0, ts_utils_1.fail)(`${path}: child '${part}' does not exist`);
95
- }
96
- }
97
- return (0, ts_utils_1.succeed)(result);
98
- }
99
- exports.pickJsonValue = pickJsonValue;
100
- /**
101
- * Picks a nested JsonObject from a supplied JsonObject
102
- * @param src The object from which the field is to be picked
103
- * @param path Dot-separated path of the member to be picked
104
- * @returns Success with the property if the path is valid and the value
105
- * is an object. Returns failure with details if an error occurs.
106
- */
107
- function pickJsonObject(src, path) {
108
- return pickJsonValue(src, path).onSuccess((v) => {
109
- if (!isJsonObject(v)) {
110
- return (0, ts_utils_1.fail)(`${path}: not an object`);
111
- }
112
- return (0, ts_utils_1.succeed)(v);
113
- });
114
- }
115
- exports.pickJsonObject = pickJsonObject;
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"","sources":["../src/common.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;;;AAEH,4CAAsD;AAgBtD;;;;;GAKG;AACH,SAAgB,eAAe,CAAC,IAAa;IACzC,OAAO,CAAC,CAAC,OAAO,IAAI,KAAK,SAAS,CAAC,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC;AACxH,CAAC;AAFD,0CAEC;AAED;;;;;GAKG;AACH,SAAgB,YAAY,CAAC,IAAa;IACtC,OAAO,CAAC,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClE,CAAC;AAFD,oCAEC;AAED;;;;;GAKG;AACH,SAAgB,WAAW,CAAC,IAAa;IACrC,OAAO,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AAC7D,CAAC;AAFD,kCAEC;AAED;;;;;;;GAOG;AACH,SAAgB,iBAAiB,CAAC,IAAa;IAC3C,IAAI,eAAe,CAAC,IAAI,CAAC,EAAE;QACvB,OAAO,IAAA,kBAAO,EAAC,WAAW,CAAC,CAAC;KAC/B;SACI,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE;QACzB,OAAO,IAAA,kBAAO,EAAC,QAAQ,CAAC,CAAC;KAC5B;SACI,IAAI,WAAW,CAAC,IAAI,CAAC,EAAE;QACxB,OAAO,IAAA,kBAAO,EAAC,OAAO,CAAC,CAAC;KAC3B;IACD,OAAO,IAAA,eAAI,EAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;AACzC,CAAC;AAXD,8CAWC;AAED;;;;;;GAMG;AACH,SAAgB,aAAa,CAAC,GAAe,EAAE,IAAY;IACvD,IAAI,MAAM,GAAc,GAAG,CAAC;IAC5B,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;QAChC,IAAI,MAAM,IAAI,YAAY,CAAC,MAAM,CAAC,EAAE;YAChC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;YACtB,IAAI,MAAM,KAAK,SAAS,EAAE;gBACtB,OAAO,IAAA,eAAI,EAAC,GAAG,IAAI,YAAY,IAAI,kBAAkB,CAAC,CAAC;aAC1D;SACJ;aACI;YACD,OAAO,IAAA,eAAI,EAAC,GAAG,IAAI,YAAY,IAAI,kBAAkB,CAAC,CAAC;SAC1D;KACJ;IACD,OAAO,IAAA,kBAAO,EAAC,MAAM,CAAC,CAAC;AAC3B,CAAC;AAdD,sCAcC;AAED;;;;;;GAMG;AACH,SAAgB,cAAc,CAAC,GAAe,EAAE,IAAY;IACxD,OAAO,aAAa,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;QAC5C,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;YAClB,OAAO,IAAA,eAAI,EAAC,GAAG,IAAI,iBAAiB,CAAC,CAAC;SACzC;QACD,OAAO,IAAA,kBAAO,EAAC,CAAC,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;AACP,CAAC;AAPD,wCAOC","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport { Result, fail, succeed } from '@fgv/ts-utils';\n\n/* eslint-disable no-use-before-define */\n\nexport type JsonPrimitive = boolean | number | string | null;\nexport interface JsonObject { [key: string]: JsonValue }\n\nexport type JsonValue = JsonPrimitive | JsonObject | JsonArray;\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface JsonArray extends Array<JsonValue> { }\n\n/**\n * Classes of JSON value\n */\nexport type JsonValueType = 'primitive'|'object'|'array';\n\n/**\n * Test if an unknown is a JsonValue\n * @param from The unknown to be tested\n * @returns true if the supplied parameter is a valid JSON primitive,\n * false otherwise.\n */\nexport function isJsonPrimitive(from: unknown): from is JsonPrimitive {\n    return ((typeof from === 'boolean') || (typeof from === 'number') || (typeof from === 'string') || (from === null));\n}\n\n/**\n * Test if an unknown is potentially a JsonObject\n * @param from The unknown to be tested\n * @returns true if the supplied parameter is a non-array object,\n * false otherwise.\n */\nexport function isJsonObject(from: unknown): from is JsonObject {\n    return ((typeof from === 'object') && (!Array.isArray(from)));\n}\n\n/**\n * Test if an unknown is potentially a JsonArary\n * @param from The unknown to be tested\n * @returns true if the supplied parameter is an array object,\n * false otherwise\n */\nexport function isJsonArray(from: unknown): from is JsonArray {\n    return (typeof from === 'object') && Array.isArray(from);\n}\n\n/**\n * Identifies whether some unknown value is a primitive,\n * object or array. Fails for any value that cannot be\n * converted to JSON (e.g. a function) _but_ this is a\n * shallow test - it does not test the properties of an\n * object or elements in an array.\n * @param from The unknown value to be tested\n */\nexport function classifyJsonValue(from: unknown): Result<JsonValueType> {\n    if (isJsonPrimitive(from)) {\n        return succeed('primitive');\n    }\n    else if (isJsonObject(from)) {\n        return succeed('object');\n    }\n    else if (isJsonArray(from)) {\n        return succeed('array');\n    }\n    return fail(`Invalid JSON: ${from}`);\n}\n\n/**\n * Picks a nested field from a supplied JsonObject\n * @param src The object from which the field is to be picked\n * @param path Dot-separated path of the member to be picked\n * @returns Success with the property if the path is valid, Failure\n * otherwise.\n */\nexport function pickJsonValue(src: JsonObject, path: string): Result<JsonValue> {\n    let result: JsonValue = src;\n    for (const part of path.split('.')) {\n        if (result && isJsonObject(result)) {\n            result = result[part];\n            if (result === undefined) {\n                return fail(`${path}: child '${part}' does not exist`);\n            }\n        }\n        else {\n            return fail(`${path}: child '${part}' does not exist`);\n        }\n    }\n    return succeed(result);\n}\n\n/**\n * Picks a nested JsonObject from a supplied JsonObject\n * @param src The object from which the field is to be picked\n * @param path Dot-separated path of the member to be picked\n * @returns Success with the property if the path is valid and the value\n * is an object. Returns failure with details if an error occurs.\n */\nexport function pickJsonObject(src: JsonObject, path: string): Result<JsonObject> {\n    return pickJsonValue(src, path).onSuccess((v) => {\n        if (!isJsonObject(v)) {\n            return fail(`${path}: not an object`);\n        }\n        return succeed(v);\n    });\n}\n"]}
@@ -1,47 +0,0 @@
1
- import { DetailedResult, Result } from '@fgv/ts-utils';
2
- import { JsonContext, JsonReferenceMap, JsonReferenceMapFailureReason } from './jsonContext';
3
- import { JsonObject, JsonValue } from './common';
4
- /**
5
- * A CompositeJsonMap presents a composed view of one or more other
6
- * JsonReferenceMaps.
7
- */
8
- export declare class CompositeJsonMap implements JsonReferenceMap {
9
- protected _maps: JsonReferenceMap[];
10
- protected constructor(maps: JsonReferenceMap[]);
11
- /**
12
- * Creates a new @see CompositeJsonMap from the supplied maps
13
- * @param maps one or more object maps to be composed
14
- */
15
- static create(maps: JsonReferenceMap[]): Result<CompositeJsonMap>;
16
- /**
17
- * Determine if a key might be valid for this map but does not determine
18
- * if key actually exists. Allows key range to be constrained.
19
- * @param key key to be tested
20
- * @returns true if the key is in the valid range, false otherwise.
21
- */
22
- keyIsInRange(key: string): boolean;
23
- /**
24
- * Determines if an object with the specified key actually exists in the map.
25
- * @param key key to be tested
26
- * @returns true if an object with the specified key exists, false otherwise.
27
- */
28
- has(key: string): boolean;
29
- /**
30
- * Gets a JSON object specified by key.
31
- * @param key key of the object to be retrieved
32
- * @param context optional @see JsonContext used to format the object
33
- * @returns Success with the formatted object if successful. Failure with detail 'unknown'
34
- * if no such object exists, or failure with detail 'error' if the object was found but
35
- * could not be formatted.
36
- */
37
- getJsonObject(key: string, context?: JsonContext): DetailedResult<JsonObject, JsonReferenceMapFailureReason>;
38
- /**
39
- * Gets a JSON value specified by key.
40
- * @param key key of the object to be retrieved
41
- * @param context Optional @see JsonContext used to format the value
42
- * @returns Success with the formatted object if successful. Failure with detail 'unknown'
43
- * if no such object exists, or failure with detail 'error' if the object was found but
44
- * could not be formatted.
45
- */
46
- getJsonValue(key: string, context?: JsonContext): DetailedResult<JsonValue, JsonReferenceMapFailureReason>;
47
- }
@@ -1,97 +0,0 @@
1
- "use strict";
2
- /*
3
- * Copyright (c) 2020 Erik Fortune
4
- *
5
- * Permission is hereby granted, free of charge, to any person obtaining a copy
6
- * of this software and associated documentation files (the "Software"), to deal
7
- * in the Software without restriction, including without limitation the rights
8
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- * copies of the Software, and to permit persons to whom the Software is
10
- * furnished to do so, subject to the following conditions:
11
- *
12
- * The above copyright notice and this permission notice shall be included in all
13
- * copies or substantial portions of the Software.
14
- *
15
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- * SOFTWARE.
22
- */
23
- Object.defineProperty(exports, "__esModule", { value: true });
24
- exports.CompositeJsonMap = void 0;
25
- const ts_utils_1 = require("@fgv/ts-utils");
26
- const common_1 = require("./common");
27
- /**
28
- * A CompositeJsonMap presents a composed view of one or more other
29
- * JsonReferenceMaps.
30
- */
31
- class CompositeJsonMap {
32
- constructor(maps) {
33
- this._maps = maps;
34
- }
35
- /**
36
- * Creates a new @see CompositeJsonMap from the supplied maps
37
- * @param maps one or more object maps to be composed
38
- */
39
- static create(maps) {
40
- return (0, ts_utils_1.captureResult)(() => new CompositeJsonMap(maps));
41
- }
42
- /**
43
- * Determine if a key might be valid for this map but does not determine
44
- * if key actually exists. Allows key range to be constrained.
45
- * @param key key to be tested
46
- * @returns true if the key is in the valid range, false otherwise.
47
- */
48
- keyIsInRange(key) {
49
- return this._maps.find((map) => map.keyIsInRange(key)) !== undefined;
50
- }
51
- /**
52
- * Determines if an object with the specified key actually exists in the map.
53
- * @param key key to be tested
54
- * @returns true if an object with the specified key exists, false otherwise.
55
- */
56
- has(key) {
57
- return this._maps.find((map) => map.has(key)) !== undefined;
58
- }
59
- /**
60
- * Gets a JSON object specified by key.
61
- * @param key key of the object to be retrieved
62
- * @param context optional @see JsonContext used to format the object
63
- * @returns Success with the formatted object if successful. Failure with detail 'unknown'
64
- * if no such object exists, or failure with detail 'error' if the object was found but
65
- * could not be formatted.
66
- */
67
- getJsonObject(key, context) {
68
- return this.getJsonValue(key, context).onSuccess((jv) => {
69
- if (!(0, common_1.isJsonObject)(jv)) {
70
- return (0, ts_utils_1.failWithDetail)(`${key}: not an object`, 'error');
71
- }
72
- return (0, ts_utils_1.succeedWithDetail)(jv);
73
- });
74
- }
75
- /**
76
- * Gets a JSON value specified by key.
77
- * @param key key of the object to be retrieved
78
- * @param context Optional @see JsonContext used to format the value
79
- * @returns Success with the formatted object if successful. Failure with detail 'unknown'
80
- * if no such object exists, or failure with detail 'error' if the object was found but
81
- * could not be formatted.
82
- */
83
- // eslint-disable-next-line no-use-before-define
84
- getJsonValue(key, context) {
85
- for (const map of this._maps) {
86
- if (map.keyIsInRange(key)) {
87
- const result = map.getJsonValue(key, context);
88
- if (result.isSuccess() || (result.detail === 'error')) {
89
- return result;
90
- }
91
- }
92
- }
93
- return (0, ts_utils_1.failWithDetail)(`${key}: value not found`, 'unknown');
94
- }
95
- }
96
- exports.CompositeJsonMap = CompositeJsonMap;
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"compositeJsonMap.js","sourceRoot":"","sources":["../src/compositeJsonMap.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;;;AAEH,4CAAyG;AAEzG,qCAA+D;AAE/D;;;GAGG;AACH,MAAa,gBAAgB;IAGzB,YAAsB,IAAwB;QAC1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACtB,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,MAAM,CAAC,IAAwB;QACzC,OAAO,IAAA,wBAAa,EAAC,GAAG,EAAE,CAAC,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;OAKG;IACI,YAAY,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,SAAS,CAAC;IACzE,CAAC;IAED;;;;OAIG;IACI,GAAG,CAAC,GAAW;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,SAAS,CAAC;IAChE,CAAC;IAED;;;;;;;OAOG;IACI,aAAa,CAAC,GAAW,EAAE,OAAqB;QACnD,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE;YACpD,IAAI,CAAC,IAAA,qBAAY,EAAC,EAAE,CAAC,EAAE;gBACnB,OAAO,IAAA,yBAAc,EAAC,GAAG,GAAG,iBAAiB,EAAE,OAAO,CAAC,CAAC;aAC3D;YACD,OAAO,IAAA,4BAAiB,EAAC,EAAE,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;OAOG;IACH,gDAAgD;IACzC,YAAY,CAAC,GAAW,EAAE,OAAqB;QAClD,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,KAAK,EAAE;YAC1B,IAAI,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE;gBACvB,MAAM,MAAM,GAAG,GAAG,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;gBAC9C,IAAI,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,OAAO,CAAC,EAAE;oBACnD,OAAO,MAAM,CAAC;iBACjB;aACJ;SACJ;QACD,OAAO,IAAA,yBAAc,EAAC,GAAG,GAAG,mBAAmB,EAAE,SAAS,CAAC,CAAC;IAChE,CAAC;CACJ;AAvED,4CAuEC","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport { DetailedResult, Result, captureResult, failWithDetail, succeedWithDetail } from '@fgv/ts-utils';\nimport { JsonContext, JsonReferenceMap, JsonReferenceMapFailureReason } from './jsonContext';\nimport { JsonObject, JsonValue, isJsonObject } from './common';\n\n/**\n * A CompositeJsonMap presents a composed view of one or more other\n * JsonReferenceMaps.\n */\nexport class CompositeJsonMap implements JsonReferenceMap {\n    protected _maps: JsonReferenceMap[];\n\n    protected constructor(maps: JsonReferenceMap[]) {\n        this._maps = maps;\n    }\n\n    /**\n     * Creates a new @see CompositeJsonMap from the supplied maps\n     * @param maps one or more object maps to be composed\n     */\n    public static create(maps: JsonReferenceMap[]): Result<CompositeJsonMap> {\n        return captureResult(() => new CompositeJsonMap(maps));\n    }\n\n    /**\n     * Determine if a key might be valid for this map but does not determine\n     * if key actually exists. Allows key range to be constrained.\n     * @param key key to be tested\n     * @returns true if the key is in the valid range, false otherwise.\n     */\n    public keyIsInRange(key: string): boolean {\n        return this._maps.find((map) => map.keyIsInRange(key)) !== undefined;\n    }\n\n    /**\n     * Determines if an object with the specified key actually exists in the map.\n     * @param key key to be tested\n     * @returns true if an object with the specified key exists, false otherwise.\n     */\n    public has(key: string): boolean {\n        return this._maps.find((map) => map.has(key)) !== undefined;\n    }\n\n    /**\n     * Gets a JSON object specified by key.\n     * @param key key of the object to be retrieved\n     * @param context optional @see JsonContext used to format the object\n     * @returns Success with the formatted object if successful. Failure with detail 'unknown'\n     * if no such object exists, or failure with detail 'error' if the object was found but\n     * could not be formatted.\n     */\n    public getJsonObject(key: string, context?: JsonContext): DetailedResult<JsonObject, JsonReferenceMapFailureReason> {\n        return this.getJsonValue(key, context).onSuccess((jv) => {\n            if (!isJsonObject(jv)) {\n                return failWithDetail(`${key}: not an object`, 'error');\n            }\n            return succeedWithDetail(jv);\n        });\n    }\n\n    /**\n     * Gets a JSON value specified by key.\n     * @param key key of the object to be retrieved\n     * @param context Optional @see JsonContext used to format the value\n     * @returns Success with the formatted object if successful. Failure with detail 'unknown'\n     * if no such object exists, or failure with detail 'error' if the object was found but\n     * could not be formatted.\n     */\n    // eslint-disable-next-line no-use-before-define\n    public getJsonValue(key: string, context?: JsonContext): DetailedResult<JsonValue, JsonReferenceMapFailureReason> {\n        for (const map of this._maps) {\n            if (map.keyIsInRange(key)) {\n                const result = map.getJsonValue(key, context);\n                if (result.isSuccess() || (result.detail === 'error')) {\n                    return result;\n                }\n            }\n        }\n        return failWithDetail(`${key}: value not found`, 'unknown');\n    }\n}\n"]}
@@ -1,21 +0,0 @@
1
- import { JsonContext, JsonReferenceMap, TemplateVars, VariableValue } from './jsonContext';
2
- import { Result } from '@fgv/ts-utils';
3
- export declare class JsonContextHelper {
4
- protected _context?: JsonContext;
5
- constructor(context?: JsonContext);
6
- static create(context?: JsonContext): Result<JsonContextHelper>;
7
- static extendContextVars(baseContext: JsonContext | undefined, vars?: VariableValue[]): Result<TemplateVars | undefined>;
8
- static extendContextRefs(baseContext: JsonContext | undefined, refs?: JsonReferenceMap[]): Result<JsonReferenceMap | undefined>;
9
- static extendContext(baseContext?: JsonContext | undefined, add?: {
10
- vars?: VariableValue[];
11
- refs?: JsonReferenceMap[];
12
- }): Result<JsonContext | undefined>;
13
- static mergeContext(baseContext: JsonContext | undefined, add: JsonContext | undefined): Result<JsonContext | undefined>;
14
- extendVars(vars?: VariableValue[]): Result<TemplateVars | undefined>;
15
- extendRefs(refs?: JsonReferenceMap[]): Result<JsonReferenceMap | undefined>;
16
- extendContext(add?: {
17
- vars?: VariableValue[];
18
- refs?: JsonReferenceMap[];
19
- }): Result<JsonContext | undefined>;
20
- mergeContext(merge?: JsonContext): Result<JsonContext | undefined>;
21
- }
package/contextHelpers.js DELETED
@@ -1,101 +0,0 @@
1
- "use strict";
2
- /*
3
- * Copyright (c) 2020 Erik Fortune
4
- *
5
- * Permission is hereby granted, free of charge, to any person obtaining a copy
6
- * of this software and associated documentation files (the "Software"), to deal
7
- * in the Software without restriction, including without limitation the rights
8
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- * copies of the Software, and to permit persons to whom the Software is
10
- * furnished to do so, subject to the following conditions:
11
- *
12
- * The above copyright notice and this permission notice shall be included in all
13
- * copies or substantial portions of the Software.
14
- *
15
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- * SOFTWARE.
22
- */
23
- Object.defineProperty(exports, "__esModule", { value: true });
24
- exports.JsonContextHelper = void 0;
25
- const jsonContext_1 = require("./jsonContext");
26
- const ts_utils_1 = require("@fgv/ts-utils");
27
- const compositeJsonMap_1 = require("./compositeJsonMap");
28
- class JsonContextHelper {
29
- constructor(context) {
30
- this._context = context;
31
- }
32
- static create(context) {
33
- return (0, ts_utils_1.captureResult)(() => new JsonContextHelper(context));
34
- }
35
- static extendContextVars(baseContext, vars) {
36
- var _a, _b;
37
- if (vars && (vars.length > 0)) {
38
- const extend = (_a = baseContext === null || baseContext === void 0 ? void 0 : baseContext.extendVars) !== null && _a !== void 0 ? _a : jsonContext_1.defaultExtendVars;
39
- return extend((_b = baseContext === null || baseContext === void 0 ? void 0 : baseContext.vars) !== null && _b !== void 0 ? _b : {}, vars);
40
- }
41
- return (0, ts_utils_1.succeed)(baseContext === null || baseContext === void 0 ? void 0 : baseContext.vars);
42
- }
43
- static extendContextRefs(baseContext, refs) {
44
- if (refs && (refs.length > 0)) {
45
- const full = (baseContext === null || baseContext === void 0 ? void 0 : baseContext.refs) ? [...refs, baseContext.refs] : refs;
46
- if (full.length > 1) {
47
- return compositeJsonMap_1.CompositeJsonMap.create(full);
48
- }
49
- return (0, ts_utils_1.succeed)(full[0]);
50
- }
51
- return (0, ts_utils_1.succeed)(baseContext === null || baseContext === void 0 ? void 0 : baseContext.refs);
52
- }
53
- static extendContext(baseContext, add) {
54
- return JsonContextHelper.extendContextVars(baseContext, (add === null || add === void 0 ? void 0 : add.vars) || []).onSuccess((vars) => {
55
- return JsonContextHelper.extendContextRefs(baseContext, (add === null || add === void 0 ? void 0 : add.refs) || []).onSuccess((refs) => {
56
- if (!vars && !refs && !(baseContext === null || baseContext === void 0 ? void 0 : baseContext.extendVars)) {
57
- return (0, ts_utils_1.succeed)(undefined);
58
- }
59
- const rtrn = { vars, refs };
60
- if (baseContext === null || baseContext === void 0 ? void 0 : baseContext.extendVars) {
61
- rtrn.extendVars = baseContext.extendVars;
62
- }
63
- return (0, ts_utils_1.succeed)(rtrn);
64
- });
65
- });
66
- }
67
- static mergeContext(baseContext, add) {
68
- var _a, _b;
69
- if (baseContext) {
70
- if (add) {
71
- const rtrn = {
72
- vars: (_a = add.vars) !== null && _a !== void 0 ? _a : baseContext.vars,
73
- refs: (_b = add.refs) !== null && _b !== void 0 ? _b : baseContext.refs,
74
- };
75
- if (add.hasOwnProperty('extendVars')) {
76
- rtrn.extendVars = add.extendVars;
77
- }
78
- else if (baseContext.hasOwnProperty('extendVars')) {
79
- rtrn.extendVars = baseContext.extendVars;
80
- }
81
- return (0, ts_utils_1.succeed)(rtrn);
82
- }
83
- return (0, ts_utils_1.succeed)(baseContext);
84
- }
85
- return (0, ts_utils_1.succeed)(add);
86
- }
87
- extendVars(vars) {
88
- return JsonContextHelper.extendContextVars(this._context, vars);
89
- }
90
- extendRefs(refs) {
91
- return JsonContextHelper.extendContextRefs(this._context, refs);
92
- }
93
- extendContext(add) {
94
- return JsonContextHelper.extendContext(this._context, add);
95
- }
96
- mergeContext(merge) {
97
- return JsonContextHelper.mergeContext(this._context, merge);
98
- }
99
- }
100
- exports.JsonContextHelper = JsonContextHelper;
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextHelpers.js","sourceRoot":"","sources":["../src/contextHelpers.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;;;AAEH,+CAA8G;AAC9G,4CAA+D;AAC/D,yDAAsD;AAEtD,MAAa,iBAAiB;IAG1B,YAAmB,OAAqB;QACpC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;IAC5B,CAAC;IAEM,MAAM,CAAC,MAAM,CAAC,OAAqB;QACtC,OAAO,IAAA,wBAAa,EAAC,GAAG,EAAE,CAAC,IAAI,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC;IAC/D,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,WAAkC,EAAE,IAAsB;;QACtF,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE;YAC3B,MAAM,MAAM,GAAG,MAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,mCAAI,+BAAiB,CAAC;YAC5D,OAAO,MAAM,CAAC,MAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,IAAI,mCAAI,EAAE,EAAE,IAAI,CAAC,CAAC;SAChD;QACD,OAAO,IAAA,kBAAO,EAAC,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,IAAI,CAAC,CAAC;IACtC,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAAC,WAAkC,EAAE,IAAyB;QACzF,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE;YAC3B,MAAM,IAAI,GAAG,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,IAAI,EAAC,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACpE,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjB,OAAO,mCAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aACxC;YACD,OAAO,IAAA,kBAAO,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;SAC3B;QACD,OAAO,IAAA,kBAAO,EAAC,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,IAAI,CAAC,CAAC;IACtC,CAAC;IAEM,MAAM,CAAC,aAAa,CAAC,WAAmC,EAAE,GAA2D;QACxH,OAAO,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,IAAI,KAAI,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACxF,OAAO,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,IAAI,KAAI,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;gBACxF,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,CAAA,EAAE;oBAC5C,OAAO,IAAA,kBAAO,EAAC,SAAS,CAAC,CAAC;iBAC7B;gBACD,MAAM,IAAI,GAAgB,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;gBACzC,IAAI,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,EAAE;oBACzB,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,UAAU,CAAC;iBAC5C;gBACD,OAAO,IAAA,kBAAO,EAAC,IAAI,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,MAAM,CAAC,YAAY,CAAC,WAAkC,EAAE,GAA0B;;QACrF,IAAI,WAAW,EAAE;YACb,IAAI,GAAG,EAAE;gBACL,MAAM,IAAI,GAAgB;oBACtB,IAAI,EAAE,MAAA,GAAG,CAAC,IAAI,mCAAI,WAAW,CAAC,IAAI;oBAClC,IAAI,EAAE,MAAA,GAAG,CAAC,IAAI,mCAAI,WAAW,CAAC,IAAI;iBACrC,CAAC;gBACF,IAAI,GAAG,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE;oBAClC,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC;iBACpC;qBACI,IAAI,WAAW,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE;oBAC/C,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,UAAU,CAAC;iBAC5C;gBACD,OAAO,IAAA,kBAAO,EAAC,IAAI,CAAC,CAAC;aACxB;YACD,OAAO,IAAA,kBAAO,EAAC,WAAW,CAAC,CAAC;SAC/B;QACD,OAAO,IAAA,kBAAO,EAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAEM,UAAU,CAAC,IAAsB;QACpC,OAAO,iBAAiB,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACpE,CAAC;IAEM,UAAU,CAAC,IAAyB;QACvC,OAAO,iBAAiB,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACpE,CAAC;IAEM,aAAa,CAAC,GAA2D;QAC5E,OAAO,iBAAiB,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAC/D,CAAC;IAEM,YAAY,CAAC,KAAmB;QACnC,OAAO,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAChE,CAAC;CACJ;AAhFD,8CAgFC","sourcesContent":["/*\n * Copyright (c) 2020 Erik Fortune\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n\nimport { JsonContext, JsonReferenceMap, TemplateVars, VariableValue, defaultExtendVars } from './jsonContext';\nimport { Result, captureResult, succeed } from '@fgv/ts-utils';\nimport { CompositeJsonMap } from './compositeJsonMap';\n\nexport class JsonContextHelper {\n    protected _context?: JsonContext;\n\n    public constructor(context?: JsonContext) {\n        this._context = context;\n    }\n\n    public static create(context?: JsonContext): Result<JsonContextHelper> {\n        return captureResult(() => new JsonContextHelper(context));\n    }\n\n    public static extendContextVars(baseContext: JsonContext|undefined, vars?: VariableValue[]): Result<TemplateVars|undefined> {\n        if (vars && (vars.length > 0)) {\n            const extend = baseContext?.extendVars ?? defaultExtendVars;\n            return extend(baseContext?.vars ?? {}, vars);\n        }\n        return succeed(baseContext?.vars);\n    }\n\n    public static extendContextRefs(baseContext: JsonContext|undefined, refs?: JsonReferenceMap[]): Result<JsonReferenceMap|undefined> {\n        if (refs && (refs.length > 0)) {\n            const full = baseContext?.refs ? [...refs, baseContext.refs] : refs;\n            if (full.length > 1) {\n                return CompositeJsonMap.create(full);\n            }\n            return succeed(full[0]);\n        }\n        return succeed(baseContext?.refs);\n    }\n\n    public static extendContext(baseContext?: JsonContext|undefined, add?: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        return JsonContextHelper.extendContextVars(baseContext, add?.vars || []).onSuccess((vars) => {\n            return JsonContextHelper.extendContextRefs(baseContext, add?.refs || []).onSuccess((refs) => {\n                if (!vars && !refs && !baseContext?.extendVars) {\n                    return succeed(undefined);\n                }\n                const rtrn: JsonContext = { vars, refs };\n                if (baseContext?.extendVars) {\n                    rtrn.extendVars = baseContext.extendVars;\n                }\n                return succeed(rtrn);\n            });\n        });\n    }\n\n    public static mergeContext(baseContext: JsonContext|undefined, add: JsonContext|undefined): Result<JsonContext|undefined> {\n        if (baseContext) {\n            if (add) {\n                const rtrn: JsonContext = {\n                    vars: add.vars ?? baseContext.vars,\n                    refs: add.refs ?? baseContext.refs,\n                };\n                if (add.hasOwnProperty('extendVars')) {\n                    rtrn.extendVars = add.extendVars;\n                }\n                else if (baseContext.hasOwnProperty('extendVars')) {\n                    rtrn.extendVars = baseContext.extendVars;\n                }\n                return succeed(rtrn);\n            }\n            return succeed(baseContext);\n        }\n        return succeed(add);\n    }\n\n    public extendVars(vars?: VariableValue[]): Result<TemplateVars|undefined> {\n        return JsonContextHelper.extendContextVars(this._context, vars);\n    }\n\n    public extendRefs(refs?: JsonReferenceMap[]): Result<JsonReferenceMap|undefined> {\n        return JsonContextHelper.extendContextRefs(this._context, refs);\n    }\n\n    public extendContext(add?: { vars?: VariableValue[], refs?: JsonReferenceMap[] }): Result<JsonContext|undefined> {\n        return JsonContextHelper.extendContext(this._context, add);\n    }\n\n    public mergeContext(merge?: JsonContext): Result<JsonContext|undefined> {\n        return JsonContextHelper.mergeContext(this._context, merge);\n    }\n}\n"]}
package/converters.d.ts DELETED
@@ -1,37 +0,0 @@
1
- import { ConditionalJsonConverterOptions, JsonConverter, RichJsonConverterOptions, TemplatedJsonConverterOptions } from './jsonConverter';
2
- /**
3
- * A simple validating JSON converter. Converts unknown to JSON or fails
4
- * if the unknown contains any invalid JSON values.
5
- */
6
- export declare const json: JsonConverter;
7
- /**
8
- * A simple validating JSON converter. Converts unknown to a JSON object
9
- * or fails if the unknown contains invalid JSON or is not an object.
10
- */
11
- export declare const jsonObject: import("@fgv/ts-utils").Converter<import("./common").JsonObject, import("./jsonContext").JsonContext>;
12
- /**
13
- * A simple validating JSON converter. Converts unknown to a JSON array
14
- * or fails if the unknown contains invalid JSON or is not an array.
15
- */
16
- export declare const jsonArray: import("@fgv/ts-utils").Converter<import("./common").JsonArray, import("./jsonContext").JsonContext>;
17
- /**
18
- * Converts the supplied unknown to JSON, rendering any property names
19
- * or string values using mustache with the supplied context. See the
20
- * mustache documentation for details of mustache syntax and view.
21
- * @param options A @see TemplatedJsonConverterOptions with options and context for the conversion
22
- */
23
- export declare function templatedJson(options?: Partial<TemplatedJsonConverterOptions>): JsonConverter;
24
- /**
25
- * Converts the supplied unknown to strongly-typed JSON, by first rendering any property
26
- * names or string values using mustache with the supplied context, then applying
27
- * multi-value property expansion and conditional flattening based on property names.
28
- * @param options A @see ConditionalJsonConverterOptions with options and context for the conversion
29
- */
30
- export declare function conditionalJson(options?: Partial<ConditionalJsonConverterOptions>): JsonConverter;
31
- /**
32
- * Converts the supplied unknown to strongly-typed JSON, by first rendering any property
33
- * names or string values using mustache with the supplied context, then applying
34
- * multi-value property expansion and conditional flattening based on property names.
35
- * @param options A @see RichJsonConverterOptions with options and context for the conversion
36
- */
37
- export declare function richJson(options?: Partial<RichJsonConverterOptions>): JsonConverter;
package/converters.js DELETED
@@ -1,92 +0,0 @@
1
- "use strict";
2
- /*
3
- * Copyright (c) 2020 Erik Fortune
4
- *
5
- * Permission is hereby granted, free of charge, to any person obtaining a copy
6
- * of this software and associated documentation files (the "Software"), to deal
7
- * in the Software without restriction, including without limitation the rights
8
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- * copies of the Software, and to permit persons to whom the Software is
10
- * furnished to do so, subject to the following conditions:
11
- *
12
- * The above copyright notice and this permission notice shall be included in all
13
- * copies or substantial portions of the Software.
14
- *
15
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- * SOFTWARE.
22
- */
23
- Object.defineProperty(exports, "__esModule", { value: true });
24
- exports.richJson = exports.conditionalJson = exports.templatedJson = exports.jsonArray = exports.jsonObject = exports.json = void 0;
25
- const jsonConverter_1 = require("./jsonConverter");
26
- /**
27
- * A simple validating JSON converter. Converts unknown to JSON or fails
28
- * if the unknown contains any invalid JSON values.
29
- */
30
- exports.json = new jsonConverter_1.JsonConverter();
31
- /**
32
- * A simple validating JSON converter. Converts unknown to a JSON object
33
- * or fails if the unknown contains invalid JSON or is not an object.
34
- */
35
- exports.jsonObject = exports.json.object();
36
- /**
37
- * A simple validating JSON converter. Converts unknown to a JSON array
38
- * or fails if the unknown contains invalid JSON or is not an array.
39
- */
40
- exports.jsonArray = exports.json.array();
41
- let templatedJsonDefault;
42
- let conditionalJsonDefault;
43
- let richJsonDefault;
44
- /**
45
- * Converts the supplied unknown to JSON, rendering any property names
46
- * or string values using mustache with the supplied context. See the
47
- * mustache documentation for details of mustache syntax and view.
48
- * @param options A @see TemplatedJsonConverterOptions with options and context for the conversion
49
- */
50
- function templatedJson(options) {
51
- if (!options) {
52
- if (!templatedJsonDefault) {
53
- templatedJsonDefault = new jsonConverter_1.TemplatedJsonConverter();
54
- }
55
- return templatedJsonDefault;
56
- }
57
- return new jsonConverter_1.TemplatedJsonConverter(options);
58
- }
59
- exports.templatedJson = templatedJson;
60
- /**
61
- * Converts the supplied unknown to strongly-typed JSON, by first rendering any property
62
- * names or string values using mustache with the supplied context, then applying
63
- * multi-value property expansion and conditional flattening based on property names.
64
- * @param options A @see ConditionalJsonConverterOptions with options and context for the conversion
65
- */
66
- function conditionalJson(options) {
67
- if (!options) {
68
- if (!conditionalJsonDefault) {
69
- conditionalJsonDefault = new jsonConverter_1.ConditionalJsonConverter();
70
- }
71
- return conditionalJsonDefault;
72
- }
73
- return new jsonConverter_1.ConditionalJsonConverter(options);
74
- }
75
- exports.conditionalJson = conditionalJson;
76
- /**
77
- * Converts the supplied unknown to strongly-typed JSON, by first rendering any property
78
- * names or string values using mustache with the supplied context, then applying
79
- * multi-value property expansion and conditional flattening based on property names.
80
- * @param options A @see RichJsonConverterOptions with options and context for the conversion
81
- */
82
- function richJson(options) {
83
- if (!options) {
84
- if (!richJsonDefault) {
85
- richJsonDefault = new jsonConverter_1.RichJsonConverter();
86
- }
87
- return richJsonDefault;
88
- }
89
- return new jsonConverter_1.RichJsonConverter(options);
90
- }
91
- exports.richJson = richJson;
92
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVydGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9jb252ZXJ0ZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FvQkc7OztBQUVILG1EQVF5QjtBQUV6Qjs7O0dBR0c7QUFDVSxRQUFBLElBQUksR0FBRyxJQUFJLDZCQUFhLEVBQUUsQ0FBQztBQUV4Qzs7O0dBR0c7QUFDVSxRQUFBLFVBQVUsR0FBRyxZQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7QUFFeEM7OztHQUdHO0FBQ1UsUUFBQSxTQUFTLEdBQUcsWUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0FBRXRDLElBQUksb0JBQTZDLENBQUM7QUFDbEQsSUFBSSxzQkFBK0MsQ0FBQztBQUNwRCxJQUFJLGVBQXdDLENBQUM7QUFFN0M7Ozs7O0dBS0c7QUFDSCxTQUFnQixhQUFhLENBQUMsT0FBZ0Q7SUFDMUUsSUFBSSxDQUFDLE9BQU8sRUFBRTtRQUNWLElBQUksQ0FBQyxvQkFBb0IsRUFBRTtZQUN2QixvQkFBb0IsR0FBRyxJQUFJLHNDQUFzQixFQUFFLENBQUM7U0FDdkQ7UUFDRCxPQUFPLG9CQUFvQixDQUFDO0tBQy9CO0lBQ0QsT0FBTyxJQUFJLHNDQUFzQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQy9DLENBQUM7QUFSRCxzQ0FRQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBZ0IsZUFBZSxDQUFDLE9BQWtEO0lBQzlFLElBQUksQ0FBQyxPQUFPLEVBQUU7UUFDVixJQUFJLENBQUMsc0JBQXNCLEVBQUU7WUFDekIsc0JBQXNCLEdBQUcsSUFBSSx3Q0FBd0IsRUFBRSxDQUFDO1NBQzNEO1FBQ0QsT0FBTyxzQkFBc0IsQ0FBQztLQUNqQztJQUNELE9BQU8sSUFBSSx3Q0FBd0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUNqRCxDQUFDO0FBUkQsMENBUUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLFFBQVEsQ0FBQyxPQUEyQztJQUNoRSxJQUFJLENBQUMsT0FBTyxFQUFFO1FBQ1YsSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUNsQixlQUFlLEdBQUcsSUFBSSxpQ0FBaUIsRUFBRSxDQUFDO1NBQzdDO1FBQ0QsT0FBTyxlQUFlLENBQUM7S0FDMUI7SUFDRCxPQUFPLElBQUksaUNBQWlCLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDMUMsQ0FBQztBQVJELDRCQVFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyMCBFcmlrIEZvcnR1bmVcbiAqXG4gKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4gKiBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4gKiBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4gKiB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4gKiBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbiAqIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4gKlxuICogVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWQgaW4gYWxsXG4gKiBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuICpcbiAqIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1JcbiAqIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4gKiBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4gKiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuICogT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEVcbiAqIFNPRlRXQVJFLlxuICovXG5cbmltcG9ydCB7XG4gICAgQ29uZGl0aW9uYWxKc29uQ29udmVydGVyLFxuICAgIENvbmRpdGlvbmFsSnNvbkNvbnZlcnRlck9wdGlvbnMsXG4gICAgSnNvbkNvbnZlcnRlcixcbiAgICBSaWNoSnNvbkNvbnZlcnRlcixcbiAgICBSaWNoSnNvbkNvbnZlcnRlck9wdGlvbnMsXG4gICAgVGVtcGxhdGVkSnNvbkNvbnZlcnRlcixcbiAgICBUZW1wbGF0ZWRKc29uQ29udmVydGVyT3B0aW9ucyxcbn0gZnJvbSAnLi9qc29uQ29udmVydGVyJztcblxuLyoqXG4gKiBBIHNpbXBsZSB2YWxpZGF0aW5nIEpTT04gY29udmVydGVyLiBDb252ZXJ0cyB1bmtub3duIHRvIEpTT04gb3IgZmFpbHNcbiAqIGlmIHRoZSB1bmtub3duIGNvbnRhaW5zIGFueSBpbnZhbGlkIEpTT04gdmFsdWVzLlxuICovXG5leHBvcnQgY29uc3QganNvbiA9IG5ldyBKc29uQ29udmVydGVyKCk7XG5cbi8qKlxuICogQSBzaW1wbGUgdmFsaWRhdGluZyBKU09OIGNvbnZlcnRlci4gQ29udmVydHMgdW5rbm93biB0byBhIEpTT04gb2JqZWN0XG4gKiBvciBmYWlscyBpZiB0aGUgdW5rbm93biBjb250YWlucyBpbnZhbGlkIEpTT04gb3IgaXMgbm90IGFuIG9iamVjdC5cbiAqL1xuZXhwb3J0IGNvbnN0IGpzb25PYmplY3QgPSBqc29uLm9iamVjdCgpO1xuXG4vKipcbiAqIEEgc2ltcGxlIHZhbGlkYXRpbmcgSlNPTiBjb252ZXJ0ZXIuIENvbnZlcnRzIHVua25vd24gdG8gYSBKU09OIGFycmF5XG4gKiBvciBmYWlscyBpZiB0aGUgdW5rbm93biBjb250YWlucyBpbnZhbGlkIEpTT04gb3IgaXMgbm90IGFuIGFycmF5LlxuICovXG5leHBvcnQgY29uc3QganNvbkFycmF5ID0ganNvbi5hcnJheSgpO1xuXG5sZXQgdGVtcGxhdGVkSnNvbkRlZmF1bHQ6IEpzb25Db252ZXJ0ZXJ8dW5kZWZpbmVkO1xubGV0IGNvbmRpdGlvbmFsSnNvbkRlZmF1bHQ6IEpzb25Db252ZXJ0ZXJ8dW5kZWZpbmVkO1xubGV0IHJpY2hKc29uRGVmYXVsdDogSnNvbkNvbnZlcnRlcnx1bmRlZmluZWQ7XG5cbi8qKlxuICogQ29udmVydHMgdGhlIHN1cHBsaWVkIHVua25vd24gdG8gSlNPTiwgcmVuZGVyaW5nIGFueSBwcm9wZXJ0eSBuYW1lc1xuICogb3Igc3RyaW5nIHZhbHVlcyB1c2luZyBtdXN0YWNoZSB3aXRoIHRoZSBzdXBwbGllZCBjb250ZXh0LiAgU2VlIHRoZVxuICogbXVzdGFjaGUgZG9jdW1lbnRhdGlvbiBmb3IgZGV0YWlscyBvZiBtdXN0YWNoZSBzeW50YXggYW5kIHZpZXcuXG4gKiBAcGFyYW0gb3B0aW9ucyBBIEBzZWUgVGVtcGxhdGVkSnNvbkNvbnZlcnRlck9wdGlvbnMgd2l0aCBvcHRpb25zIGFuZCBjb250ZXh0IGZvciB0aGUgY29udmVyc2lvblxuICovXG5leHBvcnQgZnVuY3Rpb24gdGVtcGxhdGVkSnNvbihvcHRpb25zPzogUGFydGlhbDxUZW1wbGF0ZWRKc29uQ29udmVydGVyT3B0aW9ucz4pOiBKc29uQ29udmVydGVyIHtcbiAgICBpZiAoIW9wdGlvbnMpIHtcbiAgICAgICAgaWYgKCF0ZW1wbGF0ZWRKc29uRGVmYXVsdCkge1xuICAgICAgICAgICAgdGVtcGxhdGVkSnNvbkRlZmF1bHQgPSBuZXcgVGVtcGxhdGVkSnNvbkNvbnZlcnRlcigpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0ZW1wbGF0ZWRKc29uRGVmYXVsdDtcbiAgICB9XG4gICAgcmV0dXJuIG5ldyBUZW1wbGF0ZWRKc29uQ29udmVydGVyKG9wdGlvbnMpO1xufVxuXG4vKipcbiAqIENvbnZlcnRzIHRoZSBzdXBwbGllZCB1bmtub3duIHRvIHN0cm9uZ2x5LXR5cGVkIEpTT04sIGJ5IGZpcnN0IHJlbmRlcmluZyBhbnkgcHJvcGVydHlcbiAqIG5hbWVzIG9yIHN0cmluZyB2YWx1ZXMgdXNpbmcgbXVzdGFjaGUgd2l0aCB0aGUgc3VwcGxpZWQgY29udGV4dCwgdGhlbiBhcHBseWluZ1xuICogbXVsdGktdmFsdWUgcHJvcGVydHkgZXhwYW5zaW9uIGFuZCBjb25kaXRpb25hbCBmbGF0dGVuaW5nIGJhc2VkIG9uIHByb3BlcnR5IG5hbWVzLlxuICogQHBhcmFtIG9wdGlvbnMgQSBAc2VlIENvbmRpdGlvbmFsSnNvbkNvbnZlcnRlck9wdGlvbnMgd2l0aCBvcHRpb25zIGFuZCBjb250ZXh0IGZvciB0aGUgY29udmVyc2lvblxuICovXG5leHBvcnQgZnVuY3Rpb24gY29uZGl0aW9uYWxKc29uKG9wdGlvbnM/OiBQYXJ0aWFsPENvbmRpdGlvbmFsSnNvbkNvbnZlcnRlck9wdGlvbnM+KTogSnNvbkNvbnZlcnRlciB7XG4gICAgaWYgKCFvcHRpb25zKSB7XG4gICAgICAgIGlmICghY29uZGl0aW9uYWxKc29uRGVmYXVsdCkge1xuICAgICAgICAgICAgY29uZGl0aW9uYWxKc29uRGVmYXVsdCA9IG5ldyBDb25kaXRpb25hbEpzb25Db252ZXJ0ZXIoKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY29uZGl0aW9uYWxKc29uRGVmYXVsdDtcbiAgICB9XG4gICAgcmV0dXJuIG5ldyBDb25kaXRpb25hbEpzb25Db252ZXJ0ZXIob3B0aW9ucyk7XG59XG5cbi8qKlxuICogQ29udmVydHMgdGhlIHN1cHBsaWVkIHVua25vd24gdG8gc3Ryb25nbHktdHlwZWQgSlNPTiwgYnkgZmlyc3QgcmVuZGVyaW5nIGFueSBwcm9wZXJ0eVxuICogbmFtZXMgb3Igc3RyaW5nIHZhbHVlcyB1c2luZyBtdXN0YWNoZSB3aXRoIHRoZSBzdXBwbGllZCBjb250ZXh0LCB0aGVuIGFwcGx5aW5nXG4gKiBtdWx0aS12YWx1ZSBwcm9wZXJ0eSBleHBhbnNpb24gYW5kIGNvbmRpdGlvbmFsIGZsYXR0ZW5pbmcgYmFzZWQgb24gcHJvcGVydHkgbmFtZXMuXG4gKiBAcGFyYW0gb3B0aW9ucyBBIEBzZWUgUmljaEpzb25Db252ZXJ0ZXJPcHRpb25zIHdpdGggb3B0aW9ucyBhbmQgY29udGV4dCBmb3IgdGhlIGNvbnZlcnNpb25cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJpY2hKc29uKG9wdGlvbnM/OiBQYXJ0aWFsPFJpY2hKc29uQ29udmVydGVyT3B0aW9ucz4pOiBKc29uQ29udmVydGVyIHtcbiAgICBpZiAoIW9wdGlvbnMpIHtcbiAgICAgICAgaWYgKCFyaWNoSnNvbkRlZmF1bHQpIHtcbiAgICAgICAgICAgIHJpY2hKc29uRGVmYXVsdCA9IG5ldyBSaWNoSnNvbkNvbnZlcnRlcigpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByaWNoSnNvbkRlZmF1bHQ7XG4gICAgfVxuICAgIHJldHVybiBuZXcgUmljaEpzb25Db252ZXJ0ZXIob3B0aW9ucyk7XG59XG4iXX0=