Report a bug
		
				If you spot a problem with this page, click here to create a Bugzilla issue.
		
			Improve this page
		
			Quickly fork, edit online, and submit a pull request for this page.
			Requires a signed-in GitHub account. This works well for small changes.
			If you'd like to make larger changes you may want to consider using
			a local clone.
		
	std.datetime.date
| Category | Functions | 
|---|---|
| Main date types | Date DateTime | 
| Other date types | Month DayOfWeek TimeOfDay | 
| Date checking | valid validTimeUnits yearIsLeapYear isTimePoint enforceValid | 
| Date conversion | daysToDayOfWeek monthsToMonth | 
| Time units | cmpTimeUnits timeStrings | 
| Other | AllowDayOverflow DateTimeException | 
License: 
Authors: 
Source std/datetime/date.d
- aliasDateTimeException= core.time.TimeException;
- Exception type used by std.datetime. It's an alias to core.time.TimeException. Either can be caught without concern about which module it came from.
- enumMonth: ubyte;
- Represents the 12 months of the Gregorian year (January is 1).Examples:writeln(Date(2018, 10, 1).month); // Month.oct writeln(DateTime(1, 1, 1).month); // Month.jan - jan
- feb
- mar
- apr
- may
- jun
- jul
- aug
- sep
- oct
- nov
- dec
 
- enumDayOfWeek: ubyte;
- Represents the 7 days of the Gregorian week (Sunday is 0).Examples:writeln(Date(2018, 10, 1).dayOfWeek); // DayOfWeek.mon writeln(DateTime(5, 5, 5).dayOfWeek); // DayOfWeek.thu - sun
- mon
- tue
- wed
- thu
- fri
- sat
 
- aliasAllowDayOverflow= std.typecons.Flag!"allowDayOverflow".Flag;
- In some date calculations, adding months or years can cause the date to fall on a day of the month which is not valid (e.g. February 29th 2001 or June 31st 2000). If overflow is allowed (as is the default), then the month will be incremented accordingly (so, February 29th 2001 would become March 1st 2001, and June 31st 2000 would become July 1st 2000). If overflow is not allowed, then the day will be adjusted to the last valid day in that month (so, February 29th 2001 would become February 28th 2001 and June 31st 2000 would become June 30th 2000).AllowDayOverflow only applies to calculations involving months or years. If set toAllowDayOverflow.no, then day overflow is not allowed. Otherwise, if set toAllowDayOverflow.yes, then day overflow is allowed.
- immutable string[]timeStrings;
- Array of the strings representing time units, starting with the smallest unit and going to the largest. It does not include "nsecs".Includes "hnsecs" (hecto-nanoseconds (100 ns)), "usecs" (microseconds), "msecs" (milliseconds), "seconds", "minutes", "hours", "days", "weeks", "months", and "years"
- structDateTime;
- Combines the std.datetime.date.Date and std.datetime.date.TimeOfDay structs to give an object which holds both the date and the time. It is optimized for calendar-based operations and has no concept of time zone. For an object which is optimized for time operations based on the system time, use std.datetime.systime.SysTime. std.datetime.systime.SysTime has a concept of time zone and has much higher precision (hnsecs).DateTimeis intended primarily for calendar-based uses rather than precise time operations.Examples:import core.time : days, seconds; auto dt = DateTime(2000, 6, 1, 10, 30, 0); writeln(dt.date); // Date(2000, 6, 1) writeln(dt.timeOfDay); // TimeOfDay(10, 30, 0) writeln(dt.dayOfYear); // 153 writeln(dt.dayOfWeek); // DayOfWeek.thu dt += 10.days + 100.seconds; writeln(dt); // DateTime(2000, 6, 11, 10, 31, 40) writeln(dt.toISOExtString()); // "2000-06-11T10:31:40" writeln(dt.toISOString()); // "20000611T103140" writeln(dt.toSimpleString()); // "2000-Jun-11 10:31:40" writeln(DateTime.fromISOExtString("2018-01-01T12:00:00")); // DateTime(2018, 1, 1, 12, 0, 0) writeln(DateTime.fromISOString("20180101T120000")); // DateTime(2018, 1, 1, 12, 0, 0) writeln(DateTime.fromSimpleString("2018-Jan-01 12:00:00")); // DateTime(2018, 1, 1, 12, 0, 0) - pure nothrow @nogc @safe this(Datedate, TimeOfDaytod= TimeOfDay.init);
- pure @safe this(intyear, intmonth, intday, inthour= 0, intminute= 0, intsecond= 0);
- Parameters:int yearThe year portion of the date. int monthThe month portion of the date (January is 1). int dayThe day portion of the date. int hourThe hour portion of the time; int minuteThe minute portion of the time; int secondThe second portion of the time; 
- const pure nothrow @nogc @safe intopCmp(DateTimerhs);
- Compares this DateTime with the given DateTime..Returns:this < rhs < 0 this == rhs 0 this > rhs > 0 
- const pure nothrow @nogc @property @safe Datedate();
- The date portion of DateTime.
- pure nothrow @nogc @property @safe voiddate(Datedate);
- The date portion of DateTime.Parameters:Date dateThe Date to set this DateTime's date portion to. 
- const pure nothrow @nogc @property @safe TimeOfDaytimeOfDay();
- The time portion of DateTime.
- pure nothrow @nogc @property @safe voidtimeOfDay(TimeOfDaytod);
- The time portion of DateTime.Parameters:TimeOfDay todThe std.datetime.date.TimeOfDay to set this DateTime's time portion to. 
- const pure nothrow @nogc @property @safe shortyear();
- Year of the Gregorian Calendar. Positive numbers are A.D. Non-positive are B.C.
- pure @property @safe voidyear(intyear);
- Year of the Gregorian Calendar. Positive numbers are A.D. Non-positive are B.C.Parameters:int yearThe year to set this DateTime's year to. Throws:std.datetime.date.DateTimeException if the new year is not a leap year and if the resulting date would be on February 29th.Examples:writeln(DateTime(Date(1999, 7, 6), TimeOfDay(9, 7, 5)).year); // 1999 writeln(DateTime(Date(2010, 10, 4), TimeOfDay(0, 0, 30)).year); // 2010 writeln(DateTime(Date(-7, 4, 5), TimeOfDay(7, 45, 2)).year); // -7 
- const pure @property @safe shortyearBC();
- Year B.C. of the Gregorian Calendar counting year 0 as 1 B.C.Throws:std.datetime.date.DateTimeException if isAD is true.Examples:writeln(DateTime(Date(0, 1, 1), TimeOfDay(12, 30, 33)).yearBC); // 1 writeln(DateTime(Date(-1, 1, 1), TimeOfDay(10, 7, 2)).yearBC); // 2 writeln(DateTime(Date(-100, 1, 1), TimeOfDay(4, 59, 0)).yearBC); // 101 
- pure @property @safe voidyearBC(intyear);
- Year B.C. of the Gregorian Calendar counting year 0 as 1 B.C.Parameters:int yearThe year B.C. to set this DateTime's year to. Throws:std.datetime.date.DateTimeException if a non-positive value is given.Examples:auto dt = DateTime(Date(2010, 1, 1), TimeOfDay(7, 30, 0)); dt.yearBC = 1; writeln(dt); // DateTime(Date(0, 1, 1), TimeOfDay(7, 30, 0)) dt.yearBC = 10; writeln(dt); // DateTime(Date(-9, 1, 1), TimeOfDay(7, 30, 0)) 
- const pure nothrow @nogc @property @safe Monthmonth();
- Month of a Gregorian Year.Examples:writeln(DateTime(Date(1999, 7, 6), TimeOfDay(9, 7, 5)).month); // 7 writeln(DateTime(Date(2010, 10, 4), TimeOfDay(0, 0, 30)).month); // 10 writeln(DateTime(Date(-7, 4, 5), TimeOfDay(7, 45, 2)).month); // 4 
- pure @property @safe voidmonth(Monthmonth);
- Month of a Gregorian Year.Parameters:Month monthThe month to set this DateTime's month to. Throws:std.datetime.date.DateTimeException if the given month is not a valid month.
- const pure nothrow @nogc @property @safe ubyteday();
- Day of a Gregorian Month.Examples:writeln(DateTime(Date(1999, 7, 6), TimeOfDay(9, 7, 5)).day); // 6 writeln(DateTime(Date(2010, 10, 4), TimeOfDay(0, 0, 30)).day); // 4 writeln(DateTime(Date(-7, 4, 5), TimeOfDay(7, 45, 2)).day); // 5 
- pure @property @safe voidday(intday);
- Day of a Gregorian Month.Parameters:int dayThe day of the month to set this DateTime's day to. Throws:std.datetime.date.DateTimeException if the given day is not a valid day of the current month.
- const pure nothrow @nogc @property @safe ubytehour();
- Hours past midnight.
- pure @property @safe voidhour(inthour);
- Hours past midnight.Parameters:int hourThe hour of the day to set this DateTime's hour to. Throws:std.datetime.date.DateTimeException if the given hour would result in an invalid DateTime.
- const pure nothrow @nogc @property @safe ubyteminute();
- Minutes past the hour.
- pure @property @safe voidminute(intminute);
- Minutes past the hour.Parameters:int minuteThe minute to set this DateTime's minute to. Throws:std.datetime.date.DateTimeException if the given minute would result in an invalid DateTime.
- const pure nothrow @nogc @property @safe ubytesecond();
- Seconds past the minute.
- pure @property @safe voidsecond(intsecond);
- Seconds past the minute.Parameters:int secondThe second to set this DateTime's second to. Throws:std.datetime.date.DateTimeException if the given seconds would result in an invalid DateTime.
- pure nothrow @nogc ref @safe DateTimeadd(string units)(longvalue, AllowDayOverflowallowOverflow= AllowDayOverflow.yes)
 if (units == "years" || units == "months");
- Adds the given number of years or months to this DateTime, mutating it. A negative number will subtract.Note that if day overflow is allowed, and the date with the adjusted year/month overflows the number of days in the new month, then the month will be incremented by one, and the day set to the number of days overflowed. (e.g. if the day were 31 and the new month were June, then the month would be incremented to July, and the new day would be 1). If day overflow is not allowed, then the day will be set to the last valid day in the month (e.g. June 31st would become June 30th).Parameters:units The type of units to add ("years" or "months"). long valueThe number of months or years to add to this DateTime. AllowDayOverflow allowOverflowWhether the days should be allowed to overflow, causing the month to increment. Returns:A reference to the DateTime (this).Examples:auto dt1 = DateTime(2010, 1, 1, 12, 30, 33); dt1.add!"months"(11); writeln(dt1); // DateTime(2010, 12, 1, 12, 30, 33) auto dt2 = DateTime(2010, 1, 1, 12, 30, 33); dt2.add!"months"(-11); writeln(dt2); // DateTime(2009, 2, 1, 12, 30, 33) auto dt3 = DateTime(2000, 2, 29, 12, 30, 33); dt3.add!"years"(1); writeln(dt3); // DateTime(2001, 3, 1, 12, 30, 33) auto dt4 = DateTime(2000, 2, 29, 12, 30, 33); dt4.add!"years"(1, AllowDayOverflow.no); writeln(dt4); // DateTime(2001, 2, 28, 12, 30, 33) 
- pure nothrow @nogc ref @safe DateTimeroll(string units)(longvalue, AllowDayOverflowallowOverflow= AllowDayOverflow.yes)
 if (units == "years" || units == "months");
- Adds the given number of years or months to this DateTime, mutating it. A negative number will subtract.The difference between rolling and adding is that rolling does not affect larger units. Rolling a DateTime 12 months gets the exact same DateTime. However, the days can still be affected due to the differing number of days in each month. Because there are no units larger than years, there is no difference between adding and rolling years.Parameters:units The type of units to add ("years" or "months"). long valueThe number of months or years to add to this DateTime. AllowDayOverflow allowOverflowWhether the days should be allowed to overflow, causing the month to increment. Returns:A reference to the DateTime (this).Examples:auto dt1 = DateTime(2010, 1, 1, 12, 33, 33); dt1.roll!"months"(1); writeln(dt1); // DateTime(2010, 2, 1, 12, 33, 33) auto dt2 = DateTime(2010, 1, 1, 12, 33, 33); dt2.roll!"months"(-1); writeln(dt2); // DateTime(2010, 12, 1, 12, 33, 33) auto dt3 = DateTime(1999, 1, 29, 12, 33, 33); dt3.roll!"months"(1); writeln(dt3); // DateTime(1999, 3, 1, 12, 33, 33) auto dt4 = DateTime(1999, 1, 29, 12, 33, 33); dt4.roll!"months"(1, AllowDayOverflow.no); writeln(dt4); // DateTime(1999, 2, 28, 12, 33, 33) auto dt5 = DateTime(2000, 2, 29, 12, 30, 33); dt5.roll!"years"(1); writeln(dt5); // DateTime(2001, 3, 1, 12, 30, 33) auto dt6 = DateTime(2000, 2, 29, 12, 30, 33); dt6.roll!"years"(1, AllowDayOverflow.no); writeln(dt6); // DateTime(2001, 2, 28, 12, 30, 33) 
- pure nothrow @nogc ref @safe DateTimeroll(string units)(longvalue)
 if (units == "days");
 pure nothrow @nogc ref @safe DateTimeroll(string units)(longvalue)
 if (units == "hours" || units == "minutes" || units == "seconds");
- Adds the given number of units to this DateTime, mutating it. A negative number will subtract.The difference between rolling and adding is that rolling does not affect larger units. For instance, rolling a DateTime one year's worth of days gets the exact same DateTime. Accepted units are "days", "minutes", "hours", "minutes", and "seconds".Parameters:units The units to add. long valueThe number of units to add to this DateTime. Returns:A reference to the DateTime (this).Examples:auto dt1 = DateTime(2010, 1, 1, 11, 23, 12); dt1.roll!"days"(1); writeln(dt1); // DateTime(2010, 1, 2, 11, 23, 12) dt1.roll!"days"(365); writeln(dt1); // DateTime(2010, 1, 26, 11, 23, 12) dt1.roll!"days"(-32); writeln(dt1); // DateTime(2010, 1, 25, 11, 23, 12) auto dt2 = DateTime(2010, 7, 4, 12, 0, 0); dt2.roll!"hours"(1); writeln(dt2); // DateTime(2010, 7, 4, 13, 0, 0) auto dt3 = DateTime(2010, 1, 1, 0, 0, 0); dt3.roll!"seconds"(-1); writeln(dt3); // DateTime(2010, 1, 1, 0, 0, 59) 
- const pure nothrow @nogc @safe DateTimeopBinary(string op)(Durationduration)
 if (op == "+" || op == "-");
- Gives the result of adding or subtracting a core.time.Duration from this DateTime.The legal types of arithmetic for DateTime using this operator areDateTime + Duration --> DateTime DateTime - Duration --> DateTime Parameters:Duration durationThe core.time.Duration to add to or subtract from this DateTime. Examples:import core.time : hours, seconds; assert(DateTime(2015, 12, 31, 23, 59, 59) + seconds(1) == DateTime(2016, 1, 1, 0, 0, 0)); assert(DateTime(2015, 12, 31, 23, 59, 59) + hours(1) == DateTime(2016, 1, 1, 0, 59, 59)); assert(DateTime(2016, 1, 1, 0, 0, 0) - seconds(1) == DateTime(2015, 12, 31, 23, 59, 59)); assert(DateTime(2016, 1, 1, 0, 59, 59) - hours(1) == DateTime(2015, 12, 31, 23, 59, 59)); 
- pure nothrow @nogc ref @safe DateTimeopOpAssign(string op)(Durationduration)
 if (op == "+" || op == "-");
- Gives the result of adding or subtracting a duration from this DateTime, as well as assigning the result to this DateTime.The legal types of arithmetic for DateTime using this operator areDateTime + duration --> DateTime DateTime - duration --> DateTime Parameters:Duration durationThe duration to add to or subtract from this DateTime. 
- const pure nothrow @nogc @safe DurationopBinary(string op)(DateTimerhs)
 if (op == "-");
- Gives the difference between two DateTimes.The legal types of arithmetic for DateTime using this operator areDateTime - DateTime --> duration 
- const pure nothrow @nogc @safe intdiffMonths(DateTimerhs);
- Returns the difference between the two DateTimes in months.To get the difference in years, subtract the year property of two DateTimes. To get the difference in days or weeks, subtract the DateTimes themselves and use the core.time.Duration that results. Because converting between months and smaller units requires a specific date (which core.time.Durations don't have), getting the difference in months requires some math using both the year and month properties, so this is a convenience function for getting the difference in months. Note that the number of days in the months or how far into the month either date is is irrelevant. It is the difference in the month property combined with the difference in years * 12. So, for instance, December 31st and January 1st are one month apart just as December 1st and January 31st are one month apart.Parameters:DateTime rhsThe DateTime to subtract from this one. Examples:assert(DateTime(1999, 2, 1, 12, 2, 3).diffMonths( DateTime(1999, 1, 31, 23, 59, 59)) == 1); assert(DateTime(1999, 1, 31, 0, 0, 0).diffMonths( DateTime(1999, 2, 1, 12, 3, 42)) == -1); assert(DateTime(1999, 3, 1, 5, 30, 0).diffMonths( DateTime(1999, 1, 1, 2, 4, 7)) == 2); assert(DateTime(1999, 1, 1, 7, 2, 4).diffMonths( DateTime(1999, 3, 31, 0, 30, 58)) == -2); 
- const pure nothrow @nogc @property @safe boolisLeapYear();
- Whether this DateTime is in a leap year.
- const pure nothrow @nogc @property @safe DayOfWeekdayOfWeek();
- Day of the week this DateTime is on.
- const pure nothrow @nogc @property @safe ushortdayOfYear();
- Day of the year this DateTime is on.Examples:writeln(DateTime(Date(1999, 1, 1), TimeOfDay(12, 22, 7)).dayOfYear); // 1 writeln(DateTime(Date(1999, 12, 31), TimeOfDay(7, 2, 59)).dayOfYear); // 365 writeln(DateTime(Date(2000, 12, 31), TimeOfDay(21, 20, 0)).dayOfYear); // 366 
- pure @property @safe voiddayOfYear(intday);
- Day of the year.Parameters:int dayThe day of the year to set which day of the year this DateTime is on. 
- const pure nothrow @nogc @property @safe intdayOfGregorianCal();
- The Xth day of the Gregorian Calendar that this DateTime is on.Examples:writeln(DateTime(Date(1, 1, 1), TimeOfDay(0, 0, 0)).dayOfGregorianCal); // 1 writeln(DateTime(Date(1, 12, 31), TimeOfDay(23, 59, 59)).dayOfGregorianCal); // 365 writeln(DateTime(Date(2, 1, 1), TimeOfDay(2, 2, 2)).dayOfGregorianCal); // 366 writeln(DateTime(Date(0, 12, 31), TimeOfDay(7, 7, 7)).dayOfGregorianCal); // 0 writeln(DateTime(Date(0, 1, 1), TimeOfDay(19, 30, 0)).dayOfGregorianCal); // -365 writeln(DateTime(Date(-1, 12, 31), TimeOfDay(4, 7, 0)).dayOfGregorianCal); // -366 writeln(DateTime(Date(2000, 1, 1), TimeOfDay(9, 30, 20)).dayOfGregorianCal); // 730_120 writeln(DateTime(Date(2010, 12, 31), TimeOfDay(15, 45, 50)).dayOfGregorianCal); // 734_137 
- pure nothrow @nogc @property @safe voiddayOfGregorianCal(intdays);
- The Xth day of the Gregorian Calendar that this DateTime is on. Setting this property does not affect the time portion of DateTime.Parameters:int daysThe day of the Gregorian Calendar to set this DateTime to. Examples:auto dt = DateTime(Date.init, TimeOfDay(12, 0, 0)); dt.dayOfGregorianCal = 1; writeln(dt); // DateTime(Date(1, 1, 1), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = 365; writeln(dt); // DateTime(Date(1, 12, 31), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = 366; writeln(dt); // DateTime(Date(2, 1, 1), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = 0; writeln(dt); // DateTime(Date(0, 12, 31), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = -365; writeln(dt); // DateTime(Date(-0, 1, 1), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = -366; writeln(dt); // DateTime(Date(-1, 12, 31), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = 730_120; writeln(dt); // DateTime(Date(2000, 1, 1), TimeOfDay(12, 0, 0)) dt.dayOfGregorianCal = 734_137; writeln(dt); // DateTime(Date(2010, 12, 31), TimeOfDay(12, 0, 0)) 
- const pure nothrow @property @safe ubyteisoWeek();
- The ISO 8601 week of the year that this DateTime is in.See Also:
- const pure nothrow @property @safe shortisoWeekYear();
- The year of the ISO 8601 week calendar that this DateTime is in.See Also:
- const pure nothrow @property @safe DateTimeendOfMonth();
- DateTime for the last day in the month that this DateTime is in. The time portion of endOfMonth is always 23:59:59.Examples:assert(DateTime(Date(1999, 1, 6), TimeOfDay(0, 0, 0)).endOfMonth == DateTime(Date(1999, 1, 31), TimeOfDay(23, 59, 59))); assert(DateTime(Date(1999, 2, 7), TimeOfDay(19, 30, 0)).endOfMonth == DateTime(Date(1999, 2, 28), TimeOfDay(23, 59, 59))); assert(DateTime(Date(2000, 2, 7), TimeOfDay(5, 12, 27)).endOfMonth == DateTime(Date(2000, 2, 29), TimeOfDay(23, 59, 59))); assert(DateTime(Date(2000, 6, 4), TimeOfDay(12, 22, 9)).endOfMonth == DateTime(Date(2000, 6, 30), TimeOfDay(23, 59, 59))); 
- const pure nothrow @nogc @property @safe ubytedaysInMonth();
- The last day in the month that this DateTime is in.Examples:writeln(DateTime(Date(1999, 1, 6), TimeOfDay(0, 0, 0)).daysInMonth); // 31 writeln(DateTime(Date(1999, 2, 7), TimeOfDay(19, 30, 0)).daysInMonth); // 28 writeln(DateTime(Date(2000, 2, 7), TimeOfDay(5, 12, 27)).daysInMonth); // 29 writeln(DateTime(Date(2000, 6, 4), TimeOfDay(12, 22, 9)).daysInMonth); // 30 
- const pure nothrow @nogc @property @safe boolisAD();
- Whether the current year is a date in A.D.Examples:assert(DateTime(Date(1, 1, 1), TimeOfDay(12, 7, 0)).isAD); assert(DateTime(Date(2010, 12, 31), TimeOfDay(0, 0, 0)).isAD); assert(!DateTime(Date(0, 12, 31), TimeOfDay(23, 59, 59)).isAD); assert(!DateTime(Date(-2010, 1, 1), TimeOfDay(2, 2, 2)).isAD); 
- const pure nothrow @nogc @property @safe longjulianDay();
- The Julian day for this DateTime at the given time. For example, prior to noon, 1996-03-31 would be the Julian day number 2_450_173, so this function returns 2_450_173, while from noon onward, the julian day number would be 2_450_174, so this function returns 2_450_174.
- const pure nothrow @nogc @property @safe longmodJulianDay();
- The modified Julian day for any time on this date (since, the modified Julian day changes at midnight).
- const pure nothrow @safe stringtoISOString();
 const voidtoISOString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this DateTime to a string with the format YYYYMMDDTHHMMSS. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:assert(DateTime(Date(2010, 7, 4), TimeOfDay(7, 6, 12)).toISOString() == "20100704T070612"); assert(DateTime(Date(1998, 12, 25), TimeOfDay(2, 15, 0)).toISOString() == "19981225T021500"); assert(DateTime(Date(0, 1, 5), TimeOfDay(23, 9, 59)).toISOString() == "00000105T230959"); assert(DateTime(Date(-4, 1, 5), TimeOfDay(0, 0, 2)).toISOString() == "-00040105T000002"); 
- const pure nothrow @safe stringtoISOExtString();
 const voidtoISOExtString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this DateTime to a string with the format YYYY-MM-DDTHH:MM:SS. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:assert(DateTime(Date(2010, 7, 4), TimeOfDay(7, 6, 12)).toISOExtString() == "2010-07-04T07:06:12"); assert(DateTime(Date(1998, 12, 25), TimeOfDay(2, 15, 0)).toISOExtString() == "1998-12-25T02:15:00"); assert(DateTime(Date(0, 1, 5), TimeOfDay(23, 9, 59)).toISOExtString() == "0000-01-05T23:09:59"); assert(DateTime(Date(-4, 1, 5), TimeOfDay(0, 0, 2)).toISOExtString() == "-0004-01-05T00:00:02"); 
- const pure nothrow @safe stringtoSimpleString();
 const voidtoSimpleString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this DateTime to a string with the format YYYY-Mon-DD HH:MM:SS. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:assert(DateTime(Date(2010, 7, 4), TimeOfDay(7, 6, 12)).toSimpleString() == "2010-Jul-04 07:06:12"); assert(DateTime(Date(1998, 12, 25), TimeOfDay(2, 15, 0)).toSimpleString() == "1998-Dec-25 02:15:00"); assert(DateTime(Date(0, 1, 5), TimeOfDay(23, 9, 59)).toSimpleString() == "0000-Jan-05 23:09:59"); assert(DateTime(Date(-4, 1, 5), TimeOfDay(0, 0, 2)).toSimpleString() == "-0004-Jan-05 00:00:02"); 
- const pure nothrow @safe stringtoString();
 const voidtoString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this DateTime to a string.This function exists to make it easy to convert a DateTime to a string for code that does not care what the exact format is - just that it presents the information in a clear manner. It also makes it easy to simply convert a DateTime to a string when using functions such as to!string, format, or writeln which use toString to convert user-defined types. So, it is unlikely that much code will call toString directly. The format of the string is purposefully unspecified, and code that cares about the format of the string should use toISOString, toISOExtString, toSimpleString, or some other custom formatting function that explicitly generates the format that the code needs. The reason is that the code is then clear about what format it's using, making it less error-prone to maintain the code and interact with other software that consumes the generated strings. It's for this same reason that DateTime has no fromString function, whereas it does have fromISOString, fromISOExtString, and fromSimpleString. The format returned by toString may or may not change in the future.
- pure @safe DateTimefromISOString(S)(scope const SisoString)
 if (isSomeString!S);
- Creates a DateTime from a string with the format YYYYMMDDTHHMMSS. Whitespace is stripped from the given string.Parameters:S isoStringA string formatted in the ISO format for dates and times. Throws:std.datetime.date.DateTimeException if the given string is not in the ISO format or if the resulting DateTime would not be valid.
- pure @safe DateTimefromISOExtString(S)(scope const SisoExtString)
 if (isSomeString!S);
- Creates a DateTime from a string with the format YYYY-MM-DDTHH:MM:SS. Whitespace is stripped from the given string.Parameters:S isoExtStringA string formatted in the ISO Extended format for dates and times. Throws:std.datetime.date.DateTimeException if the given string is not in the ISO Extended format or if the resulting DateTime would not be valid.
- pure @safe DateTimefromSimpleString(S)(scope const SsimpleString)
 if (isSomeString!S);
- Creates a DateTime from a string with the format YYYY-Mon-DD HH:MM:SS. Whitespace is stripped from the given string.Parameters:S simpleStringA string formatted in the way that toSimpleString formats dates and times. Throws:std.datetime.date.DateTimeException if the given string is not in the correct format or if the resulting DateTime would not be valid.
- static pure nothrow @nogc @property @safe DateTimemin();
- static pure nothrow @nogc @property @safe DateTimemax();
 
- structDate;
- Represents a date in the Proleptic Gregorian Calendar ranging from 32,768 B.C. to 32,767 A.D. Positive years are A.D. Non-positive years are B.C.Year, month, and day are kept separately internally so thatDateis optimized for calendar-based operations.Dateuses the Proleptic Gregorian Calendar, so it assumes the Gregorian leap year calculations for its entire length. As per ISO 8601, it treats 1 B.C. as year 0, i.e. 1 B.C. is 0, 2 B.C. is -1, etc. Use yearBC to use B.C. as a positive integer with 1 B.C. being the year prior to 1 A.D. Year 0 is a leap year.Examples:import core.time : days; auto d = Date(2000, 6, 1); writeln(d.dayOfYear); // 153 writeln(d.dayOfWeek); // DayOfWeek.thu d += 10.days; writeln(d); // Date(2000, 6, 11) writeln(d.toISOExtString()); // "2000-06-11" writeln(d.toISOString()); // "20000611" writeln(d.toSimpleString()); // "2000-Jun-11" writeln(Date.fromISOExtString("2018-01-01")); // Date(2018, 1, 1) writeln(Date.fromISOString("20180101")); // Date(2018, 1, 1) writeln(Date.fromSimpleString("2018-Jan-01")); // Date(2018, 1, 1) - pure @safe this(intyear, intmonth, intday);
- Throws:std.datetime.date.DateTimeException if the resulting Date would not be valid.Parameters:int yearYear of the Gregorian Calendar. Positive values are A.D. Non-positive values are B.C. with year 0 being the year prior to 1 A.D. int monthMonth of the year (January is 1). int dayDay of the month. 
- pure nothrow @nogc @safe this(intday);
- Parameters:int dayThe Xth day of the Gregorian Calendar that the constructed Date will be for. 
- const pure nothrow @nogc @safe intopCmp(Daterhs);
- Returns:this < rhs < 0 this == rhs 0 this > rhs > 0 
- const pure nothrow @nogc @property @safe shortyear();
- Year of the Gregorian Calendar. Positive numbers are A.D. Non-positive are B.C.Examples:writeln(Date(1999, 7, 6).year); // 1999 writeln(Date(2010, 10, 4).year); // 2010 writeln(Date(-7, 4, 5).year); // -7 
- pure @property @safe voidyear(intyear);
- Year of the Gregorian Calendar. Positive numbers are A.D. Non-positive are B.C.Parameters:int yearThe year to set this Date's year to. Throws:std.datetime.date.DateTimeException if the new year is not a leap year and the resulting date would be on February 29th.Examples:writeln(Date(1999, 7, 6).year); // 1999 writeln(Date(2010, 10, 4).year); // 2010 writeln(Date(-7, 4, 5).year); // -7 
- const pure @property @safe ushortyearBC();
- Year B.C. of the Gregorian Calendar counting year 0 as 1 B.C.Throws:std.datetime.date.DateTimeException if isAD is true.Examples:writeln(Date(0, 1, 1).yearBC); // 1 writeln(Date(-1, 1, 1).yearBC); // 2 writeln(Date(-100, 1, 1).yearBC); // 101 
- pure @property @safe voidyearBC(intyear);
- Year B.C. of the Gregorian Calendar counting year 0 as 1 B.C.Parameters:int yearThe year B.C. to set this Date's year to. Throws:std.datetime.date.DateTimeException if a non-positive value is given.Examples:auto date = Date(2010, 1, 1); date.yearBC = 1; writeln(date); // Date(0, 1, 1) date.yearBC = 10; writeln(date); // Date(-9, 1, 1) 
- const pure nothrow @nogc @property @safe Monthmonth();
- Month of a Gregorian Year.Examples:writeln(Date(1999, 7, 6).month); // 7 writeln(Date(2010, 10, 4).month); // 10 writeln(Date(-7, 4, 5).month); // 4 
- pure @property @safe voidmonth(Monthmonth);
- Month of a Gregorian Year.Parameters:Month monthThe month to set this Date's month to. Throws:std.datetime.date.DateTimeException if the given month is not a valid month or if the current day would not be valid in the given month.
- const pure nothrow @nogc @property @safe ubyteday();
- Day of a Gregorian Month.Examples:writeln(Date(1999, 7, 6).day); // 6 writeln(Date(2010, 10, 4).day); // 4 writeln(Date(-7, 4, 5).day); // 5 
- pure @property @safe voidday(intday);
- Day of a Gregorian Month.Parameters:int dayThe day of the month to set this Date's day to. Throws:std.datetime.date.DateTimeException if the given day is not a valid day of the current month.
- pure nothrow @nogc ref @safe Dateadd(string units)(longvalue, AllowDayOverflowallowOverflow= AllowDayOverflow.yes)
 if (units == "years");
- Adds the given number of years or months to this Date, mutating it. A negative number will subtract.Note that if day overflow is allowed, and the date with the adjusted year/month overflows the number of days in the new month, then the month will be incremented by one, and the day set to the number of days overflowed. (e.g. if the day were 31 and the new month were June, then the month would be incremented to July, and the new day would be 1). If day overflow is not allowed, then the day will be set to the last valid day in the month (e.g. June 31st would become June 30th).Parameters:units The type of units to add ("years" or "months"). long valueThe number of months or years to add to this Date. AllowDayOverflow allowOverflowWhether the day should be allowed to overflow, causing the month to increment. Returns:A reference to the Date (this).Examples:auto d1 = Date(2010, 1, 1); d1.add!"months"(11); writeln(d1); // Date(2010, 12, 1) auto d2 = Date(2010, 1, 1); d2.add!"months"(-11); writeln(d2); // Date(2009, 2, 1) auto d3 = Date(2000, 2, 29); d3.add!"years"(1); writeln(d3); // Date(2001, 3, 1) auto d4 = Date(2000, 2, 29); d4.add!"years"(1, AllowDayOverflow.no); writeln(d4); // Date(2001, 2, 28) 
- pure nothrow @nogc ref @safe Dateroll(string units)(longvalue, AllowDayOverflowallowOverflow= AllowDayOverflow.yes)
 if (units == "years");
- Adds the given number of years or months to this Date, mutating it. A negative number will subtract.The difference between rolling and adding is that rolling does not affect larger units. Rolling a Date 12 months gets the exact same Date. However, the days can still be affected due to the differing number of days in each month. Because there are no units larger than years, there is no difference between adding and rolling years.Parameters:units The type of units to add ("years" or "months"). long valueThe number of months or years to add to this Date. AllowDayOverflow allowOverflowWhether the day should be allowed to overflow, causing the month to increment. Returns:A reference to the Date (this).Examples:auto d1 = Date(2010, 1, 1); d1.roll!"months"(1); writeln(d1); // Date(2010, 2, 1) auto d2 = Date(2010, 1, 1); d2.roll!"months"(-1); writeln(d2); // Date(2010, 12, 1) auto d3 = Date(1999, 1, 29); d3.roll!"months"(1); writeln(d3); // Date(1999, 3, 1) auto d4 = Date(1999, 1, 29); d4.roll!"months"(1, AllowDayOverflow.no); writeln(d4); // Date(1999, 2, 28) auto d5 = Date(2000, 2, 29); d5.roll!"years"(1); writeln(d5); // Date(2001, 3, 1) auto d6 = Date(2000, 2, 29); d6.roll!"years"(1, AllowDayOverflow.no); writeln(d6); // Date(2001, 2, 28) 
- pure nothrow @nogc ref @safe Dateroll(string units)(longdays)
 if (units == "days");
- Adds the given number of units to this Date, mutating it. A negative number will subtract.The difference between rolling and adding is that rolling does not affect larger units. For instance, rolling a Date one year's worth of days gets the exact same Date. The only accepted units are "days".Parameters:units The units to add. Must be " days".long daysThe number of days to add to this Date. Returns:A reference to the Date (this).Examples:auto d = Date(2010, 1, 1); d.roll!"days"(1); writeln(d); // Date(2010, 1, 2) d.roll!"days"(365); writeln(d); // Date(2010, 1, 26) d.roll!"days"(-32); writeln(d); // Date(2010, 1, 25) 
- const pure nothrow @nogc @safe DateopBinary(string op)(Durationduration)
 if (op == "+" || op == "-");
- Gives the result of adding or subtracting a core.time.Duration fromThe legal types of arithmetic for Date using this operator areDate + Duration --> Date Date - Duration --> Date Parameters:Duration durationThe core.time.Duration to add to or subtract from this Date. Examples:import core.time : days; writeln(Date(2015, 12, 31) + days(1)); // Date(2016, 1, 1) writeln(Date(2004, 2, 26) + days(4)); // Date(2004, 3, 1) writeln(Date(2016, 1, 1) - days(1)); // Date(2015, 12, 31) writeln(Date(2004, 3, 1) - days(4)); // Date(2004, 2, 26) 
- pure nothrow @nogc ref @safe DateopOpAssign(string op)(Durationduration)
 if (op == "+" || op == "-");
- Gives the result of adding or subtracting a core.time.Duration from this Date, as well as assigning the result to this Date.The legal types of arithmetic for Date using this operator areDate + Duration --> Date Date - Duration --> Date Parameters:Duration durationThe core.time.Duration to add to or subtract from this Date. 
- const pure nothrow @nogc @safe DurationopBinary(string op)(Daterhs)
 if (op == "-");
- Gives the difference between two Dates.The legal types of arithmetic for Date using this operator areDate - Date --> duration 
- const pure nothrow @nogc @safe intdiffMonths(Daterhs);
- Returns the difference between the two Dates in months.To get the difference in years, subtract the year property of two Dates. To get the difference in days or weeks, subtract the Dates themselves and use the core.time.Duration that results. Because converting between months and smaller units requires a specific date (which core.time.Durations don't have), getting the difference in months requires some math using both the year and month properties, so this is a convenience function for getting the difference in months. Note that the number of days in the months or how far into the month either Date is is irrelevant. It is the difference in the month property combined with the difference in years * 12. So, for instance, December 31st and January 1st are one month apart just as December 1st and January 31st are one month apart.Parameters:Date rhsThe Date to subtract from this one. Examples:writeln(Date(1999, 2, 1).diffMonths(Date(1999, 1, 31))); // 1 writeln(Date(1999, 1, 31).diffMonths(Date(1999, 2, 1))); // -1 writeln(Date(1999, 3, 1).diffMonths(Date(1999, 1, 1))); // 2 writeln(Date(1999, 1, 1).diffMonths(Date(1999, 3, 31))); // -2 
- const pure nothrow @nogc @property @safe boolisLeapYear();
- Whether this Date is in a leap year.
- const pure nothrow @nogc @property @safe DayOfWeekdayOfWeek();
- Day of the week this Date is on.
- const pure nothrow @nogc @property @safe ushortdayOfYear();
- Day of the year this Date is on.Examples:writeln(Date(1999, 1, 1).dayOfYear); // 1 writeln(Date(1999, 12, 31).dayOfYear); // 365 writeln(Date(2000, 12, 31).dayOfYear); // 366 
- pure @property @safe voiddayOfYear(intday);
- Day of the year.Parameters:int dayThe day of the year to set which day of the year this Date is on. Throws:std.datetime.date.DateTimeException if the given day is an invalid day of the year.
- const pure nothrow @nogc @property @safe intdayOfGregorianCal();
- The Xth day of the Gregorian Calendar that this Date is on.Examples:writeln(Date(1, 1, 1).dayOfGregorianCal); // 1 writeln(Date(1, 12, 31).dayOfGregorianCal); // 365 writeln(Date(2, 1, 1).dayOfGregorianCal); // 366 writeln(Date(0, 12, 31).dayOfGregorianCal); // 0 writeln(Date(0, 1, 1).dayOfGregorianCal); // -365 writeln(Date(-1, 12, 31).dayOfGregorianCal); // -366 writeln(Date(2000, 1, 1).dayOfGregorianCal); // 730_120 writeln(Date(2010, 12, 31).dayOfGregorianCal); // 734_137 
- pure nothrow @nogc @property @safe voiddayOfGregorianCal(intday);
- The Xth day of the Gregorian Calendar that this Date is on.Parameters:int dayThe day of the Gregorian Calendar to set this Date to. Examples:auto date = Date.init; date.dayOfGregorianCal = 1; writeln(date); // Date(1, 1, 1) date.dayOfGregorianCal = 365; writeln(date); // Date(1, 12, 31) date.dayOfGregorianCal = 366; writeln(date); // Date(2, 1, 1) date.dayOfGregorianCal = 0; writeln(date); // Date(0, 12, 31) date.dayOfGregorianCal = -365; writeln(date); // Date(-0, 1, 1) date.dayOfGregorianCal = -366; writeln(date); // Date(-1, 12, 31) date.dayOfGregorianCal = 730_120; writeln(date); // Date(2000, 1, 1) date.dayOfGregorianCal = 734_137; writeln(date); // Date(2010, 12, 31) 
- const pure nothrow @property @safe autoisoWeekAndYear();
- The ISO 8601 week and year of the year that this Date is in.Returns:An anonymous struct with the members isoWeekYear for the resulting year and isoWeek for the resulting ISO week.See Also:
- const pure nothrow @property @safe ubyteisoWeek();
- The ISO 8601 week of the year that this Date is in.See Also:
- const pure nothrow @property @safe shortisoWeekYear();
- The year inside the ISO 8601 week calendar that this Date is in.May differ from year between 28 December and 4 January.See Also:
- const pure nothrow @property @safe DateendOfMonth();
- Examples:writeln(Date(1999, 1, 6).endOfMonth); // Date(1999, 1, 31) writeln(Date(1999, 2, 7).endOfMonth); // Date(1999, 2, 28) writeln(Date(2000, 2, 7).endOfMonth); // Date(2000, 2, 29) writeln(Date(2000, 6, 4).endOfMonth); // Date(2000, 6, 30) 
- const pure nothrow @nogc @property @safe ubytedaysInMonth();
- The last day in the month that this Date is in.Examples:writeln(Date(1999, 1, 6).daysInMonth); // 31 writeln(Date(1999, 2, 7).daysInMonth); // 28 writeln(Date(2000, 2, 7).daysInMonth); // 29 writeln(Date(2000, 6, 4).daysInMonth); // 30 
- const pure nothrow @nogc @property @safe boolisAD();
- Whether the current year is a date in A.D.Examples:assert(Date(1, 1, 1).isAD); assert(Date(2010, 12, 31).isAD); assert(!Date(0, 12, 31).isAD); assert(!Date(-2010, 1, 1).isAD); 
- const pure nothrow @nogc @property @safe longjulianDay();
- The Julian day for this Date at noon (since the Julian day changes at noon).
- const pure nothrow @nogc @property @safe longmodJulianDay();
- The modified Julian day for any time on this date (since, the modified Julian day changes at midnight).
- const pure nothrow @safe stringtoISOString();
 const voidtoISOString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this Date to a string with the format YYYYMMDD. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:writeln(Date(2010, 7, 4).toISOString()); // "20100704" writeln(Date(1998, 12, 25).toISOString()); // "19981225" writeln(Date(0, 1, 5).toISOString()); // "00000105" writeln(Date(-4, 1, 5).toISOString()); // "-00040105" 
- const pure nothrow @safe stringtoISOExtString();
 const voidtoISOExtString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this Date to a string with the format YYYY-MM-DD. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:writeln(Date(2010, 7, 4).toISOExtString()); // "2010-07-04" writeln(Date(1998, 12, 25).toISOExtString()); // "1998-12-25" writeln(Date(0, 1, 5).toISOExtString()); // "0000-01-05" writeln(Date(-4, 1, 5).toISOExtString()); // "-0004-01-05" 
- const pure nothrow @safe stringtoSimpleString();
 const voidtoSimpleString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this Date to a string with the format YYYY-Mon-DD. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:writeln(Date(2010, 7, 4).toSimpleString()); // "2010-Jul-04" writeln(Date(1998, 12, 25).toSimpleString()); // "1998-Dec-25" writeln(Date(0, 1, 5).toSimpleString()); // "0000-Jan-05" writeln(Date(-4, 1, 5).toSimpleString()); // "-0004-Jan-05" 
- const pure nothrow @safe stringtoString();
 const voidtoString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this Date to a string.This function exists to make it easy to convert a Date to a string for code that does not care what the exact format is - just that it presents the information in a clear manner. It also makes it easy to simply convert a Date to a string when using functions such as to!string, format, or writeln which use toString to convert user-defined types. So, it is unlikely that much code will call toString directly. The format of the string is purposefully unspecified, and code that cares about the format of the string should use toISOString, toISOExtString, toSimpleString, or some other custom formatting function that explicitly generates the format that the code needs. The reason is that the code is then clear about what format it's using, making it less error-prone to maintain the code and interact with other software that consumes the generated strings. It's for this same reason Date has no fromString function, whereas it does have fromISOString, fromISOExtString, and fromSimpleString. The format returned by toString may or may not change in the future.
- pure @safe DatefromISOString(S)(scope const SisoString)
 if (isSomeString!S);
- Creates a Date from a string with the format YYYYMMDD. Whitespace is stripped from the given string.Parameters:S isoStringA string formatted in the ISO format for dates. Throws:std.datetime.date.DateTimeException if the given string is not in the ISO format or if the resulting Date would not be valid.
- pure @safe DatefromISOExtString(S)(scope const SisoExtString)
 if (isSomeString!S);
- Creates a Date from a string with the format YYYY-MM-DD. Whitespace is stripped from the given string.Parameters:S isoExtStringA string formatted in the ISO Extended format for dates. Throws:std.datetime.date.DateTimeException if the given string is not in the ISO Extended format or if the resulting Date would not be valid.
- pure @safe DatefromSimpleString(S)(scope const SsimpleString)
 if (isSomeString!S);
- Creates a Date from a string with the format YYYY-Mon-DD. Whitespace is stripped from the given string.Parameters:S simpleStringA string formatted in the way that toSimpleString formats dates. Throws:std.datetime.date.DateTimeException if the given string is not in the correct format or if the resulting Date would not be valid.
- static pure nothrow @nogc @property @safe Datemin();
- static pure nothrow @nogc @property @safe Datemax();
 
- structTimeOfDay;
- Represents a time of day with hours, minutes, and seconds. It uses 24 hour time.Examples:import core.time : minutes, seconds; auto t = TimeOfDay(12, 30, 0); t += 10.minutes + 100.seconds; writeln(t); // TimeOfDay(12, 41, 40) writeln(t.toISOExtString()); // "12:41:40" writeln(t.toISOString()); // "124140" writeln(TimeOfDay.fromISOExtString("15:00:00")); // TimeOfDay(15, 0, 0) writeln(TimeOfDay.fromISOString("015000")); // TimeOfDay(1, 50, 0) - pure @safe this(inthour, intminute, intsecond= 0);
- Parameters:int hourHour of the day [0 - 24). int minuteMinute of the hour [0 - 60). int secondSecond of the minute [0 - 60). Throws:std.datetime.date.DateTimeException if the resulting TimeOfDay would be not be valid.
- const pure nothrow @nogc @safe intopCmp(TimeOfDayrhs);
- Returns:this < rhs < 0 this == rhs 0 this > rhs > 0 
- const pure nothrow @nogc @property @safe ubytehour();
- Hours past midnight.
- pure @property @safe voidhour(inthour);
- Hours past midnight.Parameters:int hourThe hour of the day to set this TimeOfDay's hour to. Throws:std.datetime.date.DateTimeException if the given hour would result in an invalid TimeOfDay.
- const pure nothrow @nogc @property @safe ubyteminute();
- Minutes past the hour.
- pure @property @safe voidminute(intminute);
- Minutes past the hour.Parameters:int minuteThe minute to set this TimeOfDay's minute to. Throws:std.datetime.date.DateTimeException if the given minute would result in an invalid TimeOfDay.
- const pure nothrow @nogc @property @safe ubytesecond();
- Seconds past the minute.
- pure @property @safe voidsecond(intsecond);
- Seconds past the minute.Parameters:int secondThe second to set this TimeOfDay's second to. Throws:std.datetime.date.DateTimeException if the given second would result in an invalid TimeOfDay.
- pure nothrow @nogc ref @safe TimeOfDayroll(string units)(longvalue)
 if (units == "hours");
 pure nothrow @nogc ref @safe TimeOfDayroll(string units)(longvalue)
 if (units == "minutes" || units == "seconds");
- Adds the given number of units to this TimeOfDay, mutating it. A negative number will subtract.The difference between rolling and adding is that rolling does not affect larger units. For instance, rolling a TimeOfDay one hours's worth of minutes gets the exact same TimeOfDay. Accepted units are "hours", "minutes", and "seconds".Parameters:units The units to add. long valueThe number of units to add to this TimeOfDay. Returns:A reference to the TimeOfDay (this).Examples:auto tod1 = TimeOfDay(7, 12, 0); tod1.roll!"hours"(1); writeln(tod1); // TimeOfDay(8, 12, 0) auto tod2 = TimeOfDay(7, 12, 0); tod2.roll!"hours"(-1); writeln(tod2); // TimeOfDay(6, 12, 0) auto tod3 = TimeOfDay(23, 59, 0); tod3.roll!"minutes"(1); writeln(tod3); // TimeOfDay(23, 0, 0) auto tod4 = TimeOfDay(0, 0, 0); tod4.roll!"minutes"(-1); writeln(tod4); // TimeOfDay(0, 59, 0) auto tod5 = TimeOfDay(23, 59, 59); tod5.roll!"seconds"(1); writeln(tod5); // TimeOfDay(23, 59, 0) auto tod6 = TimeOfDay(0, 0, 0); tod6.roll!"seconds"(-1); writeln(tod6); // TimeOfDay(0, 0, 59) 
- const pure nothrow @nogc @safe TimeOfDayopBinary(string op)(Durationduration)
 if (op == "+" || op == "-");
- Gives the result of adding or subtracting a core.time.Duration from this TimeOfDay.The legal types of arithmetic for TimeOfDay using this operator areTimeOfDay + Duration --> TimeOfDay TimeOfDay - Duration --> TimeOfDay Parameters:Duration durationThe core.time.Duration to add to or subtract from this TimeOfDay. Examples:import core.time : hours, minutes, seconds; writeln(TimeOfDay(12, 12, 12) + seconds(1)); // TimeOfDay(12, 12, 13) writeln(TimeOfDay(12, 12, 12) + minutes(1)); // TimeOfDay(12, 13, 12) writeln(TimeOfDay(12, 12, 12) + hours(1)); // TimeOfDay(13, 12, 12) writeln(TimeOfDay(23, 59, 59) + seconds(1)); // TimeOfDay(0, 0, 0) writeln(TimeOfDay(12, 12, 12) - seconds(1)); // TimeOfDay(12, 12, 11) writeln(TimeOfDay(12, 12, 12) - minutes(1)); // TimeOfDay(12, 11, 12) writeln(TimeOfDay(12, 12, 12) - hours(1)); // TimeOfDay(11, 12, 12) writeln(TimeOfDay(0, 0, 0) - seconds(1)); // TimeOfDay(23, 59, 59) 
- pure nothrow @nogc ref @safe TimeOfDayopOpAssign(string op)(Durationduration)
 if (op == "+" || op == "-");
- Gives the result of adding or subtracting a core.time.Duration from this TimeOfDay, as well as assigning the result to this TimeOfDay.The legal types of arithmetic for TimeOfDay using this operator areTimeOfDay + Duration --> TimeOfDay TimeOfDay - Duration --> TimeOfDay Parameters:Duration durationThe core.time.Duration to add to or subtract from this TimeOfDay. 
- const pure nothrow @nogc @safe DurationopBinary(string op)(TimeOfDayrhs)
 if (op == "-");
- Gives the difference between two TimeOfDays.The legal types of arithmetic for TimeOfDay using this operator areTimeOfDay - TimeOfDay --> duration Parameters:TimeOfDay rhsThe TimeOfDay to subtract from this one. 
- const pure nothrow @safe stringtoISOString();
 const voidtoISOString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this TimeOfDay to a string with the format HHMMSS. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:writeln(TimeOfDay(0, 0, 0).toISOString()); // "000000" writeln(TimeOfDay(12, 30, 33).toISOString()); // "123033" 
- const pure nothrow @safe stringtoISOExtString();
 const voidtoISOExtString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this TimeOfDay to a string with the format HH:MM:SS. Ifwriteris set, the resulting string will be written directly to it.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.Examples:writeln(TimeOfDay(0, 0, 0).toISOExtString()); // "00:00:00" writeln(TimeOfDay(12, 30, 33).toISOExtString()); // "12:30:33" 
- const pure nothrow @safe stringtoString();
 const voidtoString(W)(ref Wwriter)
 if (isOutputRange!(W, char));
- Converts this TimeOfDay to a string.This function exists to make it easy to convert a TimeOfDay to a string for code that does not care what the exact format is - just that it presents the information in a clear manner. It also makes it easy to simply convert a TimeOfDay to a string when using functions such as to!string, format, or writeln which use toString to convert user-defined types. So, it is unlikely that much code will call toString directly. The format of the string is purposefully unspecified, and code that cares about the format of the string should use toISOString, toISOExtString, or some other custom formatting function that explicitly generates the format that the code needs. The reason is that the code is then clear about what format it's using, making it less error-prone to maintain the code and interact with other software that consumes the generated strings. It's for this same reason that TimeOfDay has no fromString function, whereas it does have fromISOString and fromISOExtString. The format returned by toString may or may not change in the future.Parameters:W writerA char accepting output range Returns:A string when not using an output range; void otherwise.
- pure @safe TimeOfDayfromISOString(S)(scope const SisoString)
 if (isSomeString!S);
- Creates a TimeOfDay from a string with the format HHMMSS. Whitespace is stripped from the given string.Parameters:S isoStringA string formatted in the ISO format for times. Throws:std.datetime.date.DateTimeException if the given string is not in the ISO format or if the resulting TimeOfDay would not be valid.
- pure @safe TimeOfDayfromISOExtString(S)(scope const SisoExtString)
 if (isSomeString!S);
- Creates a TimeOfDay from a string with the format HH:MM:SS. Whitespace is stripped from the given string.Parameters:S isoExtStringA string formatted in the ISO Extended format for times. Throws:std.datetime.date.DateTimeException if the given string is not in the ISO Extended format or if the resulting TimeOfDay would not be valid.
- static pure nothrow @nogc @property @safe TimeOfDaymin();
- Returns midnight.
- static pure nothrow @nogc @property @safe TimeOfDaymax();
- Returns one second short of midnight.
 
- pure nothrow @nogc @safe boolvalid(string units)(intvalue)
 if (units == "months" || units == "hours" || units == "minutes" || units == "seconds");
- Returns whether the given value is valid for the given unit type when in a time point. Naturally, a duration is not held to a particular range, but the values in a time point are (e.g. a month must be in the range of 1 - 12 inclusive).Parameters:units The units of time to validate. int valueThe number to validate. Examples:assert(valid!"hours"(12)); assert(!valid!"hours"(32)); assert(valid!"months"(12)); assert(!valid!"months"(13)); 
- pure nothrow @nogc @safe boolvalid(string units)(intyear, intmonth, intday)
 if (units == "days");
- Returns whether the given day is valid for the given year and month.Parameters:units The units of time to validate. int yearThe year of the day to validate. int monthThe month of the day to validate (January is 1). int dayThe day to validate. Examples:assert(valid!"days"(2016, 2, 29)); assert(!valid!"days"(2016, 2, 30)); assert(valid!"days"(2017, 2, 20)); assert(!valid!"days"(2017, 2, 29)); 
- pure @safe voidenforceValid(string units)(intvalue, stringfile= __FILE__, size_tline= __LINE__)
 if (units == "months" || units == "hours" || units == "minutes" || units == "seconds");
- Parameters:units The units of time to validate. int valueThe number to validate. string fileThe file that the DateTimeException will list if thrown. size_t lineThe line number that the DateTimeException will list if thrown. Throws:DateTimeException if valid!units(value) is false.Examples:import std.exception : assertThrown, assertNotThrown; assertNotThrown(enforceValid!"months"(10)); assertNotThrown(enforceValid!"seconds"(40)); assertThrown!DateTimeException(enforceValid!"months"(0)); assertThrown!DateTimeException(enforceValid!"hours"(24)); assertThrown!DateTimeException(enforceValid!"minutes"(60)); assertThrown!DateTimeException(enforceValid!"seconds"(60)); 
- pure @safe voidenforceValid(string units)(intyear, Monthmonth, intday, stringfile= __FILE__, size_tline= __LINE__)
 if (units == "days");
- Because the validity of the day number depends on both on the year and month of which the day is occurring, take all three variables to validate the day.Parameters:units The units of time to validate. int yearThe year of the day to validate. Month monthThe month of the day to validate. int dayThe day to validate. string fileThe file that the DateTimeException will list if thrown. size_t lineThe line number that the DateTimeException will list if thrown. Throws:DateTimeException if valid!"days"(year, month, day) is false.Examples:import std.exception : assertThrown, assertNotThrown; assertNotThrown(enforceValid!"days"(2000, Month.jan, 1)); // leap year assertNotThrown(enforceValid!"days"(2000, Month.feb, 29)); assertThrown!DateTimeException(enforceValid!"days"(2001, Month.feb, 29)); assertThrown!DateTimeException(enforceValid!"days"(2000, Month.jan, 32)); assertThrown!DateTimeException(enforceValid!"days"(2000, Month.apr, 31)); 
- pure nothrow @nogc @safe intdaysToDayOfWeek(DayOfWeekcurrDoW, DayOfWeekdow);
- Returns the number of days from the current day of the week to the given day of the week. If they are the same, then the result is 0.Parameters:DayOfWeek currDoWThe current day of the week. DayOfWeek dowThe day of the week to get the number of days to. Examples:writeln(daysToDayOfWeek(DayOfWeek.mon, DayOfWeek.mon)); // 0 writeln(daysToDayOfWeek(DayOfWeek.mon, DayOfWeek.sun)); // 6 writeln(daysToDayOfWeek(DayOfWeek.mon, DayOfWeek.wed)); // 2 
- pure @safe intmonthsToMonth(intcurrMonth, intmonth);
- Returns the number of months from the current months of the year to the given month of the year. If they are the same, then the result is 0.Parameters:int currMonthThe current month of the year. int monthThe month of the year to get the number of months to. Examples:writeln(monthsToMonth(Month.jan, Month.jan)); // 0 writeln(monthsToMonth(Month.jan, Month.dec)); // 11 writeln(monthsToMonth(Month.jul, Month.oct)); // 3 
- pure nothrow @nogc @safe boolyearIsLeapYear(intyear);
- Whether the given Gregorian Year is a leap year.Parameters:int yearThe year to to be tested. Examples:foreach (year; [1, 2, 100, 2001, 2002, 2003, 2005, 2006, 2007, 2009, 2010]) { assert(!yearIsLeapYear(year)); assert(!yearIsLeapYear(-year)); } foreach (year; [0, 4, 8, 400, 800, 1600, 1996, 2000, 2004, 2008, 2012]) { assert(yearIsLeapYear(year)); assert(yearIsLeapYear(-year)); } 
- enum autoisTimePoint(T);
- Whether the given type defines all of the necessary functions for it to function as a time point.- T must define a static property named min which is the smallest value of T as Unqual!T.
- T must define a static property named max which is the largest value of T as Unqual!T.
- T must define an opBinary for addition and subtraction that accepts core.time.Duration and returns Unqual!T.
- T must define an opOpAssign for addition and subtraction that accepts core.time.Duration and returns ref Unqual!T.
- T must define a opBinary for subtraction which accepts T and returns core.time.Duration.
 Examples:import core.time : Duration; import std.datetime.interval : Interval; import std.datetime.systime : SysTime; static assert(isTimePoint!Date); static assert(isTimePoint!DateTime); static assert(isTimePoint!SysTime); static assert(isTimePoint!TimeOfDay); static assert(!isTimePoint!int); static assert(!isTimePoint!Duration); static assert(!isTimePoint!(Interval!SysTime)); 
- pure nothrow @nogc @safe boolvalidTimeUnits(string[]units...);
- Whether all of the given strings are valid units of time."nsecs" is not considered a valid unit of time. Nothing in std.datetime can handle precision greater than hnsecs, and the few functions in core.time which deal with "nsecs" deal with it explicitly.Examples:assert(validTimeUnits("msecs", "seconds", "minutes")); assert(validTimeUnits("days", "weeks", "months")); assert(!validTimeUnits("ms", "seconds", "minutes")); 
- pure @safe intcmpTimeUnits(stringlhs, stringrhs);
- Compares two time unit strings. "years" are the largest units and "hnsecs" are the smallest.Returns:this < rhs < 0 this == rhs 0 this > rhs > 0 Throws:DateTimeException if either of the given strings is not a valid time unit string.Examples:import std.exception : assertThrown; writeln(cmpTimeUnits("hours", "hours")); // 0 assert(cmpTimeUnits("hours", "weeks") < 0); assert(cmpTimeUnits("months", "seconds") > 0); assertThrown!DateTimeException(cmpTimeUnits("month", "second")); 
- templateCmpTimeUnits(string lhs, string rhs) if (validTimeUnits(lhs, rhs))
- Compares two time unit strings at compile time. "years" are the largest units and "hnsecs" are the smallest.This template is used instead of cmpTimeUnits because exceptions can't be thrown at compile time and cmpTimeUnits must enforce that the strings it's given are valid time unit strings. This template uses a template constraint instead.Returns:this < rhs < 0 this == rhs 0 this > rhs > 0 Examples:static assert(CmpTimeUnits!("years", "weeks") > 0); static assert(CmpTimeUnits!("days", "days") == 0); static assert(CmpTimeUnits!("seconds", "hours") < 0); 
Copyright © 1999-2024 by the D Language Foundation | Page generated by
Ddoc on (no date time)