cdk8s 2.2.10 → 2.2.14
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.
- package/.jsii +4 -4
- package/changelog.md +1 -1
- package/lib/api-object.d.ts +13 -48
- package/lib/api-object.js +12 -20
- package/lib/app.d.ts +12 -56
- package/lib/app.js +10 -19
- package/lib/chart.d.ts +3 -26
- package/lib/chart.js +3 -18
- package/lib/dependency.d.ts +3 -25
- package/lib/dependency.js +6 -28
- package/lib/duration.d.ts +16 -33
- package/lib/duration.js +16 -31
- package/lib/helm.d.ts +3 -18
- package/lib/helm.js +2 -7
- package/lib/include.d.ts +3 -15
- package/lib/include.js +4 -10
- package/lib/json-patch.d.ts +16 -45
- package/lib/json-patch.js +18 -47
- package/lib/lazy.d.ts +0 -15
- package/lib/lazy.js +2 -11
- package/lib/metadata.d.ts +21 -63
- package/lib/metadata.js +7 -21
- package/lib/names.d.ts +16 -26
- package/lib/names.js +18 -18
- package/lib/size.d.ts +4 -51
- package/lib/size.js +5 -31
- package/lib/testing.d.ts +2 -8
- package/lib/testing.js +4 -10
- package/lib/yaml.d.ts +9 -15
- package/lib/yaml.js +11 -17
- package/node_modules/follow-redirects/index.js +7 -3
- package/node_modules/follow-redirects/package.json +1 -1
- package/package.json +6 -6
- package/releasetag.txt +1 -1
- package/version.txt +1 -1
package/lib/chart.d.ts
CHANGED
|
@@ -1,60 +1,42 @@
|
|
|
1
1
|
import { Construct, IConstruct } from 'constructs';
|
|
2
2
|
import { ApiObject } from './api-object';
|
|
3
|
-
/**
|
|
4
|
-
* @stability stable
|
|
5
|
-
*/
|
|
6
3
|
export interface ChartProps {
|
|
7
4
|
/**
|
|
8
|
-
* The default namespace for all objects defined in this chart (directly or
|
|
9
|
-
*
|
|
10
|
-
* This namespace will only apply to objects that don't have a
|
|
5
|
+
* The default namespace for all objects defined in this chart (directly or
|
|
6
|
+
* indirectly). This namespace will only apply to objects that don't have a
|
|
11
7
|
* `namespace` explicitly defined for them.
|
|
12
8
|
*
|
|
13
9
|
* @default - no namespace is synthesized (usually this implies "default")
|
|
14
|
-
* @stability stable
|
|
15
10
|
*/
|
|
16
11
|
readonly namespace?: string;
|
|
17
12
|
/**
|
|
18
13
|
* Labels to apply to all resources in this chart.
|
|
19
14
|
*
|
|
20
15
|
* @default - no common labels
|
|
21
|
-
* @stability stable
|
|
22
16
|
*/
|
|
23
17
|
readonly labels?: {
|
|
24
18
|
[name: string]: string;
|
|
25
19
|
};
|
|
26
20
|
}
|
|
27
|
-
/**
|
|
28
|
-
* @stability stable
|
|
29
|
-
*/
|
|
30
21
|
export declare class Chart extends Construct {
|
|
31
22
|
/**
|
|
32
23
|
* Finds the chart in which a node is defined.
|
|
33
|
-
*
|
|
34
|
-
* @param c a construct node.
|
|
35
|
-
* @stability stable
|
|
24
|
+
* @param c a construct node
|
|
36
25
|
*/
|
|
37
26
|
static of(c: IConstruct): Chart;
|
|
38
27
|
/**
|
|
39
28
|
* The default namespace for all objects in this chart.
|
|
40
|
-
*
|
|
41
|
-
* @stability stable
|
|
42
29
|
*/
|
|
43
30
|
readonly namespace?: string;
|
|
44
31
|
/**
|
|
45
32
|
* Chart-level labels.
|
|
46
33
|
*/
|
|
47
34
|
private readonly _labels?;
|
|
48
|
-
/**
|
|
49
|
-
* @stability stable
|
|
50
|
-
*/
|
|
51
35
|
constructor(scope: Construct, id: string, props?: ChartProps);
|
|
52
36
|
/**
|
|
53
37
|
* Labels applied to all resources in this chart.
|
|
54
38
|
*
|
|
55
39
|
* This is an immutable copy.
|
|
56
|
-
*
|
|
57
|
-
* @stability stable
|
|
58
40
|
*/
|
|
59
41
|
get labels(): {
|
|
60
42
|
[name: string]: string;
|
|
@@ -78,23 +60,18 @@ export declare class Chart extends Construct {
|
|
|
78
60
|
* chart level.
|
|
79
61
|
*
|
|
80
62
|
* @param apiObject The API object to generate a name for.
|
|
81
|
-
* @stability stable
|
|
82
63
|
*/
|
|
83
64
|
generateObjectName(apiObject: ApiObject): string;
|
|
84
65
|
/**
|
|
85
66
|
* Create a dependency between this Chart and other constructs.
|
|
86
|
-
*
|
|
87
67
|
* These can be other ApiObjects, Charts, or custom.
|
|
88
68
|
*
|
|
89
69
|
* @param dependencies the dependencies to add.
|
|
90
|
-
* @stability stable
|
|
91
70
|
*/
|
|
92
71
|
addDependency(...dependencies: IConstruct[]): void;
|
|
93
72
|
/**
|
|
94
73
|
* Renders this chart to a set of Kubernetes JSON resources.
|
|
95
|
-
*
|
|
96
74
|
* @returns array of resource manifests
|
|
97
|
-
* @stability stable
|
|
98
75
|
*/
|
|
99
76
|
toJson(): any[];
|
|
100
77
|
}
|
package/lib/chart.js
CHANGED
|
@@ -6,13 +6,7 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
|
6
6
|
const constructs_1 = require("constructs");
|
|
7
7
|
const app_1 = require("./app");
|
|
8
8
|
const names_1 = require("./names");
|
|
9
|
-
/**
|
|
10
|
-
* @stability stable
|
|
11
|
-
*/
|
|
12
9
|
class Chart extends constructs_1.Construct {
|
|
13
|
-
/**
|
|
14
|
-
* @stability stable
|
|
15
|
-
*/
|
|
16
10
|
constructor(scope, id, props = {}) {
|
|
17
11
|
var _b;
|
|
18
12
|
super(scope, id);
|
|
@@ -21,9 +15,7 @@ class Chart extends constructs_1.Construct {
|
|
|
21
15
|
}
|
|
22
16
|
/**
|
|
23
17
|
* Finds the chart in which a node is defined.
|
|
24
|
-
*
|
|
25
|
-
* @param c a construct node.
|
|
26
|
-
* @stability stable
|
|
18
|
+
* @param c a construct node
|
|
27
19
|
*/
|
|
28
20
|
static of(c) {
|
|
29
21
|
if (c instanceof Chart) {
|
|
@@ -39,8 +31,6 @@ class Chart extends constructs_1.Construct {
|
|
|
39
31
|
* Labels applied to all resources in this chart.
|
|
40
32
|
*
|
|
41
33
|
* This is an immutable copy.
|
|
42
|
-
*
|
|
43
|
-
* @stability stable
|
|
44
34
|
*/
|
|
45
35
|
get labels() {
|
|
46
36
|
return { ...this._labels };
|
|
@@ -64,27 +54,22 @@ class Chart extends constructs_1.Construct {
|
|
|
64
54
|
* chart level.
|
|
65
55
|
*
|
|
66
56
|
* @param apiObject The API object to generate a name for.
|
|
67
|
-
* @stability stable
|
|
68
57
|
*/
|
|
69
58
|
generateObjectName(apiObject) {
|
|
70
59
|
return names_1.Names.toDnsLabel(apiObject);
|
|
71
60
|
}
|
|
72
61
|
/**
|
|
73
62
|
* Create a dependency between this Chart and other constructs.
|
|
74
|
-
*
|
|
75
63
|
* These can be other ApiObjects, Charts, or custom.
|
|
76
64
|
*
|
|
77
65
|
* @param dependencies the dependencies to add.
|
|
78
|
-
* @stability stable
|
|
79
66
|
*/
|
|
80
67
|
addDependency(...dependencies) {
|
|
81
68
|
constructs_1.Node.of(this).addDependency(...dependencies);
|
|
82
69
|
}
|
|
83
70
|
/**
|
|
84
71
|
* Renders this chart to a set of Kubernetes JSON resources.
|
|
85
|
-
*
|
|
86
72
|
* @returns array of resource manifests
|
|
87
|
-
* @stability stable
|
|
88
73
|
*/
|
|
89
74
|
toJson() {
|
|
90
75
|
return app_1.App._synthChart(this);
|
|
@@ -92,5 +77,5 @@ class Chart extends constructs_1.Construct {
|
|
|
92
77
|
}
|
|
93
78
|
exports.Chart = Chart;
|
|
94
79
|
_a = JSII_RTTI_SYMBOL_1;
|
|
95
|
-
Chart[_a] = { fqn: "cdk8s.Chart", version: "2.2.
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
Chart[_a] = { fqn: "cdk8s.Chart", version: "2.2.14" };
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwyQ0FBeUQ7QUFFekQsK0JBQTRCO0FBQzVCLG1DQUFnQztBQW9CaEMsTUFBYSxLQUFNLFNBQVEsc0JBQVM7SUE2QmxDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsUUFBb0IsRUFBRzs7UUFDL0QsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQyxTQUFTLENBQUM7UUFDakMsSUFBSSxDQUFDLE9BQU8sU0FBRyxLQUFLLENBQUMsTUFBTSxtQ0FBSSxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQS9CRDs7O09BR0c7SUFDSSxNQUFNLENBQUMsRUFBRSxDQUFDLENBQWE7UUFDNUIsSUFBSSxDQUFDLFlBQVksS0FBSyxFQUFFO1lBQ3RCLE9BQU8sQ0FBQyxDQUFDO1NBQ1Y7UUFFRCxNQUFNLE1BQU0sR0FBRyxpQkFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFrQixDQUFDO1FBQzdDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxNQUFNLElBQUksS0FBSyxDQUFDLHFEQUFxRCxDQUFDLENBQUM7U0FDeEU7UUFFRCxPQUFPLEtBQUssQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQWtCRDs7OztPQUlHO0lBQ0gsSUFBVyxNQUFNO1FBQ2YsT0FBTyxFQUFFLEdBQUcsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7OztPQW1CRztJQUNJLGtCQUFrQixDQUFDLFNBQW9CO1FBQzVDLE9BQU8sYUFBSyxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxhQUFhLENBQUMsR0FBRyxZQUEwQjtRQUNoRCxpQkFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxhQUFhLENBQUMsR0FBRyxZQUFZLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksTUFBTTtRQUNYLE9BQU8sU0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMvQixDQUFDOztBQXBGSCxzQkFxRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QsIE5vZGUsIElDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IEFwaU9iamVjdCB9IGZyb20gJy4vYXBpLW9iamVjdCc7XG5pbXBvcnQgeyBBcHAgfSBmcm9tICcuL2FwcCc7XG5pbXBvcnQgeyBOYW1lcyB9IGZyb20gJy4vbmFtZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIENoYXJ0UHJvcHMge1xuICAvKipcbiAgICogVGhlIGRlZmF1bHQgbmFtZXNwYWNlIGZvciBhbGwgb2JqZWN0cyBkZWZpbmVkIGluIHRoaXMgY2hhcnQgKGRpcmVjdGx5IG9yXG4gICAqIGluZGlyZWN0bHkpLiBUaGlzIG5hbWVzcGFjZSB3aWxsIG9ubHkgYXBwbHkgdG8gb2JqZWN0cyB0aGF0IGRvbid0IGhhdmUgYVxuICAgKiBgbmFtZXNwYWNlYCBleHBsaWNpdGx5IGRlZmluZWQgZm9yIHRoZW0uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gbmFtZXNwYWNlIGlzIHN5bnRoZXNpemVkICh1c3VhbGx5IHRoaXMgaW1wbGllcyBcImRlZmF1bHRcIilcbiAgICovXG4gIHJlYWRvbmx5IG5hbWVzcGFjZT86IHN0cmluZztcblxuICAvKipcbiAgICogTGFiZWxzIHRvIGFwcGx5IHRvIGFsbCByZXNvdXJjZXMgaW4gdGhpcyBjaGFydC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBjb21tb24gbGFiZWxzXG4gICAqL1xuICByZWFkb25seSBsYWJlbHM/OiB7IFtuYW1lOiBzdHJpbmddOiBzdHJpbmcgfTtcbn1cblxuZXhwb3J0IGNsYXNzIENoYXJ0IGV4dGVuZHMgQ29uc3RydWN0IHtcblxuICAvKipcbiAgICogRmluZHMgdGhlIGNoYXJ0IGluIHdoaWNoIGEgbm9kZSBpcyBkZWZpbmVkLlxuICAgKiBAcGFyYW0gYyBhIGNvbnN0cnVjdCBub2RlXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIG9mKGM6IElDb25zdHJ1Y3QpOiBDaGFydCB7XG4gICAgaWYgKGMgaW5zdGFuY2VvZiBDaGFydCkge1xuICAgICAgcmV0dXJuIGM7XG4gICAgfVxuXG4gICAgY29uc3QgcGFyZW50ID0gTm9kZS5vZihjKS5zY29wZSBhcyBDb25zdHJ1Y3Q7XG4gICAgaWYgKCFwYXJlbnQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignY2Fubm90IGZpbmQgYSBwYXJlbnQgY2hhcnQgKGRpcmVjdGx5IG9yIGluZGlyZWN0bHkpJyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIENoYXJ0Lm9mKHBhcmVudCk7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGRlZmF1bHQgbmFtZXNwYWNlIGZvciBhbGwgb2JqZWN0cyBpbiB0aGlzIGNoYXJ0LlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IG5hbWVzcGFjZT86IHN0cmluZztcblxuICAvKipcbiAgICogQ2hhcnQtbGV2ZWwgbGFiZWxzLlxuICAgKi9cbiAgcHJpdmF0ZSByZWFkb25seSBfbGFiZWxzPzogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIH07XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IENoYXJ0UHJvcHMgPSB7IH0pIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIHRoaXMubmFtZXNwYWNlID0gcHJvcHMubmFtZXNwYWNlO1xuICAgIHRoaXMuX2xhYmVscyA9IHByb3BzLmxhYmVscyA/PyB7fTtcbiAgfVxuXG4gIC8qKlxuICAgKiBMYWJlbHMgYXBwbGllZCB0byBhbGwgcmVzb3VyY2VzIGluIHRoaXMgY2hhcnQuXG4gICAqXG4gICAqIFRoaXMgaXMgYW4gaW1tdXRhYmxlIGNvcHkuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGxhYmVscygpOiB7IFtuYW1lOiBzdHJpbmddOiBzdHJpbmcgfSB7XG4gICAgcmV0dXJuIHsgLi4udGhpcy5fbGFiZWxzIH07XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGVzIGEgYXBwLXVuaXF1ZSBuYW1lIGZvciBhbiBvYmplY3QgZ2l2ZW4gaXQncyBjb25zdHJ1Y3Qgbm9kZSBwYXRoLlxuICAgKlxuICAgKiBEaWZmZXJlbnQgcmVzb3VyY2UgdHlwZXMgbWF5IGhhdmUgZGlmZmVyZW50IGNvbnN0cmFpbnRzIG9uIG5hbWVzXG4gICAqIChgbWV0YWRhdGEubmFtZWApLiBUaGUgcHJldmlvdXMgdmVyc2lvbiBvZiB0aGUgbmFtZSBnZW5lcmF0b3Igd2FzXG4gICAqIGNvbXBhdGlibGUgd2l0aCBETlNfU1VCRE9NQUlOIGJ1dCBub3Qgd2l0aCBETlNfTEFCRUwuXG4gICAqXG4gICAqIEZvciBleGFtcGxlLCBgRGVwbG95bWVudGAgbmFtZXMgbXVzdCBjb21wbHkgd2l0aCBETlNfU1VCRE9NQUlOIHdoaWxlXG4gICAqIGBTZXJ2aWNlYCBuYW1lcyBtdXN0IGNvbXBseSB3aXRoIEROU19MQUJFTC5cbiAgICpcbiAgICogU2luY2UgdGhlcmUgaXMgbm8gZm9ybWFsIHNwZWNpZmljYXRpb24gZm9yIHRoaXMsIHRoZSBkZWZhdWx0IG5hbWVcbiAgICogZ2VuZXJhdGlvbiBzY2hlbWUgZm9yIGt1YmVybmV0ZXMgb2JqZWN0cyBpbiBjZGs4cyB3YXMgY2hhbmdlZCB0byBETlNfTEFCRUwsXG4gICAqIHNpbmNlIGl04oCZcyB0aGUgY29tbW9uIGRlbm9taW5hdG9yIGZvciBhbGwga3ViZXJuZXRlcyByZXNvdXJjZXNcbiAgICogKHN1cHBvc2VkbHkpLlxuICAgKlxuICAgKiBZb3UgY2FuIG92ZXJyaWRlIHRoaXMgbWV0aG9kIGlmIHlvdSB3aXNoIHRvIGN1c3RvbWl6ZSBvYmplY3QgbmFtZXMgYXQgdGhlXG4gICAqIGNoYXJ0IGxldmVsLlxuICAgKlxuICAgKiBAcGFyYW0gYXBpT2JqZWN0IFRoZSBBUEkgb2JqZWN0IHRvIGdlbmVyYXRlIGEgbmFtZSBmb3IuXG4gICAqL1xuICBwdWJsaWMgZ2VuZXJhdGVPYmplY3ROYW1lKGFwaU9iamVjdDogQXBpT2JqZWN0KSB7XG4gICAgcmV0dXJuIE5hbWVzLnRvRG5zTGFiZWwoYXBpT2JqZWN0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBkZXBlbmRlbmN5IGJldHdlZW4gdGhpcyBDaGFydCBhbmQgb3RoZXIgY29uc3RydWN0cy5cbiAgICogVGhlc2UgY2FuIGJlIG90aGVyIEFwaU9iamVjdHMsIENoYXJ0cywgb3IgY3VzdG9tLlxuICAgKlxuICAgKiBAcGFyYW0gZGVwZW5kZW5jaWVzIHRoZSBkZXBlbmRlbmNpZXMgdG8gYWRkLlxuICAgKi9cbiAgcHVibGljIGFkZERlcGVuZGVuY3koLi4uZGVwZW5kZW5jaWVzOiBJQ29uc3RydWN0W10pIHtcbiAgICBOb2RlLm9mKHRoaXMpLmFkZERlcGVuZGVuY3koLi4uZGVwZW5kZW5jaWVzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW5kZXJzIHRoaXMgY2hhcnQgdG8gYSBzZXQgb2YgS3ViZXJuZXRlcyBKU09OIHJlc291cmNlcy5cbiAgICogQHJldHVybnMgYXJyYXkgb2YgcmVzb3VyY2UgbWFuaWZlc3RzXG4gICAqL1xuICBwdWJsaWMgdG9Kc29uKCk6IGFueVtdIHtcbiAgICByZXR1cm4gQXBwLl9zeW50aENoYXJ0KHRoaXMpO1xuICB9XG59XG5cbiJdfQ==
|
package/lib/dependency.d.ts
CHANGED
|
@@ -11,26 +11,19 @@ import { Node, IConstruct } from 'constructs';
|
|
|
11
11
|
* The graph does not include cross-scope dependencies. That is, if a child on the current scope depends on a node
|
|
12
12
|
* from a different scope, that relationship is not represented in this graph.
|
|
13
13
|
*
|
|
14
|
-
* @stability stable
|
|
15
14
|
*/
|
|
16
15
|
export declare class DependencyGraph {
|
|
17
16
|
private readonly _fosterParent;
|
|
18
|
-
/**
|
|
19
|
-
* @stability stable
|
|
20
|
-
*/
|
|
21
17
|
constructor(node: Node);
|
|
22
18
|
/**
|
|
23
19
|
* Returns the root of the graph.
|
|
24
20
|
*
|
|
25
21
|
* Note that this vertex will always have `null` as its `.value` since it is an artifical root
|
|
26
22
|
* that binds all the connected spaces of the graph.
|
|
27
|
-
*
|
|
28
|
-
* @stability stable
|
|
29
23
|
*/
|
|
30
24
|
get root(): DependencyVertex;
|
|
31
25
|
/**
|
|
32
26
|
* @see Vertex.topology()
|
|
33
|
-
* @stability stable
|
|
34
27
|
*/
|
|
35
28
|
topology(): IConstruct[];
|
|
36
29
|
}
|
|
@@ -38,52 +31,37 @@ export declare class DependencyGraph {
|
|
|
38
31
|
* Represents a vertex in the graph.
|
|
39
32
|
*
|
|
40
33
|
* The value of each vertex is an `IConstruct` that is accessible via the `.value` getter.
|
|
41
|
-
*
|
|
42
|
-
* @stability stable
|
|
43
34
|
*/
|
|
44
35
|
export declare class DependencyVertex {
|
|
45
36
|
private readonly _value;
|
|
46
37
|
private readonly _children;
|
|
47
38
|
private readonly _parents;
|
|
48
|
-
/**
|
|
49
|
-
* @stability stable
|
|
50
|
-
*/
|
|
51
39
|
constructor(value?: IConstruct | undefined);
|
|
52
40
|
/**
|
|
53
41
|
* Returns the IConstruct this graph vertex represents.
|
|
54
42
|
*
|
|
55
43
|
* `null` in case this is the root of the graph.
|
|
56
|
-
*
|
|
57
|
-
* @stability stable
|
|
58
44
|
*/
|
|
59
45
|
get value(): IConstruct | undefined;
|
|
60
46
|
/**
|
|
61
|
-
* Returns the children of the vertex (i.e dependencies)
|
|
62
|
-
*
|
|
63
|
-
* @stability stable
|
|
47
|
+
* Returns the children of the vertex (i.e dependencies)
|
|
64
48
|
*/
|
|
65
49
|
get outbound(): Array<DependencyVertex>;
|
|
66
50
|
/**
|
|
67
|
-
* Returns the parents of the vertex (i.e dependants)
|
|
68
|
-
*
|
|
69
|
-
* @stability stable
|
|
51
|
+
* Returns the parents of the vertex (i.e dependants)
|
|
70
52
|
*/
|
|
71
53
|
get inbound(): Array<DependencyVertex>;
|
|
72
54
|
/**
|
|
73
55
|
* Returns a topologically sorted array of the constructs in the sub-graph.
|
|
74
|
-
*
|
|
75
|
-
* @stability stable
|
|
76
56
|
*/
|
|
77
57
|
topology(): IConstruct[];
|
|
78
58
|
/**
|
|
79
59
|
* Adds a vertex as a dependency of the current node.
|
|
80
|
-
*
|
|
81
60
|
* Also updates the parents of `dep`, so that it contains this node as a parent.
|
|
82
61
|
*
|
|
83
62
|
* This operation will fail in case it creates a cycle in the graph.
|
|
84
63
|
*
|
|
85
|
-
* @param dep The dependency
|
|
86
|
-
* @stability stable
|
|
64
|
+
* @param dep The dependency
|
|
87
65
|
*/
|
|
88
66
|
addChild(dep: DependencyVertex): void;
|
|
89
67
|
private addParent;
|
package/lib/dependency.js
CHANGED
|
@@ -16,12 +16,8 @@ const constructs_1 = require("constructs");
|
|
|
16
16
|
* The graph does not include cross-scope dependencies. That is, if a child on the current scope depends on a node
|
|
17
17
|
* from a different scope, that relationship is not represented in this graph.
|
|
18
18
|
*
|
|
19
|
-
* @stability stable
|
|
20
19
|
*/
|
|
21
20
|
class DependencyGraph {
|
|
22
|
-
/**
|
|
23
|
-
* @stability stable
|
|
24
|
-
*/
|
|
25
21
|
constructor(node) {
|
|
26
22
|
this._fosterParent = new DependencyVertex();
|
|
27
23
|
const nodes = {};
|
|
@@ -67,15 +63,12 @@ class DependencyGraph {
|
|
|
67
63
|
*
|
|
68
64
|
* Note that this vertex will always have `null` as its `.value` since it is an artifical root
|
|
69
65
|
* that binds all the connected spaces of the graph.
|
|
70
|
-
*
|
|
71
|
-
* @stability stable
|
|
72
66
|
*/
|
|
73
67
|
get root() {
|
|
74
68
|
return this._fosterParent;
|
|
75
69
|
}
|
|
76
70
|
/**
|
|
77
71
|
* @see Vertex.topology()
|
|
78
|
-
* @stability stable
|
|
79
72
|
*/
|
|
80
73
|
topology() {
|
|
81
74
|
return this._fosterParent.topology();
|
|
@@ -83,18 +76,13 @@ class DependencyGraph {
|
|
|
83
76
|
}
|
|
84
77
|
exports.DependencyGraph = DependencyGraph;
|
|
85
78
|
_a = JSII_RTTI_SYMBOL_1;
|
|
86
|
-
DependencyGraph[_a] = { fqn: "cdk8s.DependencyGraph", version: "2.2.
|
|
79
|
+
DependencyGraph[_a] = { fqn: "cdk8s.DependencyGraph", version: "2.2.14" };
|
|
87
80
|
/**
|
|
88
81
|
* Represents a vertex in the graph.
|
|
89
82
|
*
|
|
90
83
|
* The value of each vertex is an `IConstruct` that is accessible via the `.value` getter.
|
|
91
|
-
*
|
|
92
|
-
* @stability stable
|
|
93
84
|
*/
|
|
94
85
|
class DependencyVertex {
|
|
95
|
-
/**
|
|
96
|
-
* @stability stable
|
|
97
|
-
*/
|
|
98
86
|
constructor(value = undefined) {
|
|
99
87
|
this._children = new Set();
|
|
100
88
|
this._parents = new Set();
|
|
@@ -104,32 +92,24 @@ class DependencyVertex {
|
|
|
104
92
|
* Returns the IConstruct this graph vertex represents.
|
|
105
93
|
*
|
|
106
94
|
* `null` in case this is the root of the graph.
|
|
107
|
-
*
|
|
108
|
-
* @stability stable
|
|
109
95
|
*/
|
|
110
96
|
get value() {
|
|
111
97
|
return this._value;
|
|
112
98
|
}
|
|
113
99
|
/**
|
|
114
|
-
* Returns the children of the vertex (i.e dependencies)
|
|
115
|
-
*
|
|
116
|
-
* @stability stable
|
|
100
|
+
* Returns the children of the vertex (i.e dependencies)
|
|
117
101
|
*/
|
|
118
102
|
get outbound() {
|
|
119
103
|
return Array.from(this._children);
|
|
120
104
|
}
|
|
121
105
|
/**
|
|
122
|
-
* Returns the parents of the vertex (i.e dependants)
|
|
123
|
-
*
|
|
124
|
-
* @stability stable
|
|
106
|
+
* Returns the parents of the vertex (i.e dependants)
|
|
125
107
|
*/
|
|
126
108
|
get inbound() {
|
|
127
109
|
return Array.from(this._parents);
|
|
128
110
|
}
|
|
129
111
|
/**
|
|
130
112
|
* Returns a topologically sorted array of the constructs in the sub-graph.
|
|
131
|
-
*
|
|
132
|
-
* @stability stable
|
|
133
113
|
*/
|
|
134
114
|
topology() {
|
|
135
115
|
const found = new Set();
|
|
@@ -148,13 +128,11 @@ class DependencyVertex {
|
|
|
148
128
|
}
|
|
149
129
|
/**
|
|
150
130
|
* Adds a vertex as a dependency of the current node.
|
|
151
|
-
*
|
|
152
131
|
* Also updates the parents of `dep`, so that it contains this node as a parent.
|
|
153
132
|
*
|
|
154
133
|
* This operation will fail in case it creates a cycle in the graph.
|
|
155
134
|
*
|
|
156
|
-
* @param dep The dependency
|
|
157
|
-
* @stability stable
|
|
135
|
+
* @param dep The dependency
|
|
158
136
|
*/
|
|
159
137
|
addChild(dep) {
|
|
160
138
|
const cycle = dep.findRoute(this);
|
|
@@ -191,5 +169,5 @@ class DependencyVertex {
|
|
|
191
169
|
}
|
|
192
170
|
exports.DependencyVertex = DependencyVertex;
|
|
193
171
|
_b = JSII_RTTI_SYMBOL_1;
|
|
194
|
-
DependencyVertex[_b] = { fqn: "cdk8s.DependencyVertex", version: "2.2.
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency.js","sourceRoot":"","sources":["../src/dependency.ts"],"names":[],"mappings":"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","sourcesContent":["import { Node, IConstruct } from 'constructs';\n\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   \nexport class DependencyGraph {\n\n  private readonly _fosterParent: DependencyVertex;\n\n  constructor(node: Node) {\n\n    this._fosterParent = new DependencyVertex();\n\n    const nodes: Record<string, DependencyVertex> = {};\n\n    function putVertex(construct: IConstruct) {\n      nodes[Node.of(construct).path] = new DependencyVertex(construct);\n    }\n\n    function getVertex(construct: IConstruct): DependencyVertex {\n      return nodes[Node.of(construct).path];\n    }\n\n    // create all vertices of the graph.\n    for (const n of node.findAll()) {\n      putVertex(n);\n    }\n\n    const deps = [];\n    for (const child of node.findAll()) {\n      for (const dep of child.node.dependencies) {\n        deps.push({ source: child, target: dep });\n      }\n    }\n\n    // create all the edges of the graph.\n    for (const dep of deps) {\n\n      if (!getVertex(dep.target)) {\n        // dont cross scope boundaries.\n        // since charts only renders its own children, this is ok and\n        // has the benefit of simplifying the graph. we should reconsider this behavior when moving\n        // to a more general purpose use-case.\n        continue;\n      }\n\n      const sourceDepNode = getVertex(dep.source);\n      const targetDepNode = getVertex(dep.target);\n\n      sourceDepNode.addChild(targetDepNode);\n\n    }\n\n    // create the root.\n    for (const n of Object.values(nodes)) {\n      if (n.inbound.length === 0) {\n        // orphans are dependency roots. lets adopt them!\n        this._fosterParent.addChild(n);\n      }\n    }\n\n  }\n\n                                                                                                                                                                                                            \n  public get root(): DependencyVertex {\n    return this._fosterParent;\n  }\n\n                                       \n  public topology(): IConstruct[] {\n    return this._fosterParent.topology();\n  }\n}\n\n                                                                                                                                          \nexport class DependencyVertex {\n\n  private readonly _value: IConstruct | undefined;\n  private readonly _children: Set<DependencyVertex> = new Set<DependencyVertex>();\n  private readonly _parents: Set<DependencyVertex> = new Set<DependencyVertex>();\n\n  constructor(value: IConstruct | undefined = undefined) {\n    this._value = value;\n  }\n\n                                                                                                                             \n  public get value(): IConstruct | undefined {\n    return this._value;\n  }\n\n                                                                      \n  public get outbound(): Array<DependencyVertex> {\n    return Array.from(this._children);\n  }\n\n                                                                   \n  public get inbound(): Array<DependencyVertex> {\n    return Array.from(this._parents);\n  }\n\n                                                                                         \n  public topology(): IConstruct[] {\n\n    const found = new Set<DependencyVertex>();\n    const topology: DependencyVertex[] = [];\n\n    function visit(n: DependencyVertex) {\n      for (const c of n.outbound) {\n        visit(c);\n      }\n      if (!found.has(n)) {\n        topology.push(n);\n        found.add(n);\n      }\n    }\n\n    visit(this);\n\n    return topology.filter(d => d.value).map(d => d.value!);\n\n  }\n\n                                                                                                                                                                                                                                                                      \n  public addChild(dep: DependencyVertex) {\n\n    const cycle: DependencyVertex[] = dep.findRoute(this);\n    if (cycle.length !== 0) {\n      cycle.push(dep);\n      throw new Error(`Dependency cycle detected: ${cycle.filter(d => d.value).map(d => Node.of(d.value!).path).join(' => ')}`);\n    }\n\n    this._children.add(dep);\n    dep.addParent(this);\n  }\n\n  private addParent(dep: DependencyVertex) {\n    this._parents.add(dep);\n  }\n\n  private findRoute(dst: DependencyVertex): DependencyVertex[] {\n\n    const route: DependencyVertex[] = [];\n    visit(this);\n    return route;\n\n    function visit(n: DependencyVertex): boolean {\n      route.push(n);\n      let found = false;\n      for (const c of n.outbound) {\n        if (c === dst) {\n          route.push(c);\n          return true;\n        }\n        found = visit(c);\n      }\n      if (!found) {\n        route.pop();\n      }\n      return found;\n\n    }\n\n  }\n}\n"]}
|
|
172
|
+
DependencyVertex[_b] = { fqn: "cdk8s.DependencyVertex", version: "2.2.14" };
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency.js","sourceRoot":"","sources":["../src/dependency.ts"],"names":[],"mappings":"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","sourcesContent":["import { Node, IConstruct } from 'constructs';\n\n\n/**\n * Represents the dependency graph for a given Node.\n *\n * This graph includes the dependency relationships between all nodes in the\n * node (construct) sub-tree who's root is this Node.\n *\n * Note that this means that lonely nodes (no dependencies and no dependants) are also included in this graph as\n * childless children of the root node of the graph.\n *\n * The graph does not include cross-scope dependencies. That is, if a child on the current scope depends on a node\n * from a different scope, that relationship is not represented in this graph.\n *\n */\nexport class DependencyGraph {\n\n  private readonly _fosterParent: DependencyVertex;\n\n  constructor(node: Node) {\n\n    this._fosterParent = new DependencyVertex();\n\n    const nodes: Record<string, DependencyVertex> = {};\n\n    function putVertex(construct: IConstruct) {\n      nodes[Node.of(construct).path] = new DependencyVertex(construct);\n    }\n\n    function getVertex(construct: IConstruct): DependencyVertex {\n      return nodes[Node.of(construct).path];\n    }\n\n    // create all vertices of the graph.\n    for (const n of node.findAll()) {\n      putVertex(n);\n    }\n\n    const deps = [];\n    for (const child of node.findAll()) {\n      for (const dep of child.node.dependencies) {\n        deps.push({ source: child, target: dep });\n      }\n    }\n\n    // create all the edges of the graph.\n    for (const dep of deps) {\n\n      if (!getVertex(dep.target)) {\n        // dont cross scope boundaries.\n        // since charts only renders its own children, this is ok and\n        // has the benefit of simplifying the graph. we should reconsider this behavior when moving\n        // to a more general purpose use-case.\n        continue;\n      }\n\n      const sourceDepNode = getVertex(dep.source);\n      const targetDepNode = getVertex(dep.target);\n\n      sourceDepNode.addChild(targetDepNode);\n\n    }\n\n    // create the root.\n    for (const n of Object.values(nodes)) {\n      if (n.inbound.length === 0) {\n        // orphans are dependency roots. lets adopt them!\n        this._fosterParent.addChild(n);\n      }\n    }\n\n  }\n\n  /**\n   * Returns the root of the graph.\n   *\n   * Note that this vertex will always have `null` as its `.value` since it is an artifical root\n   * that binds all the connected spaces of the graph.\n   */\n  public get root(): DependencyVertex {\n    return this._fosterParent;\n  }\n\n  /**\n   * @see Vertex.topology()\n   */\n  public topology(): IConstruct[] {\n    return this._fosterParent.topology();\n  }\n}\n\n/**\n * Represents a vertex in the graph.\n *\n * The value of each vertex is an `IConstruct` that is accessible via the `.value` getter.\n */\nexport class DependencyVertex {\n\n  private readonly _value: IConstruct | undefined;\n  private readonly _children: Set<DependencyVertex> = new Set<DependencyVertex>();\n  private readonly _parents: Set<DependencyVertex> = new Set<DependencyVertex>();\n\n  constructor(value: IConstruct | undefined = undefined) {\n    this._value = value;\n  }\n\n  /**\n   * Returns the IConstruct this graph vertex represents.\n   *\n   * `null` in case this is the root of the graph.\n   */\n  public get value(): IConstruct | undefined {\n    return this._value;\n  }\n\n  /**\n   * Returns the children of the vertex (i.e dependencies)\n   */\n  public get outbound(): Array<DependencyVertex> {\n    return Array.from(this._children);\n  }\n\n  /**\n   * Returns the parents of the vertex (i.e dependants)\n   */\n  public get inbound(): Array<DependencyVertex> {\n    return Array.from(this._parents);\n  }\n\n  /**\n   * Returns a topologically sorted array of the constructs in the sub-graph.\n   */\n  public topology(): IConstruct[] {\n\n    const found = new Set<DependencyVertex>();\n    const topology: DependencyVertex[] = [];\n\n    function visit(n: DependencyVertex) {\n      for (const c of n.outbound) {\n        visit(c);\n      }\n      if (!found.has(n)) {\n        topology.push(n);\n        found.add(n);\n      }\n    }\n\n    visit(this);\n\n    return topology.filter(d => d.value).map(d => d.value!);\n\n  }\n\n  /**\n   * Adds a vertex as a dependency of the current node.\n   * Also updates the parents of `dep`, so that it contains this node as a parent.\n   *\n   * This operation will fail in case it creates a cycle in the graph.\n   *\n   * @param dep The dependency\n   */\n  public addChild(dep: DependencyVertex) {\n\n    const cycle: DependencyVertex[] = dep.findRoute(this);\n    if (cycle.length !== 0) {\n      cycle.push(dep);\n      throw new Error(`Dependency cycle detected: ${cycle.filter(d => d.value).map(d => Node.of(d.value!).path).join(' => ')}`);\n    }\n\n    this._children.add(dep);\n    dep.addParent(this);\n  }\n\n  private addParent(dep: DependencyVertex) {\n    this._parents.add(dep);\n  }\n\n  private findRoute(dst: DependencyVertex): DependencyVertex[] {\n\n    const route: DependencyVertex[] = [];\n    visit(this);\n    return route;\n\n    function visit(n: DependencyVertex): boolean {\n      route.push(n);\n      let found = false;\n      for (const c of n.outbound) {\n        if (c === dst) {\n          route.push(c);\n          return true;\n        }\n        found = visit(c);\n      }\n      if (!found) {\n        route.pop();\n      }\n      return found;\n\n    }\n\n  }\n}\n"]}
|
package/lib/duration.d.ts
CHANGED
|
@@ -4,123 +4,106 @@
|
|
|
4
4
|
* The amount can be specified either as a literal value (e.g: `10`) which
|
|
5
5
|
* cannot be negative.
|
|
6
6
|
*
|
|
7
|
-
* @stability stable
|
|
8
7
|
*/
|
|
9
8
|
export declare class Duration {
|
|
10
9
|
/**
|
|
11
|
-
* Create a Duration representing an amount of milliseconds
|
|
10
|
+
* Create a Duration representing an amount of milliseconds
|
|
12
11
|
*
|
|
13
12
|
* @param amount the amount of Milliseconds the `Duration` will represent.
|
|
14
13
|
* @returns a new `Duration` representing `amount` ms.
|
|
15
|
-
* @stability stable
|
|
16
14
|
*/
|
|
17
15
|
static millis(amount: number): Duration;
|
|
18
16
|
/**
|
|
19
|
-
* Create a Duration representing an amount of seconds
|
|
17
|
+
* Create a Duration representing an amount of seconds
|
|
20
18
|
*
|
|
21
19
|
* @param amount the amount of Seconds the `Duration` will represent.
|
|
22
20
|
* @returns a new `Duration` representing `amount` Seconds.
|
|
23
|
-
* @stability stable
|
|
24
21
|
*/
|
|
25
22
|
static seconds(amount: number): Duration;
|
|
26
23
|
/**
|
|
27
|
-
* Create a Duration representing an amount of minutes
|
|
24
|
+
* Create a Duration representing an amount of minutes
|
|
28
25
|
*
|
|
29
26
|
* @param amount the amount of Minutes the `Duration` will represent.
|
|
30
27
|
* @returns a new `Duration` representing `amount` Minutes.
|
|
31
|
-
* @stability stable
|
|
32
28
|
*/
|
|
33
29
|
static minutes(amount: number): Duration;
|
|
34
30
|
/**
|
|
35
|
-
* Create a Duration representing an amount of hours
|
|
31
|
+
* Create a Duration representing an amount of hours
|
|
36
32
|
*
|
|
37
33
|
* @param amount the amount of Hours the `Duration` will represent.
|
|
38
34
|
* @returns a new `Duration` representing `amount` Hours.
|
|
39
|
-
* @stability stable
|
|
40
35
|
*/
|
|
41
36
|
static hours(amount: number): Duration;
|
|
42
37
|
/**
|
|
43
|
-
* Create a Duration representing an amount of days
|
|
38
|
+
* Create a Duration representing an amount of days
|
|
44
39
|
*
|
|
45
40
|
* @param amount the amount of Days the `Duration` will represent.
|
|
46
41
|
* @returns a new `Duration` representing `amount` Days.
|
|
47
|
-
* @stability stable
|
|
48
42
|
*/
|
|
49
43
|
static days(amount: number): Duration;
|
|
50
44
|
/**
|
|
51
|
-
* Parse a period formatted according to the ISO 8601 standard
|
|
45
|
+
* Parse a period formatted according to the ISO 8601 standard
|
|
52
46
|
*
|
|
47
|
+
* @see https://www.iso.org/fr/standard/70907.html
|
|
53
48
|
* @param duration an ISO-formtted duration to be parsed.
|
|
54
49
|
* @returns the parsed `Duration`.
|
|
55
|
-
* @see https://www.iso.org/fr/standard/70907.html
|
|
56
|
-
* @stability stable
|
|
57
50
|
*/
|
|
58
51
|
static parse(duration: string): Duration;
|
|
59
52
|
private readonly amount;
|
|
60
53
|
private readonly unit;
|
|
61
54
|
private constructor();
|
|
62
55
|
/**
|
|
63
|
-
* Return the total number of milliseconds in this Duration
|
|
56
|
+
* Return the total number of milliseconds in this Duration
|
|
64
57
|
*
|
|
65
58
|
* @returns the value of this `Duration` expressed in Milliseconds.
|
|
66
|
-
* @stability stable
|
|
67
59
|
*/
|
|
68
60
|
toMilliseconds(opts?: TimeConversionOptions): number;
|
|
69
61
|
/**
|
|
70
|
-
* Return the total number of seconds in this Duration
|
|
62
|
+
* Return the total number of seconds in this Duration
|
|
71
63
|
*
|
|
72
64
|
* @returns the value of this `Duration` expressed in Seconds.
|
|
73
|
-
* @stability stable
|
|
74
65
|
*/
|
|
75
66
|
toSeconds(opts?: TimeConversionOptions): number;
|
|
76
67
|
/**
|
|
77
|
-
* Return the total number of minutes in this Duration
|
|
68
|
+
* Return the total number of minutes in this Duration
|
|
78
69
|
*
|
|
79
70
|
* @returns the value of this `Duration` expressed in Minutes.
|
|
80
|
-
* @stability stable
|
|
81
71
|
*/
|
|
82
72
|
toMinutes(opts?: TimeConversionOptions): number;
|
|
83
73
|
/**
|
|
84
|
-
* Return the total number of hours in this Duration
|
|
74
|
+
* Return the total number of hours in this Duration
|
|
85
75
|
*
|
|
86
76
|
* @returns the value of this `Duration` expressed in Hours.
|
|
87
|
-
* @stability stable
|
|
88
77
|
*/
|
|
89
78
|
toHours(opts?: TimeConversionOptions): number;
|
|
90
79
|
/**
|
|
91
|
-
* Return the total number of days in this Duration
|
|
80
|
+
* Return the total number of days in this Duration
|
|
92
81
|
*
|
|
93
82
|
* @returns the value of this `Duration` expressed in Days.
|
|
94
|
-
* @stability stable
|
|
95
83
|
*/
|
|
96
84
|
toDays(opts?: TimeConversionOptions): number;
|
|
97
85
|
/**
|
|
98
|
-
* Return an ISO 8601 representation of this period
|
|
86
|
+
* Return an ISO 8601 representation of this period
|
|
99
87
|
*
|
|
100
88
|
* @returns a string starting with 'PT' describing the period
|
|
101
89
|
* @see https://www.iso.org/fr/standard/70907.html
|
|
102
|
-
* @stability stable
|
|
103
90
|
*/
|
|
104
91
|
toIsoString(): string;
|
|
105
92
|
/**
|
|
106
|
-
* Turn this duration into a human-readable string
|
|
107
|
-
*
|
|
108
|
-
* @stability stable
|
|
93
|
+
* Turn this duration into a human-readable string
|
|
109
94
|
*/
|
|
110
95
|
toHumanString(): string;
|
|
111
96
|
private fractionDuration;
|
|
112
97
|
}
|
|
113
98
|
/**
|
|
114
99
|
* Options for how to convert time to a different unit.
|
|
115
|
-
*
|
|
116
|
-
* @stability stable
|
|
117
100
|
*/
|
|
118
101
|
export interface TimeConversionOptions {
|
|
119
102
|
/**
|
|
120
|
-
* If `true`, conversions into a larger time unit (e.g. `Seconds` to `Minutes`) will fail if the result is not an
|
|
103
|
+
* If `true`, conversions into a larger time unit (e.g. `Seconds` to `Minutes`) will fail if the result is not an
|
|
104
|
+
* integer.
|
|
121
105
|
*
|
|
122
106
|
* @default true
|
|
123
|
-
* @stability stable
|
|
124
107
|
*/
|
|
125
108
|
readonly integral?: boolean;
|
|
126
109
|
}
|