/*========================================================================= Program: Visualization Toolkit Module: vtkTimePointUtility.h Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ /*------------------------------------------------------------------------- Copyright 2008 Sandia Corporation. Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains certain rights in this software. -------------------------------------------------------------------------*/ /** * @class vtkTimePointUtility * @brief performs common time operations * * * vtkTimePointUtility is provides methods to perform common time operations. */ #ifndef vtkTimePointUtility_h #define vtkTimePointUtility_h #include "vtkCommonCoreModule.h" // For export macro #include "vtkObject.h" class VTKCOMMONCORE_EXPORT vtkTimePointUtility : public vtkObject { public: static vtkTimePointUtility* New(); vtkTypeMacro(vtkTimePointUtility, vtkObject); void PrintSelf(ostream& os, vtkIndent indent) override; /** * Return the time point for 12:00am on a specified day. */ static vtkTypeUInt64 DateToTimePoint(int year, int month, int day); /** * Return the time point for a time of day (the number of milliseconds from 12:00am. * The hour should be from 0-23. */ static vtkTypeUInt64 TimeToTimePoint(int hour, int minute, int second, int millis = 0); /** * Return the time point for a date and time. */ static vtkTypeUInt64 DateTimeToTimePoint( int year, int month, int day, int hour, int minute, int sec, int millis = 0); /** * Retrieve the year, month, and day of a time point. * Everything but the first argument are output parameters. */ static void GetDate(vtkTypeUInt64 time, int& year, int& month, int& day); /** * Retrieve the hour, minute, second, and milliseconds of a time point. * Everything but the first argument are output parameters. */ static void GetTime(vtkTypeUInt64 time, int& hour, int& minute, int& second, int& millis); /** * Retrieve the date and time of a time point. * Everything but the first argument are output parameters. */ static void GetDateTime(vtkTypeUInt64 time, int& year, int& month, int& day, int& hour, int& minute, int& second, int& millis); /** * Retrieve the year from a time point. */ static int GetYear(vtkTypeUInt64 time); /** * Retrieve the month from a time point. */ static int GetMonth(vtkTypeUInt64 time); /** * Retrieve the day of the month from a time point. */ static int GetDay(vtkTypeUInt64 time); /** * Retrieve the hour of the day from the time point. */ static int GetHour(vtkTypeUInt64 time); /** * Retrieve the number of minutes from the start of the last hour. */ static int GetMinute(vtkTypeUInt64 time); /** * Retrieve the number of seconds from the start of the last minute. */ static int GetSecond(vtkTypeUInt64 time); /** * Retrieve the milliseconds from the start of the last second. */ static int GetMillisecond(vtkTypeUInt64 time); enum { ISO8601_DATETIME_MILLIS = 0, ISO8601_DATETIME = 1, ISO8601_DATE = 2, ISO8601_TIME_MILLIS = 3, ISO8601_TIME = 4 }; static const int MILLIS_PER_SECOND; static const int MILLIS_PER_MINUTE; static const int MILLIS_PER_HOUR; static const int MILLIS_PER_DAY; static const int SECONDS_PER_MINUTE; static const int SECONDS_PER_HOUR; static const int SECONDS_PER_DAY; static const int MINUTES_PER_HOUR; static const int MINUTES_PER_DAY; static const int HOURS_PER_DAY; /** * Converts a ISO8601 string into a VTK timepoint. * The string must follow one of the ISO8601 formats described * in ToISO8601. To check for a valid format, pass a bool* as * the second argument. The value will be set to true if the * string was parsed successfully, false otherwise. */ static vtkTypeUInt64 ISO8601ToTimePoint(const char* str, bool* ok = nullptr); /** * Converts a VTK timepoint into one of the following ISO8601 * formats. The default format is ISO8601_DATETIME_MILLIS. *
   * Type                      Format / Example
   * 0 ISO8601_DATETIME_MILLIS [YYYY]-[MM]-[DD]T[hh]:[mm]:[ss].[SSS]
   * 2006-01-02T03:04:05.678
   * 1 ISO8601_DATETIME        [YYYY]-[MM]-[DD]T[hh]:[mm]:[ss]
   * 2006-01-02T03:04:05
   * 2 ISO8601_DATE            [YYYY]-[MM]-[DD]
   * 2006-01-02
   * 3 ISO8601_TIME_MILLIS     [hh]:[mm]:[ss].[SSS]
   * 03:04:05.678
   * 4 ISO8601_TIME            [hh]:[mm]:[ss]
   * 03:04:05
   * 
*/ static const char* TimePointToISO8601(vtkTypeUInt64, int format = ISO8601_DATETIME_MILLIS); protected: vtkTimePointUtility() {} ~vtkTimePointUtility() override {} private: vtkTimePointUtility(const vtkTimePointUtility&) = delete; void operator=(const vtkTimePointUtility&) = delete; }; #endif