-
Notifications
You must be signed in to change notification settings - Fork 1
/
ConvertTo-DatetimeArray.ps1
71 lines (67 loc) · 1.78 KB
/
ConvertTo-DatetimeArray.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<#
.Synopsis
Simple conversion of spans to dates
.DESCRIPTION
Takes an array of timespan objects and a datetime object and
calculates a resultant set of datetime objects based on the input.
If the Backwards switch is enabled, the conversion is negative (historical).
.EXAMPLE
1..30 | %{New-Timespan -Days $_} | ConvertTo-DatetimeArray -Date '1/1/2020'
.EXAMPLE
New-Timespan -Days 10 | ConvertTo-DatetimeArray
.INPUTS
An array of timespan objects
.OUTPUTS
An array of datetime objects
#>
function ConvertTo-DateTimeArray
{
[CmdletBinding()]
[Alias()]
[OutputType([Datetime[]])]
Param
(
# Timespan array to convert into datetime objects
[Parameter(Mandatory=$true,
ValueFromPipeline=$true,
Position=0)]
[ValidateNotNull()]
[ValidateNotNullOrEmpty()]
[timespan[]]
$Timespan,
# Date for comparison
[Parameter(Position=1)]
[ValidateNotNull()]
[ValidateNotNullOrEmpty()]
[datetime]
$Date=(Get-Date),
# Apply timespan to the given date in the past
[Parameter()]
[switch]
$Backwards
)
Begin
{
$arrTimespan = New-Object -TypeName 'System.Collections.ArrayList'
}
Process
{
foreach ($span in $Timespan){
[void]($arrTimespan.Add($span))
}
}
End
{
# Sort the incoming list
if($Backwards){$SortSplat = @{'Descending'=$true}}
$sortedTimespan = $arrTimespan | Sort-Object @SortSplat
# Recurse the set and spit out datetimes in order
foreach ($span in $sortedTimespan){
if($Backwards){
$Date - $span
}else{
$Date + $span
}
}
}
}