-
Notifications
You must be signed in to change notification settings - Fork 2
/
doc.go
52 lines (51 loc) · 1.96 KB
/
doc.go
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
// Copyright 2016 Rick Beton. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Package period provides functionality for periods of time using ISO-8601 conventions.
// This deals with years, months, weeks, days, hours, minutes and seconds.
//
// Because of the vagaries of calendar systems, the meaning of year lengths, month lengths
// and even day lengths depends on context. So a period is not necessarily a fixed duration
// of time in terms of seconds. The type time.Duration is measured in terms of (nano-)
// seconds. Periods can be converted to/from durations; depending on the length of period
// this may be calculated exactly or approximately.
//
// The period defined in this API is specified by ISO-8601, but that uses the term 'duration'
// instead; see https://en.wikipedia.org/wiki/ISO_8601#Durations. In Go, time.Duration and
// this period.ISOString follow terminology similar to e.g. Joda Time in that a 'duration' is
// a definite number of seconds (or fractions of a second).
//
// Example period.ISOString representations:
//
// * "P2Y" is two years;
//
// * "P6M" is six months;
//
// * "P1W" is one week (seven days);
//
// * "P4D" is four days;
//
// * "PT3H" is three hours.
//
// * "PT20M" is twenty minutes.
//
// * "PT30S" is thirty seconds.
//
// * "-PT30S" or "PT-30S" is minus thirty seconds (implies an "earlier" time).
//
// These can be combined, for example:
//
// * "P3Y11M4W1D" is 3 years, 11 months, 4 weeks and 1 day, which is nearly 4 years.
//
// * "P2DT12H" is 2 days and 12 hours.
//
// * "P1M-1D" is 1 month minus 1 day. Mixed signs are permitted but may not be widely supported elsewhere.
//
// Also, decimal fractions are supported. To comply with the standard,
// only the last non-zero component is allowed to have a fraction.
// For example
//
// * "P2.5Y" or "P2,5Y" is 2.5 years; both notations are allowed.
//
// * "PT12M7.5S" is 12 minutes and 7.5 seconds.
package period