cdk8s 2.3.82 → 2.4.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.
- package/.jsii +273 -4
- package/docs/java.md +184 -0
- package/docs/python.md +243 -0
- package/docs/typescript.md +177 -0
- package/lib/api-object.js +1 -1
- package/lib/app.js +1 -1
- package/lib/chart.js +1 -1
- package/lib/dependency.js +2 -2
- package/lib/duration.d.ts +4 -0
- package/lib/duration.js +11 -2
- package/lib/helm.js +1 -1
- package/lib/include.js +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/index.js +2 -1
- package/lib/json-patch.js +1 -1
- package/lib/lazy.js +1 -1
- package/lib/metadata.js +1 -1
- package/lib/names.js +1 -1
- package/lib/schedule.d.ts +78 -0
- package/lib/schedule.js +92 -0
- package/lib/size.js +1 -1
- package/lib/testing.js +1 -1
- package/lib/yaml.js +1 -1
- package/package.json +2 -2
package/docs/python.md
CHANGED
|
@@ -925,6 +925,106 @@ This namespace will only apply to objects that don't have a
|
|
|
925
925
|
|
|
926
926
|
---
|
|
927
927
|
|
|
928
|
+
### CronOptions <a name="cdk8s.CronOptions"></a>
|
|
929
|
+
|
|
930
|
+
Options to configure a cron expression.
|
|
931
|
+
|
|
932
|
+
All fields are strings so you can use complex expressions. Absence of
|
|
933
|
+
a field implies '*' or '?', whichever one is appropriate.
|
|
934
|
+
|
|
935
|
+
#### Initializer <a name="[object Object].Initializer"></a>
|
|
936
|
+
|
|
937
|
+
```python
|
|
938
|
+
import cdk8s
|
|
939
|
+
|
|
940
|
+
cdk8s.CronOptions(
|
|
941
|
+
day: str = None,
|
|
942
|
+
hour: str = None,
|
|
943
|
+
minute: str = None,
|
|
944
|
+
month: str = None,
|
|
945
|
+
week_day: str = None,
|
|
946
|
+
year: str = None
|
|
947
|
+
)
|
|
948
|
+
```
|
|
949
|
+
|
|
950
|
+
##### `day`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.day"></a>
|
|
951
|
+
|
|
952
|
+
```python
|
|
953
|
+
day: str
|
|
954
|
+
```
|
|
955
|
+
|
|
956
|
+
- *Type:* `str`
|
|
957
|
+
- *Default:* Every day of the month
|
|
958
|
+
|
|
959
|
+
The day of the month to run this rule at.
|
|
960
|
+
|
|
961
|
+
---
|
|
962
|
+
|
|
963
|
+
##### `hour`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.hour"></a>
|
|
964
|
+
|
|
965
|
+
```python
|
|
966
|
+
hour: str
|
|
967
|
+
```
|
|
968
|
+
|
|
969
|
+
- *Type:* `str`
|
|
970
|
+
- *Default:* Every hour
|
|
971
|
+
|
|
972
|
+
The hour to run this rule at.
|
|
973
|
+
|
|
974
|
+
---
|
|
975
|
+
|
|
976
|
+
##### `minute`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.minute"></a>
|
|
977
|
+
|
|
978
|
+
```python
|
|
979
|
+
minute: str
|
|
980
|
+
```
|
|
981
|
+
|
|
982
|
+
- *Type:* `str`
|
|
983
|
+
- *Default:* Every minute
|
|
984
|
+
|
|
985
|
+
The minute to run this rule at.
|
|
986
|
+
|
|
987
|
+
---
|
|
988
|
+
|
|
989
|
+
##### `month`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.month"></a>
|
|
990
|
+
|
|
991
|
+
```python
|
|
992
|
+
month: str
|
|
993
|
+
```
|
|
994
|
+
|
|
995
|
+
- *Type:* `str`
|
|
996
|
+
- *Default:* Every month
|
|
997
|
+
|
|
998
|
+
The month to run this rule at.
|
|
999
|
+
|
|
1000
|
+
---
|
|
1001
|
+
|
|
1002
|
+
##### `week_day`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.week_day"></a>
|
|
1003
|
+
|
|
1004
|
+
```python
|
|
1005
|
+
week_day: str
|
|
1006
|
+
```
|
|
1007
|
+
|
|
1008
|
+
- *Type:* `str`
|
|
1009
|
+
- *Default:* Any day of the week
|
|
1010
|
+
|
|
1011
|
+
The day of the week to run this rule at.
|
|
1012
|
+
|
|
1013
|
+
---
|
|
1014
|
+
|
|
1015
|
+
##### `year`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.year"></a>
|
|
1016
|
+
|
|
1017
|
+
```python
|
|
1018
|
+
year: str
|
|
1019
|
+
```
|
|
1020
|
+
|
|
1021
|
+
- *Type:* `str`
|
|
1022
|
+
- *Default:* Every year
|
|
1023
|
+
|
|
1024
|
+
The year to run this rule at.
|
|
1025
|
+
|
|
1026
|
+
---
|
|
1027
|
+
|
|
928
1028
|
### GroupVersionKind <a name="cdk8s.GroupVersionKind"></a>
|
|
929
1029
|
|
|
930
1030
|
#### Initializer <a name="[object Object].Initializer"></a>
|
|
@@ -1903,6 +2003,12 @@ If `true`, conversions into a larger time unit (e.g. `Seconds` to `Minutes`) wil
|
|
|
1903
2003
|
|
|
1904
2004
|
---
|
|
1905
2005
|
|
|
2006
|
+
##### `unit_label` <a name="cdk8s.Duration.unit_label"></a>
|
|
2007
|
+
|
|
2008
|
+
```python
|
|
2009
|
+
def unit_label()
|
|
2010
|
+
```
|
|
2011
|
+
|
|
1906
2012
|
#### Static Functions <a name="Static Functions"></a>
|
|
1907
2013
|
|
|
1908
2014
|
##### `days` <a name="cdk8s.Duration.days"></a>
|
|
@@ -2343,6 +2449,143 @@ Maximum allowed length for the name.
|
|
|
2343
2449
|
|
|
2344
2450
|
|
|
2345
2451
|
|
|
2452
|
+
### Schedule <a name="cdk8s.Schedule"></a>
|
|
2453
|
+
|
|
2454
|
+
Represents a schedule.
|
|
2455
|
+
|
|
2456
|
+
Note that rates cannot be defined in fractions of minutes.
|
|
2457
|
+
|
|
2458
|
+
#### Initializers <a name="cdk8s.Schedule.Initializer"></a>
|
|
2459
|
+
|
|
2460
|
+
```python
|
|
2461
|
+
import cdk8s
|
|
2462
|
+
|
|
2463
|
+
cdk8s.Schedule()
|
|
2464
|
+
```
|
|
2465
|
+
|
|
2466
|
+
|
|
2467
|
+
#### Static Functions <a name="Static Functions"></a>
|
|
2468
|
+
|
|
2469
|
+
##### `cron` <a name="cdk8s.Schedule.cron"></a>
|
|
2470
|
+
|
|
2471
|
+
```python
|
|
2472
|
+
import cdk8s
|
|
2473
|
+
|
|
2474
|
+
cdk8s.Schedule.cron(
|
|
2475
|
+
day: str = None,
|
|
2476
|
+
hour: str = None,
|
|
2477
|
+
minute: str = None,
|
|
2478
|
+
month: str = None,
|
|
2479
|
+
week_day: str = None,
|
|
2480
|
+
year: str = None
|
|
2481
|
+
)
|
|
2482
|
+
```
|
|
2483
|
+
|
|
2484
|
+
###### `day`<sup>Optional</sup> <a name="cdk8s.CronOptions.parameter.day"></a>
|
|
2485
|
+
|
|
2486
|
+
- *Type:* `str`
|
|
2487
|
+
- *Default:* Every day of the month
|
|
2488
|
+
|
|
2489
|
+
The day of the month to run this rule at.
|
|
2490
|
+
|
|
2491
|
+
---
|
|
2492
|
+
|
|
2493
|
+
###### `hour`<sup>Optional</sup> <a name="cdk8s.CronOptions.parameter.hour"></a>
|
|
2494
|
+
|
|
2495
|
+
- *Type:* `str`
|
|
2496
|
+
- *Default:* Every hour
|
|
2497
|
+
|
|
2498
|
+
The hour to run this rule at.
|
|
2499
|
+
|
|
2500
|
+
---
|
|
2501
|
+
|
|
2502
|
+
###### `minute`<sup>Optional</sup> <a name="cdk8s.CronOptions.parameter.minute"></a>
|
|
2503
|
+
|
|
2504
|
+
- *Type:* `str`
|
|
2505
|
+
- *Default:* Every minute
|
|
2506
|
+
|
|
2507
|
+
The minute to run this rule at.
|
|
2508
|
+
|
|
2509
|
+
---
|
|
2510
|
+
|
|
2511
|
+
###### `month`<sup>Optional</sup> <a name="cdk8s.CronOptions.parameter.month"></a>
|
|
2512
|
+
|
|
2513
|
+
- *Type:* `str`
|
|
2514
|
+
- *Default:* Every month
|
|
2515
|
+
|
|
2516
|
+
The month to run this rule at.
|
|
2517
|
+
|
|
2518
|
+
---
|
|
2519
|
+
|
|
2520
|
+
###### `week_day`<sup>Optional</sup> <a name="cdk8s.CronOptions.parameter.week_day"></a>
|
|
2521
|
+
|
|
2522
|
+
- *Type:* `str`
|
|
2523
|
+
- *Default:* Any day of the week
|
|
2524
|
+
|
|
2525
|
+
The day of the week to run this rule at.
|
|
2526
|
+
|
|
2527
|
+
---
|
|
2528
|
+
|
|
2529
|
+
###### `year`<sup>Optional</sup> <a name="cdk8s.CronOptions.parameter.year"></a>
|
|
2530
|
+
|
|
2531
|
+
- *Type:* `str`
|
|
2532
|
+
- *Default:* Every year
|
|
2533
|
+
|
|
2534
|
+
The year to run this rule at.
|
|
2535
|
+
|
|
2536
|
+
---
|
|
2537
|
+
|
|
2538
|
+
##### `expression` <a name="cdk8s.Schedule.expression"></a>
|
|
2539
|
+
|
|
2540
|
+
```python
|
|
2541
|
+
import cdk8s
|
|
2542
|
+
|
|
2543
|
+
cdk8s.Schedule.expression(
|
|
2544
|
+
expression: str
|
|
2545
|
+
)
|
|
2546
|
+
```
|
|
2547
|
+
|
|
2548
|
+
###### `expression`<sup>Required</sup> <a name="cdk8s.Schedule.parameter.expression"></a>
|
|
2549
|
+
|
|
2550
|
+
- *Type:* `str`
|
|
2551
|
+
|
|
2552
|
+
The expression to use.
|
|
2553
|
+
|
|
2554
|
+
Must be in a format of 'value unit'
|
|
2555
|
+
|
|
2556
|
+
---
|
|
2557
|
+
|
|
2558
|
+
##### `rate` <a name="cdk8s.Schedule.rate"></a>
|
|
2559
|
+
|
|
2560
|
+
```python
|
|
2561
|
+
import cdk8s
|
|
2562
|
+
|
|
2563
|
+
cdk8s.Schedule.rate(
|
|
2564
|
+
duration: Duration
|
|
2565
|
+
)
|
|
2566
|
+
```
|
|
2567
|
+
|
|
2568
|
+
###### `duration`<sup>Required</sup> <a name="cdk8s.Schedule.parameter.duration"></a>
|
|
2569
|
+
|
|
2570
|
+
- *Type:* [`cdk8s.Duration`](#cdk8s.Duration)
|
|
2571
|
+
|
|
2572
|
+
---
|
|
2573
|
+
|
|
2574
|
+
#### Properties <a name="Properties"></a>
|
|
2575
|
+
|
|
2576
|
+
##### `expression_string`<sup>Required</sup> <a name="cdk8s.Schedule.property.expression_string"></a>
|
|
2577
|
+
|
|
2578
|
+
```python
|
|
2579
|
+
expression_string: str
|
|
2580
|
+
```
|
|
2581
|
+
|
|
2582
|
+
- *Type:* `str`
|
|
2583
|
+
|
|
2584
|
+
Retrieve the expression for this schedule.
|
|
2585
|
+
|
|
2586
|
+
---
|
|
2587
|
+
|
|
2588
|
+
|
|
2346
2589
|
### Size <a name="cdk8s.Size"></a>
|
|
2347
2590
|
|
|
2348
2591
|
Represents the amount of digital storage.
|
package/docs/typescript.md
CHANGED
|
@@ -769,6 +769,99 @@ This namespace will only apply to objects that don't have a
|
|
|
769
769
|
|
|
770
770
|
---
|
|
771
771
|
|
|
772
|
+
### CronOptions <a name="cdk8s.CronOptions"></a>
|
|
773
|
+
|
|
774
|
+
Options to configure a cron expression.
|
|
775
|
+
|
|
776
|
+
All fields are strings so you can use complex expressions. Absence of
|
|
777
|
+
a field implies '*' or '?', whichever one is appropriate.
|
|
778
|
+
|
|
779
|
+
#### Initializer <a name="[object Object].Initializer"></a>
|
|
780
|
+
|
|
781
|
+
```typescript
|
|
782
|
+
import { CronOptions } from 'cdk8s'
|
|
783
|
+
|
|
784
|
+
const cronOptions: CronOptions = { ... }
|
|
785
|
+
```
|
|
786
|
+
|
|
787
|
+
##### `day`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.day"></a>
|
|
788
|
+
|
|
789
|
+
```typescript
|
|
790
|
+
public readonly day: string;
|
|
791
|
+
```
|
|
792
|
+
|
|
793
|
+
- *Type:* `string`
|
|
794
|
+
- *Default:* Every day of the month
|
|
795
|
+
|
|
796
|
+
The day of the month to run this rule at.
|
|
797
|
+
|
|
798
|
+
---
|
|
799
|
+
|
|
800
|
+
##### `hour`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.hour"></a>
|
|
801
|
+
|
|
802
|
+
```typescript
|
|
803
|
+
public readonly hour: string;
|
|
804
|
+
```
|
|
805
|
+
|
|
806
|
+
- *Type:* `string`
|
|
807
|
+
- *Default:* Every hour
|
|
808
|
+
|
|
809
|
+
The hour to run this rule at.
|
|
810
|
+
|
|
811
|
+
---
|
|
812
|
+
|
|
813
|
+
##### `minute`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.minute"></a>
|
|
814
|
+
|
|
815
|
+
```typescript
|
|
816
|
+
public readonly minute: string;
|
|
817
|
+
```
|
|
818
|
+
|
|
819
|
+
- *Type:* `string`
|
|
820
|
+
- *Default:* Every minute
|
|
821
|
+
|
|
822
|
+
The minute to run this rule at.
|
|
823
|
+
|
|
824
|
+
---
|
|
825
|
+
|
|
826
|
+
##### `month`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.month"></a>
|
|
827
|
+
|
|
828
|
+
```typescript
|
|
829
|
+
public readonly month: string;
|
|
830
|
+
```
|
|
831
|
+
|
|
832
|
+
- *Type:* `string`
|
|
833
|
+
- *Default:* Every month
|
|
834
|
+
|
|
835
|
+
The month to run this rule at.
|
|
836
|
+
|
|
837
|
+
---
|
|
838
|
+
|
|
839
|
+
##### `weekDay`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.weekDay"></a>
|
|
840
|
+
|
|
841
|
+
```typescript
|
|
842
|
+
public readonly weekDay: string;
|
|
843
|
+
```
|
|
844
|
+
|
|
845
|
+
- *Type:* `string`
|
|
846
|
+
- *Default:* Any day of the week
|
|
847
|
+
|
|
848
|
+
The day of the week to run this rule at.
|
|
849
|
+
|
|
850
|
+
---
|
|
851
|
+
|
|
852
|
+
##### `year`<sup>Optional</sup> <a name="cdk8s.CronOptions.property.year"></a>
|
|
853
|
+
|
|
854
|
+
```typescript
|
|
855
|
+
public readonly year: string;
|
|
856
|
+
```
|
|
857
|
+
|
|
858
|
+
- *Type:* `string`
|
|
859
|
+
- *Default:* Every year
|
|
860
|
+
|
|
861
|
+
The year to run this rule at.
|
|
862
|
+
|
|
863
|
+
---
|
|
864
|
+
|
|
772
865
|
### GroupVersionKind <a name="cdk8s.GroupVersionKind"></a>
|
|
773
866
|
|
|
774
867
|
#### Initializer <a name="[object Object].Initializer"></a>
|
|
@@ -1506,6 +1599,12 @@ public toSeconds(opts?: TimeConversionOptions)
|
|
|
1506
1599
|
|
|
1507
1600
|
---
|
|
1508
1601
|
|
|
1602
|
+
##### `unitLabel` <a name="cdk8s.Duration.unitLabel"></a>
|
|
1603
|
+
|
|
1604
|
+
```typescript
|
|
1605
|
+
public unitLabel()
|
|
1606
|
+
```
|
|
1607
|
+
|
|
1509
1608
|
#### Static Functions <a name="Static Functions"></a>
|
|
1510
1609
|
|
|
1511
1610
|
##### `days` <a name="cdk8s.Duration.days"></a>
|
|
@@ -1844,6 +1943,84 @@ Name options.
|
|
|
1844
1943
|
|
|
1845
1944
|
|
|
1846
1945
|
|
|
1946
|
+
### Schedule <a name="cdk8s.Schedule"></a>
|
|
1947
|
+
|
|
1948
|
+
Represents a schedule.
|
|
1949
|
+
|
|
1950
|
+
Note that rates cannot be defined in fractions of minutes.
|
|
1951
|
+
|
|
1952
|
+
#### Initializers <a name="cdk8s.Schedule.Initializer"></a>
|
|
1953
|
+
|
|
1954
|
+
```typescript
|
|
1955
|
+
import { Schedule } from 'cdk8s'
|
|
1956
|
+
|
|
1957
|
+
new Schedule()
|
|
1958
|
+
```
|
|
1959
|
+
|
|
1960
|
+
|
|
1961
|
+
#### Static Functions <a name="Static Functions"></a>
|
|
1962
|
+
|
|
1963
|
+
##### `cron` <a name="cdk8s.Schedule.cron"></a>
|
|
1964
|
+
|
|
1965
|
+
```typescript
|
|
1966
|
+
import { Schedule } from 'cdk8s'
|
|
1967
|
+
|
|
1968
|
+
Schedule.cron(options: CronOptions)
|
|
1969
|
+
```
|
|
1970
|
+
|
|
1971
|
+
###### `options`<sup>Required</sup> <a name="cdk8s.Schedule.parameter.options"></a>
|
|
1972
|
+
|
|
1973
|
+
- *Type:* [`cdk8s.CronOptions`](#cdk8s.CronOptions)
|
|
1974
|
+
|
|
1975
|
+
---
|
|
1976
|
+
|
|
1977
|
+
##### `expression` <a name="cdk8s.Schedule.expression"></a>
|
|
1978
|
+
|
|
1979
|
+
```typescript
|
|
1980
|
+
import { Schedule } from 'cdk8s'
|
|
1981
|
+
|
|
1982
|
+
Schedule.expression(expression: string)
|
|
1983
|
+
```
|
|
1984
|
+
|
|
1985
|
+
###### `expression`<sup>Required</sup> <a name="cdk8s.Schedule.parameter.expression"></a>
|
|
1986
|
+
|
|
1987
|
+
- *Type:* `string`
|
|
1988
|
+
|
|
1989
|
+
The expression to use.
|
|
1990
|
+
|
|
1991
|
+
Must be in a format of 'value unit'
|
|
1992
|
+
|
|
1993
|
+
---
|
|
1994
|
+
|
|
1995
|
+
##### `rate` <a name="cdk8s.Schedule.rate"></a>
|
|
1996
|
+
|
|
1997
|
+
```typescript
|
|
1998
|
+
import { Schedule } from 'cdk8s'
|
|
1999
|
+
|
|
2000
|
+
Schedule.rate(duration: Duration)
|
|
2001
|
+
```
|
|
2002
|
+
|
|
2003
|
+
###### `duration`<sup>Required</sup> <a name="cdk8s.Schedule.parameter.duration"></a>
|
|
2004
|
+
|
|
2005
|
+
- *Type:* [`cdk8s.Duration`](#cdk8s.Duration)
|
|
2006
|
+
|
|
2007
|
+
---
|
|
2008
|
+
|
|
2009
|
+
#### Properties <a name="Properties"></a>
|
|
2010
|
+
|
|
2011
|
+
##### `expressionString`<sup>Required</sup> <a name="cdk8s.Schedule.property.expressionString"></a>
|
|
2012
|
+
|
|
2013
|
+
```typescript
|
|
2014
|
+
public readonly expressionString: string;
|
|
2015
|
+
```
|
|
2016
|
+
|
|
2017
|
+
- *Type:* `string`
|
|
2018
|
+
|
|
2019
|
+
Retrieve the expression for this schedule.
|
|
2020
|
+
|
|
2021
|
+
---
|
|
2022
|
+
|
|
2023
|
+
|
|
1847
2024
|
### Size <a name="cdk8s.Size"></a>
|
|
1848
2025
|
|
|
1849
2026
|
Represents the amount of digital storage.
|
package/lib/api-object.js
CHANGED
|
@@ -106,7 +106,7 @@ class ApiObject extends constructs_1.Construct {
|
|
|
106
106
|
}
|
|
107
107
|
exports.ApiObject = ApiObject;
|
|
108
108
|
_a = JSII_RTTI_SYMBOL_1;
|
|
109
|
-
ApiObject[_a] = { fqn: "cdk8s.ApiObject", version: "2.
|
|
109
|
+
ApiObject[_a] = { fqn: "cdk8s.ApiObject", version: "2.4.0" };
|
|
110
110
|
function parseApiGroup(apiVersion) {
|
|
111
111
|
const v = apiVersion.split('/');
|
|
112
112
|
// no group means "core"
|
package/lib/app.js
CHANGED
|
@@ -159,7 +159,7 @@ class App extends constructs_1.Construct {
|
|
|
159
159
|
}
|
|
160
160
|
exports.App = App;
|
|
161
161
|
_a = JSII_RTTI_SYMBOL_1;
|
|
162
|
-
App[_a] = { fqn: "cdk8s.App", version: "2.
|
|
162
|
+
App[_a] = { fqn: "cdk8s.App", version: "2.4.0" };
|
|
163
163
|
function validate(app) {
|
|
164
164
|
const errors = [];
|
|
165
165
|
for (const child of app.node.findAll()) {
|
package/lib/chart.js
CHANGED
|
@@ -86,5 +86,5 @@ class Chart extends constructs_1.Construct {
|
|
|
86
86
|
}
|
|
87
87
|
exports.Chart = Chart;
|
|
88
88
|
_a = JSII_RTTI_SYMBOL_1;
|
|
89
|
-
Chart[_a] = { fqn: "cdk8s.Chart", version: "2.
|
|
89
|
+
Chart[_a] = { fqn: "cdk8s.Chart", version: "2.4.0" };
|
|
90
90
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwyQ0FBeUQ7QUFFekQsK0JBQTRCO0FBQzVCLG1DQUFnQztBQUVoQyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0FBb0IvQyxNQUFhLEtBQU0sU0FBUSxzQkFBUztJQXFDbEMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxRQUFvQixFQUFHO1FBQy9ELEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUM7UUFFbEMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsWUFBWSxFQUFFLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQTFDRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFNO1FBQzFCLE9BQU8sQ0FBQyxLQUFLLElBQUksSUFBSSxPQUFNLENBQUMsQ0FBQyxDQUFDLEtBQUssUUFBUSxJQUFJLFlBQVksSUFBSSxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUVEOzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBYTtRQUM1QixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDcEIsT0FBTyxDQUFDLENBQUM7U0FDVjtRQUVELE1BQU0sTUFBTSxHQUFHLGlCQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQWtCLENBQUM7UUFDN0MsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNYLE1BQU0sSUFBSSxLQUFLLENBQUMscURBQXFELENBQUMsQ0FBQztTQUN4RTtRQUVELE9BQU8sS0FBSyxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBb0JEOzs7O09BSUc7SUFDSCxJQUFXLE1BQU07UUFDZixPQUFPLEVBQUUsR0FBRyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O09BbUJHO0lBQ0ksa0JBQWtCLENBQUMsU0FBb0I7UUFDNUMsT0FBTyxhQUFLLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLGFBQWEsQ0FBQyxHQUFHLFlBQTBCO1FBQ2hELGlCQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLGFBQWEsQ0FBQyxHQUFHLFlBQVksQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRDs7O09BR0c7SUFDSSxNQUFNO1FBQ1gsT0FBTyxTQUFHLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9CLENBQUM7O0FBOUZILHNCQStGQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdCwgTm9kZSwgSUNvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQXBpT2JqZWN0IH0gZnJvbSAnLi9hcGktb2JqZWN0JztcbmltcG9ydCB7IEFwcCB9IGZyb20gJy4vYXBwJztcbmltcG9ydCB7IE5hbWVzIH0gZnJvbSAnLi9uYW1lcyc7XG5cbmNvbnN0IENIQVJUX1NZTUJPTCA9IFN5bWJvbC5mb3IoJ2NkazhzLkNoYXJ0Jyk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhcnRQcm9wcyB7XG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBuYW1lc3BhY2UgZm9yIGFsbCBvYmplY3RzIGRlZmluZWQgaW4gdGhpcyBjaGFydCAoZGlyZWN0bHkgb3JcbiAgICogaW5kaXJlY3RseSkuIFRoaXMgbmFtZXNwYWNlIHdpbGwgb25seSBhcHBseSB0byBvYmplY3RzIHRoYXQgZG9uJ3QgaGF2ZSBhXG4gICAqIGBuYW1lc3BhY2VgIGV4cGxpY2l0bHkgZGVmaW5lZCBmb3IgdGhlbS5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBuYW1lc3BhY2UgaXMgc3ludGhlc2l6ZWQgKHVzdWFsbHkgdGhpcyBpbXBsaWVzIFwiZGVmYXVsdFwiKVxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZXNwYWNlPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBMYWJlbHMgdG8gYXBwbHkgdG8gYWxsIHJlc291cmNlcyBpbiB0aGlzIGNoYXJ0LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGNvbW1vbiBsYWJlbHNcbiAgICovXG4gIHJlYWRvbmx5IGxhYmVscz86IHsgW25hbWU6IHN0cmluZ106IHN0cmluZyB9O1xufVxuXG5leHBvcnQgY2xhc3MgQ2hhcnQgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAvKipcbiAgICogUmV0dXJuIHdoZXRoZXIgdGhlIGdpdmVuIG9iamVjdCBpcyBhIENoYXJ0LlxuICAgKlxuICAgKiBXZSBkbyBhdHRyaWJ1dGUgZGV0ZWN0aW9uIHNpbmNlIHdlIGNhbid0IHJlbGlhYmx5IHVzZSAnaW5zdGFuY2VvZicuXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGlzQ2hhcnQoeDogYW55KTogeCBpcyBDaGFydCB7XG4gICAgcmV0dXJuIHggIT09IG51bGwgJiYgdHlwZW9mKHgpID09PSAnb2JqZWN0JyAmJiBDSEFSVF9TWU1CT0wgaW4geDtcbiAgfVxuXG4gIC8qKlxuICAgKiBGaW5kcyB0aGUgY2hhcnQgaW4gd2hpY2ggYSBub2RlIGlzIGRlZmluZWQuXG4gICAqIEBwYXJhbSBjIGEgY29uc3RydWN0IG5vZGVcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgb2YoYzogSUNvbnN0cnVjdCk6IENoYXJ0IHtcbiAgICBpZiAoQ2hhcnQuaXNDaGFydChjKSkge1xuICAgICAgcmV0dXJuIGM7XG4gICAgfVxuXG4gICAgY29uc3QgcGFyZW50ID0gTm9kZS5vZihjKS5zY29wZSBhcyBDb25zdHJ1Y3Q7XG4gICAgaWYgKCFwYXJlbnQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignY2Fubm90IGZpbmQgYSBwYXJlbnQgY2hhcnQgKGRpcmVjdGx5IG9yIGluZGlyZWN0bHkpJyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIENoYXJ0Lm9mKHBhcmVudCk7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGRlZmF1bHQgbmFtZXNwYWNlIGZvciBhbGwgb2JqZWN0cyBpbiB0aGlzIGNoYXJ0LlxuICAgKi9cbiAgcHVibGljIHJlYWRvbmx5IG5hbWVzcGFjZT86IHN0cmluZztcblxuICAvKipcbiAgICogQ2hhcnQtbGV2ZWwgbGFiZWxzLlxuICAgKi9cbiAgcHJpdmF0ZSByZWFkb25seSBfbGFiZWxzPzogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIH07XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IENoYXJ0UHJvcHMgPSB7IH0pIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuICAgIHRoaXMubmFtZXNwYWNlID0gcHJvcHMubmFtZXNwYWNlO1xuICAgIHRoaXMuX2xhYmVscyA9IHByb3BzLmxhYmVscyA/PyB7fTtcblxuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eSh0aGlzLCBDSEFSVF9TWU1CT0wsIHsgdmFsdWU6IHRydWUgfSk7XG4gIH1cblxuICAvKipcbiAgICogTGFiZWxzIGFwcGxpZWQgdG8gYWxsIHJlc291cmNlcyBpbiB0aGlzIGNoYXJ0LlxuICAgKlxuICAgKiBUaGlzIGlzIGFuIGltbXV0YWJsZSBjb3B5LlxuICAgKi9cbiAgcHVibGljIGdldCBsYWJlbHMoKTogeyBbbmFtZTogc3RyaW5nXTogc3RyaW5nIH0ge1xuICAgIHJldHVybiB7IC4uLnRoaXMuX2xhYmVscyB9O1xuICB9XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlcyBhIGFwcC11bmlxdWUgbmFtZSBmb3IgYW4gb2JqZWN0IGdpdmVuIGl0J3MgY29uc3RydWN0IG5vZGUgcGF0aC5cbiAgICpcbiAgICogRGlmZmVyZW50IHJlc291cmNlIHR5cGVzIG1heSBoYXZlIGRpZmZlcmVudCBjb25zdHJhaW50cyBvbiBuYW1lc1xuICAgKiAoYG1ldGFkYXRhLm5hbWVgKS4gVGhlIHByZXZpb3VzIHZlcnNpb24gb2YgdGhlIG5hbWUgZ2VuZXJhdG9yIHdhc1xuICAgKiBjb21wYXRpYmxlIHdpdGggRE5TX1NVQkRPTUFJTiBidXQgbm90IHdpdGggRE5TX0xBQkVMLlxuICAgKlxuICAgKiBGb3IgZXhhbXBsZSwgYERlcGxveW1lbnRgIG5hbWVzIG11c3QgY29tcGx5IHdpdGggRE5TX1NVQkRPTUFJTiB3aGlsZVxuICAgKiBgU2VydmljZWAgbmFtZXMgbXVzdCBjb21wbHkgd2l0aCBETlNfTEFCRUwuXG4gICAqXG4gICAqIFNpbmNlIHRoZXJlIGlzIG5vIGZvcm1hbCBzcGVjaWZpY2F0aW9uIGZvciB0aGlzLCB0aGUgZGVmYXVsdCBuYW1lXG4gICAqIGdlbmVyYXRpb24gc2NoZW1lIGZvciBrdWJlcm5ldGVzIG9iamVjdHMgaW4gY2RrOHMgd2FzIGNoYW5nZWQgdG8gRE5TX0xBQkVMLFxuICAgKiBzaW5jZSBpdOKAmXMgdGhlIGNvbW1vbiBkZW5vbWluYXRvciBmb3IgYWxsIGt1YmVybmV0ZXMgcmVzb3VyY2VzXG4gICAqIChzdXBwb3NlZGx5KS5cbiAgICpcbiAgICogWW91IGNhbiBvdmVycmlkZSB0aGlzIG1ldGhvZCBpZiB5b3Ugd2lzaCB0byBjdXN0b21pemUgb2JqZWN0IG5hbWVzIGF0IHRoZVxuICAgKiBjaGFydCBsZXZlbC5cbiAgICpcbiAgICogQHBhcmFtIGFwaU9iamVjdCBUaGUgQVBJIG9iamVjdCB0byBnZW5lcmF0ZSBhIG5hbWUgZm9yLlxuICAgKi9cbiAgcHVibGljIGdlbmVyYXRlT2JqZWN0TmFtZShhcGlPYmplY3Q6IEFwaU9iamVjdCkge1xuICAgIHJldHVybiBOYW1lcy50b0Ruc0xhYmVsKGFwaU9iamVjdCk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlIGEgZGVwZW5kZW5jeSBiZXR3ZWVuIHRoaXMgQ2hhcnQgYW5kIG90aGVyIGNvbnN0cnVjdHMuXG4gICAqIFRoZXNlIGNhbiBiZSBvdGhlciBBcGlPYmplY3RzLCBDaGFydHMsIG9yIGN1c3RvbS5cbiAgICpcbiAgICogQHBhcmFtIGRlcGVuZGVuY2llcyB0aGUgZGVwZW5kZW5jaWVzIHRvIGFkZC5cbiAgICovXG4gIHB1YmxpYyBhZGREZXBlbmRlbmN5KC4uLmRlcGVuZGVuY2llczogSUNvbnN0cnVjdFtdKSB7XG4gICAgTm9kZS5vZih0aGlzKS5hZGREZXBlbmRlbmN5KC4uLmRlcGVuZGVuY2llcyk7XG4gIH1cblxuICAvKipcbiAgICogUmVuZGVycyB0aGlzIGNoYXJ0IHRvIGEgc2V0IG9mIEt1YmVybmV0ZXMgSlNPTiByZXNvdXJjZXMuXG4gICAqIEByZXR1cm5zIGFycmF5IG9mIHJlc291cmNlIG1hbmlmZXN0c1xuICAgKi9cbiAgcHVibGljIHRvSnNvbigpOiBhbnlbXSB7XG4gICAgcmV0dXJuIEFwcC5fc3ludGhDaGFydCh0aGlzKTtcbiAgfVxufVxuXG4iXX0=
|
package/lib/dependency.js
CHANGED
|
@@ -76,7 +76,7 @@ class DependencyGraph {
|
|
|
76
76
|
}
|
|
77
77
|
exports.DependencyGraph = DependencyGraph;
|
|
78
78
|
_a = JSII_RTTI_SYMBOL_1;
|
|
79
|
-
DependencyGraph[_a] = { fqn: "cdk8s.DependencyGraph", version: "2.
|
|
79
|
+
DependencyGraph[_a] = { fqn: "cdk8s.DependencyGraph", version: "2.4.0" };
|
|
80
80
|
/**
|
|
81
81
|
* Represents a vertex in the graph.
|
|
82
82
|
*
|
|
@@ -169,5 +169,5 @@ class DependencyVertex {
|
|
|
169
169
|
}
|
|
170
170
|
exports.DependencyVertex = DependencyVertex;
|
|
171
171
|
_b = JSII_RTTI_SYMBOL_1;
|
|
172
|
-
DependencyVertex[_b] = { fqn: "cdk8s.DependencyVertex", version: "2.
|
|
172
|
+
DependencyVertex[_b] = { fqn: "cdk8s.DependencyVertex", version: "2.4.0" };
|
|
173
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
package/lib/duration.js
CHANGED
|
@@ -179,6 +179,12 @@ class Duration {
|
|
|
179
179
|
return `${amount} ${unit.label}`;
|
|
180
180
|
}
|
|
181
181
|
}
|
|
182
|
+
/**
|
|
183
|
+
* Return unit of Duration
|
|
184
|
+
*/
|
|
185
|
+
unitLabel() {
|
|
186
|
+
return this.unit.toString();
|
|
187
|
+
}
|
|
182
188
|
fractionDuration(symbol, modulus, next) {
|
|
183
189
|
if (this.amount < modulus) {
|
|
184
190
|
return `${this.amount}${symbol}`;
|
|
@@ -192,7 +198,7 @@ class Duration {
|
|
|
192
198
|
}
|
|
193
199
|
exports.Duration = Duration;
|
|
194
200
|
_a = JSII_RTTI_SYMBOL_1;
|
|
195
|
-
Duration[_a] = { fqn: "cdk8s.Duration", version: "2.
|
|
201
|
+
Duration[_a] = { fqn: "cdk8s.Duration", version: "2.4.0" };
|
|
196
202
|
class TimeUnit {
|
|
197
203
|
constructor(label, inMillis) {
|
|
198
204
|
this.label = label;
|
|
@@ -212,6 +218,9 @@ TimeUnit.Hours = new TimeUnit('hours', 3600000);
|
|
|
212
218
|
TimeUnit.Days = new TimeUnit('days', 86400000);
|
|
213
219
|
function convert(amount, fromUnit, toUnit, { integral = true }) {
|
|
214
220
|
if (fromUnit.inMillis === toUnit.inMillis) {
|
|
221
|
+
if (integral && !Number.isInteger(amount)) {
|
|
222
|
+
throw new Error(`${amount} must be a whole number of ${toUnit}.`);
|
|
223
|
+
}
|
|
215
224
|
return amount;
|
|
216
225
|
}
|
|
217
226
|
const multiplier = fromUnit.inMillis / toUnit.inMillis;
|
|
@@ -221,4 +230,4 @@ function convert(amount, fromUnit, toUnit, { integral = true }) {
|
|
|
221
230
|
}
|
|
222
231
|
return value;
|
|
223
232
|
}
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"duration.js","sourceRoot":"","sources":["../src/duration.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;GAMG;AACH,MAAa,QAAQ;IAmFnB,YAAoB,MAAc,EAAE,IAAc;QAChD,IAAI,MAAM,GAAG,CAAC,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,kDAAkD,MAAM,EAAE,CAAC,CAAC;SAC7E;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAzFD;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAC,MAAc;QACjC,OAAO,IAAI,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,YAAY,CAAC,CAAC;IACrD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,OAAO,CAAC,MAAc;QAClC,OAAO,IAAI,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,OAAO,CAAC,MAAc;QAClC,OAAO,IAAI,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,KAAK,CAAC,MAAc;QAChC,OAAO,IAAI,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,IAAI,CAAC,MAAc;QAC/B,OAAO,IAAI,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,KAAK,CAAC,QAAgB;QAClC,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,kDAAkD,CAAC,CAAC;QACnF,IAAI,CAAC,OAAO,EAAE;YACZ,MAAM,IAAI,KAAK,CAAC,6BAA6B,QAAQ,EAAE,CAAC,CAAC;SAC1D;QACD,MAAM,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC;QAClD,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,EAAE;YAC3C,MAAM,IAAI,KAAK,CAAC,6BAA6B,QAAQ,EAAE,CAAC,CAAC;SAC1D;QACD,OAAO,QAAQ,CAAC,MAAM,CACpB,MAAM,CAAC,OAAO,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,QAAQ;cACzC,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC;cAC7C,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC;cACzC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAC1C,CAAC;QAEF,SAAS,MAAM,CAAC,GAAW;YACzB,IAAI,CAAC,GAAG,EAAE;gBAAE,OAAO,CAAC,CAAC;aAAE;YACvB,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IAcD;;;;OAIG;IACI,cAAc,CAAC,OAA8B,EAAE;QACpD,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;IACtE,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,OAA8B,EAAE;QAC/C,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACjE,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,OAA8B,EAAE;QAC/C,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACjE,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,OAA8B,EAAE;QAC7C,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC/D,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,OAA8B,EAAE;QAC5C,OAAO,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;OAKG;IACI,WAAW;QAChB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YAAE,OAAO,MAAM,CAAC;SAAE;QACzC,QAAQ,IAAI,CAAC,IAAI,EAAE;YACjB,KAAK,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YACtF,KAAK,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YACpF,KAAK,QAAQ,CAAC,KAAK,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YACjF,KAAK,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC;YAC/C;gBACE,MAAM,IAAI,KAAK,CAAC,yBAAyB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;SACzD;IACH,CAAC;IAED;;OAEG;IACI,aAAa;QAClB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YAAE,OAAO,OAAO,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;SAAE;QAExD,IAAI,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,YAAY,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;QACzF,MAAM,KAAK,GAAG,IAAI,KAAK,EAAU,CAAC;QAElC,KAAK,MAAM,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE;YACtG,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC,YAAY,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YACjG,IAAI,UAAU,GAAG,CAAC,EAAE;gBAClB,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC;gBACtC,MAAM,IAAI,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC;aACtC;SACF;QAED,sBAAsB;QACtB,IAAI,MAAM,GAAG,CAAC,EAAE;YACd,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;SACpD;QAED,wDAAwD;QACxD,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEnC,SAAS,OAAO,CAAC,MAAc,EAAE,IAAc;YAC7C,IAAI,MAAM,KAAK,CAAC,EAAE;gBAChB,+BAA+B;gBAC/B,OAAO,GAAG,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC;aACtE;YACD,OAAO,GAAG,MAAM,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACnC,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,MAAc,EAAE,OAAe,EAAE,IAAkC;QAC1F,IAAI,IAAI,CAAC,MAAM,GAAG,OAAO,EAAE;YACzB,OAAO,GAAG,IAAI,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC;SAClC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,GAAG,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAClF,OAAO,SAAS,GAAG,CAAC;YAClB,CAAC,CAAC,GAAG,QAAQ,GAAG,SAAS,GAAG,MAAM,EAAE;YACpC,CAAC,CAAC,QAAQ,CAAC;IACf,CAAC;;AAtMH,4BAuMC;;;AAeD,MAAM,QAAQ;IAOZ,YAAoC,KAAa,EAAkB,QAAgB;QAA/C,UAAK,GAAL,KAAK,CAAQ;QAAkB,aAAQ,GAAR,QAAQ,CAAQ;QACjF,kFAAkF;QAClF,wDAAwD;QACxD,8DAA8D;IAChE,CAAC;IAEM,QAAQ;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;AAdsB,qBAAY,GAAG,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;AACzC,gBAAO,GAAG,IAAI,QAAQ,CAAC,SAAS,EAAE,IAAK,CAAC,CAAC;AACzC,gBAAO,GAAG,IAAI,QAAQ,CAAC,SAAS,EAAE,KAAM,CAAC,CAAC;AAC1C,cAAK,GAAG,IAAI,QAAQ,CAAC,OAAO,EAAE,OAAS,CAAC,CAAC;AACzC,aAAI,GAAG,IAAI,QAAQ,CAAC,MAAM,EAAE,QAAU,CAAC,CAAC;AAajE,SAAS,OAAO,CAAC,MAAc,EAAE,QAAkB,EAAE,MAAgB,EAAE,EAAE,QAAQ,GAAG,IAAI,EAAyB;IAC/G,IAAI,QAAQ,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,EAAE;QAAE,OAAO,MAAM,CAAC;KAAE;IAC7D,MAAM,UAAU,GAAG,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;IAEvD,MAAM,KAAK,GAAG,MAAM,GAAG,UAAU,CAAC;IAClC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,QAAQ,EAAE;QACxC,MAAM,IAAI,KAAK,CAAC,IAAI,MAAM,IAAI,QAAQ,gDAAgD,MAAM,GAAG,CAAC,CAAC;KAClG;IACD,OAAO,KAAK,CAAC;AACf,CAAC","sourcesContent":["/**\n * Represents a length of time.\n *\n * The amount can be specified either as a literal value (e.g: `10`) which\n * cannot be negative.\n *\n */\nexport class Duration {\n  /**\n   * Create a Duration representing an amount of milliseconds\n   *\n   * @param amount the amount of Milliseconds the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` ms.\n   */\n  public static millis(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Milliseconds);\n  }\n\n  /**\n   * Create a Duration representing an amount of seconds\n   *\n   * @param amount the amount of Seconds the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Seconds.\n   */\n  public static seconds(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Seconds);\n  }\n\n  /**\n   * Create a Duration representing an amount of minutes\n   *\n   * @param amount the amount of Minutes the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Minutes.\n   */\n  public static minutes(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Minutes);\n  }\n\n  /**\n   * Create a Duration representing an amount of hours\n   *\n   * @param amount the amount of Hours the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Hours.\n   */\n  public static hours(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Hours);\n  }\n\n  /**\n   * Create a Duration representing an amount of days\n   *\n   * @param amount the amount of Days the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Days.\n   */\n  public static days(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Days);\n  }\n\n  /**\n   * Parse a period formatted according to the ISO 8601 standard\n   *\n   * @see https://www.iso.org/fr/standard/70907.html\n   * @param duration an ISO-formtted duration to be parsed.\n   * @returns the parsed `Duration`.\n   */\n  public static parse(duration: string): Duration {\n    const matches = duration.match(/^PT(?:(\\d+)D)?(?:(\\d+)H)?(?:(\\d+)M)?(?:(\\d+)S)?$/);\n    if (!matches) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    const [, days, hours, minutes, seconds] = matches;\n    if (!days && !hours && !minutes && !seconds) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    return Duration.millis(\n      _toInt(seconds) * TimeUnit.Seconds.inMillis\n      + (_toInt(minutes) * TimeUnit.Minutes.inMillis)\n      + (_toInt(hours) * TimeUnit.Hours.inMillis)\n      + (_toInt(days) * TimeUnit.Days.inMillis),\n    );\n\n    function _toInt(str: string): number {\n      if (!str) { return 0; }\n      return Number(str);\n    }\n  }\n\n  private readonly amount: number;\n  private readonly unit: TimeUnit;\n\n  private constructor(amount: number, unit: TimeUnit) {\n    if (amount < 0) {\n      throw new Error(`Duration amounts cannot be negative. Received: ${amount}`);\n    }\n\n    this.amount = amount;\n    this.unit = unit;\n  }\n\n  /**\n   * Return the total number of milliseconds in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Milliseconds.\n   */\n  public toMilliseconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Milliseconds, opts);\n  }\n\n  /**\n   * Return the total number of seconds in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Seconds.\n   */\n  public toSeconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Seconds, opts);\n  }\n\n  /**\n   * Return the total number of minutes in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Minutes.\n   */\n  public toMinutes(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Minutes, opts);\n  }\n\n  /**\n   * Return the total number of hours in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Hours.\n   */\n  public toHours(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Hours, opts);\n  }\n\n  /**\n   * Return the total number of days in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Days.\n   */\n  public toDays(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Days, opts);\n  }\n\n  /**\n   * Return an ISO 8601 representation of this period\n   *\n   * @returns a string starting with 'PT' describing the period\n   * @see https://www.iso.org/fr/standard/70907.html\n   */\n  public toIsoString(): string {\n    if (this.amount === 0) { return 'PT0S'; }\n    switch (this.unit) {\n      case TimeUnit.Seconds: return `PT${this.fractionDuration('S', 60, Duration.minutes)}`;\n      case TimeUnit.Minutes: return `PT${this.fractionDuration('M', 60, Duration.hours)}`;\n      case TimeUnit.Hours: return `PT${this.fractionDuration('H', 24, Duration.days)}`;\n      case TimeUnit.Days: return `PT${this.amount}D`;\n      default:\n        throw new Error(`Unexpected time unit: ${this.unit}`);\n    }\n  }\n\n  /**\n   * Turn this duration into a human-readable string\n   */\n  public toHumanString(): string {\n    if (this.amount === 0) { return fmtUnit(0, this.unit); }\n\n    let millis = convert(this.amount, this.unit, TimeUnit.Milliseconds, { integral: false });\n    const parts = new Array<string>();\n\n    for (const unit of [TimeUnit.Days, TimeUnit.Hours, TimeUnit.Hours, TimeUnit.Minutes, TimeUnit.Seconds]) {\n      const wholeCount = Math.floor(convert(millis, TimeUnit.Milliseconds, unit, { integral: false }));\n      if (wholeCount > 0) {\n        parts.push(fmtUnit(wholeCount, unit));\n        millis -= wholeCount * unit.inMillis;\n      }\n    }\n\n    // Remainder in millis\n    if (millis > 0) {\n      parts.push(fmtUnit(millis, TimeUnit.Milliseconds));\n    }\n\n    // 2 significant parts, that's totally enough for humans\n    return parts.slice(0, 2).join(' ');\n\n    function fmtUnit(amount: number, unit: TimeUnit) {\n      if (amount === 1) {\n        // All of the labels end in 's'\n        return `${amount} ${unit.label.substring(0, unit.label.length - 1)}`;\n      }\n      return `${amount} ${unit.label}`;\n    }\n  }\n\n  private fractionDuration(symbol: string, modulus: number, next: (amount: number) => Duration): string {\n    if (this.amount < modulus) {\n      return `${this.amount}${symbol}`;\n    }\n    const remainder = this.amount % modulus;\n    const quotient = next((this.amount - remainder) / modulus).toIsoString().slice(2);\n    return remainder > 0\n      ? `${quotient}${remainder}${symbol}`\n      : quotient;\n  }\n}\n\n/**\n * Options for how to convert time to a different unit.\n */\nexport interface TimeConversionOptions {\n  /**\n   * If `true`, conversions into a larger time unit (e.g. `Seconds` to `Minutes`) will fail if the result is not an\n   * integer.\n   *\n   * @default true\n   */\n  readonly integral?: boolean;\n}\n\nclass TimeUnit {\n  public static readonly Milliseconds = new TimeUnit('millis', 1);\n  public static readonly Seconds = new TimeUnit('seconds', 1_000);\n  public static readonly Minutes = new TimeUnit('minutes', 60_000);\n  public static readonly Hours = new TimeUnit('hours', 3_600_000);\n  public static readonly Days = new TimeUnit('days', 86_400_000);\n\n  private constructor(public readonly label: string, public readonly inMillis: number) {\n    // MAX_SAFE_INTEGER is 2^53, so by representing our duration in millis (the lowest\n    // common unit) the highest duration we can represent is\n    // 2^53 / 86*10^6 ~= 104 * 10^6 days (about 100 million days).\n  }\n\n  public toString() {\n    return this.label;\n  }\n}\n\nfunction convert(amount: number, fromUnit: TimeUnit, toUnit: TimeUnit, { integral = true }: TimeConversionOptions) {\n  if (fromUnit.inMillis === toUnit.inMillis) { return amount; }\n  const multiplier = fromUnit.inMillis / toUnit.inMillis;\n\n  const value = amount * multiplier;\n  if (!Number.isInteger(value) && integral) {\n    throw new Error(`'${amount} ${fromUnit}' cannot be converted into a whole number of ${toUnit}.`);\n  }\n  return value;\n}"]}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"duration.js","sourceRoot":"","sources":["../src/duration.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Represents a length of time.\n *\n * The amount can be specified either as a literal value (e.g: `10`) which\n * cannot be negative.\n *\n */\nexport class Duration {\n  /**\n   * Create a Duration representing an amount of milliseconds\n   *\n   * @param amount the amount of Milliseconds the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` ms.\n   */\n  public static millis(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Milliseconds);\n  }\n\n  /**\n   * Create a Duration representing an amount of seconds\n   *\n   * @param amount the amount of Seconds the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Seconds.\n   */\n  public static seconds(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Seconds);\n  }\n\n  /**\n   * Create a Duration representing an amount of minutes\n   *\n   * @param amount the amount of Minutes the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Minutes.\n   */\n  public static minutes(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Minutes);\n  }\n\n  /**\n   * Create a Duration representing an amount of hours\n   *\n   * @param amount the amount of Hours the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Hours.\n   */\n  public static hours(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Hours);\n  }\n\n  /**\n   * Create a Duration representing an amount of days\n   *\n   * @param amount the amount of Days the `Duration` will represent.\n   * @returns a new `Duration` representing `amount` Days.\n   */\n  public static days(amount: number): Duration {\n    return new Duration(amount, TimeUnit.Days);\n  }\n\n  /**\n   * Parse a period formatted according to the ISO 8601 standard\n   *\n   * @see https://www.iso.org/fr/standard/70907.html\n   * @param duration an ISO-formtted duration to be parsed.\n   * @returns the parsed `Duration`.\n   */\n  public static parse(duration: string): Duration {\n    const matches = duration.match(/^PT(?:(\\d+)D)?(?:(\\d+)H)?(?:(\\d+)M)?(?:(\\d+)S)?$/);\n    if (!matches) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    const [, days, hours, minutes, seconds] = matches;\n    if (!days && !hours && !minutes && !seconds) {\n      throw new Error(`Not a valid ISO duration: ${duration}`);\n    }\n    return Duration.millis(\n      _toInt(seconds) * TimeUnit.Seconds.inMillis\n      + (_toInt(minutes) * TimeUnit.Minutes.inMillis)\n      + (_toInt(hours) * TimeUnit.Hours.inMillis)\n      + (_toInt(days) * TimeUnit.Days.inMillis),\n    );\n\n    function _toInt(str: string): number {\n      if (!str) { return 0; }\n      return Number(str);\n    }\n  }\n\n  private readonly amount: number;\n  private readonly unit: TimeUnit;\n\n  private constructor(amount: number, unit: TimeUnit) {\n    if (amount < 0) {\n      throw new Error(`Duration amounts cannot be negative. Received: ${amount}`);\n    }\n\n    this.amount = amount;\n    this.unit = unit;\n  }\n\n  /**\n   * Return the total number of milliseconds in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Milliseconds.\n   */\n  public toMilliseconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Milliseconds, opts);\n  }\n\n  /**\n   * Return the total number of seconds in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Seconds.\n   */\n  public toSeconds(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Seconds, opts);\n  }\n\n  /**\n   * Return the total number of minutes in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Minutes.\n   */\n  public toMinutes(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Minutes, opts);\n  }\n\n  /**\n   * Return the total number of hours in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Hours.\n   */\n  public toHours(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Hours, opts);\n  }\n\n  /**\n   * Return the total number of days in this Duration\n   *\n   * @returns the value of this `Duration` expressed in Days.\n   */\n  public toDays(opts: TimeConversionOptions = {}): number {\n    return convert(this.amount, this.unit, TimeUnit.Days, opts);\n  }\n\n  /**\n   * Return an ISO 8601 representation of this period\n   *\n   * @returns a string starting with 'PT' describing the period\n   * @see https://www.iso.org/fr/standard/70907.html\n   */\n  public toIsoString(): string {\n    if (this.amount === 0) { return 'PT0S'; }\n    switch (this.unit) {\n      case TimeUnit.Seconds: return `PT${this.fractionDuration('S', 60, Duration.minutes)}`;\n      case TimeUnit.Minutes: return `PT${this.fractionDuration('M', 60, Duration.hours)}`;\n      case TimeUnit.Hours: return `PT${this.fractionDuration('H', 24, Duration.days)}`;\n      case TimeUnit.Days: return `PT${this.amount}D`;\n      default:\n        throw new Error(`Unexpected time unit: ${this.unit}`);\n    }\n  }\n\n  /**\n   * Turn this duration into a human-readable string\n   */\n  public toHumanString(): string {\n    if (this.amount === 0) { return fmtUnit(0, this.unit); }\n\n    let millis = convert(this.amount, this.unit, TimeUnit.Milliseconds, { integral: false });\n    const parts = new Array<string>();\n\n    for (const unit of [TimeUnit.Days, TimeUnit.Hours, TimeUnit.Hours, TimeUnit.Minutes, TimeUnit.Seconds]) {\n      const wholeCount = Math.floor(convert(millis, TimeUnit.Milliseconds, unit, { integral: false }));\n      if (wholeCount > 0) {\n        parts.push(fmtUnit(wholeCount, unit));\n        millis -= wholeCount * unit.inMillis;\n      }\n    }\n\n    // Remainder in millis\n    if (millis > 0) {\n      parts.push(fmtUnit(millis, TimeUnit.Milliseconds));\n    }\n\n    // 2 significant parts, that's totally enough for humans\n    return parts.slice(0, 2).join(' ');\n\n    function fmtUnit(amount: number, unit: TimeUnit) {\n      if (amount === 1) {\n        // All of the labels end in 's'\n        return `${amount} ${unit.label.substring(0, unit.label.length - 1)}`;\n      }\n      return `${amount} ${unit.label}`;\n    }\n  }\n\n  /**\n   * Return unit of Duration\n   */\n  public unitLabel(): string {\n    return this.unit.toString();\n  }\n\n  private fractionDuration(symbol: string, modulus: number, next: (amount: number) => Duration): string {\n    if (this.amount < modulus) {\n      return `${this.amount}${symbol}`;\n    }\n    const remainder = this.amount % modulus;\n    const quotient = next((this.amount - remainder) / modulus).toIsoString().slice(2);\n    return remainder > 0\n      ? `${quotient}${remainder}${symbol}`\n      : quotient;\n  }\n}\n\n/**\n * Options for how to convert time to a different unit.\n */\nexport interface TimeConversionOptions {\n  /**\n   * If `true`, conversions into a larger time unit (e.g. `Seconds` to `Minutes`) will fail if the result is not an\n   * integer.\n   *\n   * @default true\n   */\n  readonly integral?: boolean;\n}\n\nclass TimeUnit {\n  public static readonly Milliseconds = new TimeUnit('millis', 1);\n  public static readonly Seconds = new TimeUnit('seconds', 1_000);\n  public static readonly Minutes = new TimeUnit('minutes', 60_000);\n  public static readonly Hours = new TimeUnit('hours', 3_600_000);\n  public static readonly Days = new TimeUnit('days', 86_400_000);\n\n  private constructor(public readonly label: string, public readonly inMillis: number) {\n    // MAX_SAFE_INTEGER is 2^53, so by representing our duration in millis (the lowest\n    // common unit) the highest duration we can represent is\n    // 2^53 / 86*10^6 ~= 104 * 10^6 days (about 100 million days).\n  }\n\n  public toString() {\n    return this.label;\n  }\n}\n\nfunction convert(amount: number, fromUnit: TimeUnit, toUnit: TimeUnit, { integral = true }: TimeConversionOptions) {\n  if (fromUnit.inMillis === toUnit.inMillis) {\n    if (integral && !Number.isInteger(amount)) {\n      throw new Error(`${amount} must be a whole number of ${toUnit}.`);\n    }\n    return amount;\n  }\n  const multiplier = fromUnit.inMillis / toUnit.inMillis;\n\n  const value = amount * multiplier;\n  if (!Number.isInteger(value) && integral) {\n    throw new Error(`'${amount} ${fromUnit}' cannot be converted into a whole number of ${toUnit}.`);\n  }\n  return value;\n}"]}
|