Open CASCADE Technology 7.8.2.dev
Quantity_Date Class Reference

This class provides services to manage date information. A date represents the following time intervals: year, month, day, hour, minute, second, millisecond and microsecond. Current time is expressed in elapsed seconds and microseconds beginning from 00:00 GMT, January 1, 1979 (zero hour). The valid date can only be later than this one. Note: a Period object gives the interval between two dates. More...

#include <Quantity_Date.hxx>

Public Member Functions

 Quantity_Date ()
 Constructs a default date (00:00 GMT, January 1, 1979 (zero hour)); use the function SetValues to define the required date; or.
 
 Quantity_Date (const Standard_Integer mm, const Standard_Integer dd, const Standard_Integer yyyy, const Standard_Integer hh, const Standard_Integer mn, const Standard_Integer ss, const Standard_Integer mis=0, const Standard_Integer mics=0)
 Constructs a date from the year yyyy, the month mm, the day dd, the hour hh, the minute mn, the second ss, the millisecond mis (defaulted to 0) and the microsecond mics (defaulted to 0).. With: 1 <= mm <= 12 1 <= dd <= max number of days of <mm> 1979 <= yyyy 0 <= hh <= 23 0 <= mn <= 59 0 <= ss <= 59 0 <= mis <= 999 0 <= mics <= 999 Exceptions Quantity_DateDefinitionError if mm, dd, hh, mn, ss, mis and mics are not the components of the valid date.
 
void Values (Standard_Integer &mm, Standard_Integer &dd, Standard_Integer &yy, Standard_Integer &hh, Standard_Integer &mn, Standard_Integer &ss, Standard_Integer &mis, Standard_Integer &mics) const
 Gets a complete Date.
 
void SetValues (const Standard_Integer mm, const Standard_Integer dd, const Standard_Integer yy, const Standard_Integer hh, const Standard_Integer mn, const Standard_Integer ss, const Standard_Integer mis=0, const Standard_Integer mics=0)
 Assigns to this date the year yyyy, the month mm, the day dd, the hour hh, the minute mn, the second ss, the millisecond mis (defaulted to 0) and the microsecond mics (defaulted to 0). Exceptions Quantity_DateDefinitionError if mm, dd, hh, mn, ss, mis and mics are not components of a valid date.
 
Quantity_Period Difference (const Quantity_Date &anOther)
 Subtracts one Date from another one to find the period between and returns the value. The result is the absolute value between the difference of two dates.
 
Quantity_Date Subtract (const Quantity_Period &aPeriod)
 Subtracts a period from a Date and returns the new Date. Raises an exception if the result date is anterior to Jan 1, 1979.
 
Quantity_Date operator- (const Quantity_Period &aPeriod)
 
Quantity_Date Add (const Quantity_Period &aPeriod)
 Adds a Period to a Date and returns the new Date.
 
Quantity_Date operator+ (const Quantity_Period &aPeriod)
 
Standard_Integer Year ()
 Returns year of a Date.
 
Standard_Integer Month ()
 Returns month of a Date.
 
Standard_Integer Day ()
 Returns Day of a Date.
 
Standard_Integer Hour ()
 Returns Hour of a Date.
 
Standard_Integer Minute ()
 Returns minute of a Date.
 
Standard_Integer Second ()
 Returns seconde of a Date.
 
Standard_Integer MilliSecond ()
 Returns millisecond of a Date.
 
Standard_Integer MicroSecond ()
 Returns microsecond of a Date.
 
Standard_Boolean IsEqual (const Quantity_Date &anOther) const
 Returns TRUE if both <me> and <other> are equal. This method is an alias of operator ==.
 
Standard_Boolean operator== (const Quantity_Date &anOther) const
 
Standard_Boolean IsEarlier (const Quantity_Date &anOther) const
 Returns TRUE if <me> is earlier than <other>.
 
Standard_Boolean operator< (const Quantity_Date &anOther) const
 
Standard_Boolean IsLater (const Quantity_Date &anOther) const
 Returns TRUE if <me> is later then <other>.
 
Standard_Boolean operator> (const Quantity_Date &anOther) const
 

Static Public Member Functions

static Standard_Boolean IsValid (const Standard_Integer mm, const Standard_Integer dd, const Standard_Integer yy, const Standard_Integer hh, const Standard_Integer mn, const Standard_Integer ss, const Standard_Integer mis=0, const Standard_Integer mics=0)
 Checks the validity of a date - returns true if a date defined from the year yyyy, the month mm, the day dd, the hour hh, the minute mn, the second ss, the millisecond mis (defaulted to 0) and the microsecond mics (defaulted to 0) is valid. A date must satisfy the conditions above:
 
static Standard_Boolean IsLeap (const Standard_Integer yy)
 Returns true if a year is a leap year. The leap years are divisible by 4 and not by 100 except the years divisible by 400.
 

Detailed Description

This class provides services to manage date information. A date represents the following time intervals: year, month, day, hour, minute, second, millisecond and microsecond. Current time is expressed in elapsed seconds and microseconds beginning from 00:00 GMT, January 1, 1979 (zero hour). The valid date can only be later than this one. Note: a Period object gives the interval between two dates.

Constructor & Destructor Documentation

◆ Quantity_Date() [1/2]

Quantity_Date::Quantity_Date ( )

Constructs a default date (00:00 GMT, January 1, 1979 (zero hour)); use the function SetValues to define the required date; or.

◆ Quantity_Date() [2/2]

Quantity_Date::Quantity_Date ( const Standard_Integer mm,
const Standard_Integer dd,
const Standard_Integer yyyy,
const Standard_Integer hh,
const Standard_Integer mn,
const Standard_Integer ss,
const Standard_Integer mis = 0,
const Standard_Integer mics = 0 )

Constructs a date from the year yyyy, the month mm, the day dd, the hour hh, the minute mn, the second ss, the millisecond mis (defaulted to 0) and the microsecond mics (defaulted to 0).. With: 1 <= mm <= 12 1 <= dd <= max number of days of <mm> 1979 <= yyyy 0 <= hh <= 23 0 <= mn <= 59 0 <= ss <= 59 0 <= mis <= 999 0 <= mics <= 999 Exceptions Quantity_DateDefinitionError if mm, dd, hh, mn, ss, mis and mics are not the components of the valid date.

Member Function Documentation

◆ Add()

Quantity_Date Quantity_Date::Add ( const Quantity_Period & aPeriod)

Adds a Period to a Date and returns the new Date.

◆ Day()

Standard_Integer Quantity_Date::Day ( )

Returns Day of a Date.

◆ Difference()

Quantity_Period Quantity_Date::Difference ( const Quantity_Date & anOther)

Subtracts one Date from another one to find the period between and returns the value. The result is the absolute value between the difference of two dates.

◆ Hour()

Standard_Integer Quantity_Date::Hour ( )

Returns Hour of a Date.

◆ IsEarlier()

Standard_Boolean Quantity_Date::IsEarlier ( const Quantity_Date & anOther) const

Returns TRUE if <me> is earlier than <other>.

◆ IsEqual()

Standard_Boolean Quantity_Date::IsEqual ( const Quantity_Date & anOther) const

Returns TRUE if both <me> and <other> are equal. This method is an alias of operator ==.

◆ IsLater()

Standard_Boolean Quantity_Date::IsLater ( const Quantity_Date & anOther) const

Returns TRUE if <me> is later then <other>.

◆ IsLeap()

static Standard_Boolean Quantity_Date::IsLeap ( const Standard_Integer yy)
inlinestatic

Returns true if a year is a leap year. The leap years are divisible by 4 and not by 100 except the years divisible by 400.

◆ IsValid()

static Standard_Boolean Quantity_Date::IsValid ( const Standard_Integer mm,
const Standard_Integer dd,
const Standard_Integer yy,
const Standard_Integer hh,
const Standard_Integer mn,
const Standard_Integer ss,
const Standard_Integer mis = 0,
const Standard_Integer mics = 0 )
static

Checks the validity of a date - returns true if a date defined from the year yyyy, the month mm, the day dd, the hour hh, the minute mn, the second ss, the millisecond mis (defaulted to 0) and the microsecond mics (defaulted to 0) is valid. A date must satisfy the conditions above:

  • yyyy is greater than or equal to 1979,
  • mm lies within the range [1, 12] (with 1 corresponding to January and 12 to December),
  • dd lies within a valid range for the month mm (from 1 to 28, 29, 30 or 31 depending on mm and whether yyyy is a leap year or not),
  • hh lies within the range [0, 23],
  • mn lies within the range [0, 59],
  • ss lies within the range [0, 59],
  • mis lies within the range [0, 999],
  • mics lies within the range [0, 999].C

◆ MicroSecond()

Standard_Integer Quantity_Date::MicroSecond ( )

Returns microsecond of a Date.

◆ MilliSecond()

Standard_Integer Quantity_Date::MilliSecond ( )

Returns millisecond of a Date.

◆ Minute()

Standard_Integer Quantity_Date::Minute ( )

Returns minute of a Date.

◆ Month()

Standard_Integer Quantity_Date::Month ( )

Returns month of a Date.

◆ operator+()

Quantity_Date Quantity_Date::operator+ ( const Quantity_Period & aPeriod)
inline

◆ operator-()

Quantity_Date Quantity_Date::operator- ( const Quantity_Period & aPeriod)
inline

◆ operator<()

Standard_Boolean Quantity_Date::operator< ( const Quantity_Date & anOther) const
inline

◆ operator==()

Standard_Boolean Quantity_Date::operator== ( const Quantity_Date & anOther) const
inline

◆ operator>()

Standard_Boolean Quantity_Date::operator> ( const Quantity_Date & anOther) const
inline

◆ Second()

Standard_Integer Quantity_Date::Second ( )

Returns seconde of a Date.

◆ SetValues()

void Quantity_Date::SetValues ( const Standard_Integer mm,
const Standard_Integer dd,
const Standard_Integer yy,
const Standard_Integer hh,
const Standard_Integer mn,
const Standard_Integer ss,
const Standard_Integer mis = 0,
const Standard_Integer mics = 0 )

Assigns to this date the year yyyy, the month mm, the day dd, the hour hh, the minute mn, the second ss, the millisecond mis (defaulted to 0) and the microsecond mics (defaulted to 0). Exceptions Quantity_DateDefinitionError if mm, dd, hh, mn, ss, mis and mics are not components of a valid date.

◆ Subtract()

Quantity_Date Quantity_Date::Subtract ( const Quantity_Period & aPeriod)

Subtracts a period from a Date and returns the new Date. Raises an exception if the result date is anterior to Jan 1, 1979.

◆ Values()

void Quantity_Date::Values ( Standard_Integer & mm,
Standard_Integer & dd,
Standard_Integer & yy,
Standard_Integer & hh,
Standard_Integer & mn,
Standard_Integer & ss,
Standard_Integer & mis,
Standard_Integer & mics ) const

Gets a complete Date.

  • in mm - the month,
  • in dd - the day,
  • in yyyy - the year,
  • in hh - the hour,
  • in mn - the minute,
  • in ss - the second,
  • in mis - the millisecond, and
  • in mics - the microsecond

◆ Year()

Standard_Integer Quantity_Date::Year ( )

Returns year of a Date.


The documentation for this class was generated from the following file: