1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-06-10 11:34:06 +03:00
occt/src/Quantity/Quantity_Period.hxx
kgv 09324e85c8 0028799: Coding Rules - elimilate confusing Quantity aliases of Standard_Real type
Aliases to Standard_Real within Quantity package have been marked as deprecated.
2017-06-15 11:35:37 +03:00

148 lines
5.5 KiB
C++

// Created on: 1993-01-04
// Created by: J.P. BOUDIER - J.P. TIRAULT
// Copyright (c) 1993-1999 Matra Datavision
// Copyright (c) 1999-2014 OPEN CASCADE SAS
//
// This file is part of Open CASCADE Technology software library.
//
// This library is free software; you can redistribute it and/or modify it under
// the terms of the GNU Lesser General Public License version 2.1 as published
// by the Free Software Foundation, with special exception defined in the file
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
// distribution for complete text of the license and disclaimer of any warranty.
//
// Alternatively, this file may be used under the terms of Open CASCADE
// commercial license or contractual agreement.
#ifndef _Quantity_Period_HeaderFile
#define _Quantity_Period_HeaderFile
#include <Standard.hxx>
#include <Standard_DefineAlloc.hxx>
#include <Standard_Handle.hxx>
#include <Standard_Integer.hxx>
#include <Standard_Boolean.hxx>
class Quantity_PeriodDefinitionError;
//! Manages date intervals. For example, a Period object
//! gives the interval between two dates.
//! A period is expressed in seconds and microseconds.
class Quantity_Period
{
public:
DEFINE_STANDARD_ALLOC
//! Creates a Period
//! With: 0 <= dd
//! 0 <= hh
//! 0 <= mn
//! 0 <= ss
//! 0 <= mis
//! 0 <= mics
Standard_EXPORT Quantity_Period(const Standard_Integer dd, const Standard_Integer hh, const Standard_Integer mn, const Standard_Integer ss, const Standard_Integer mis = 0, const Standard_Integer mics = 0);
//! Creates a Period with a number of seconds and microseconds.
//! Exceptions
//! Quantity_PeriodDefinitionError:
//! - if the number of seconds expressed either by:
//! - dd days, hh hours, mn minutes and ss seconds, or
//! - Ss
//! is less than 0.
//! - if the number of microseconds expressed either by:
//! - mis milliseconds and mics microseconds, or
//! - Mics
//! is less than 0.
Standard_EXPORT Quantity_Period(const Standard_Integer ss, const Standard_Integer mics = 0);
//! Decomposes this period into a number of days,hours,
//! minutes,seconds,milliseconds and microseconds
//! Example of return values:
//! 2 days, 15 hours, 0 minute , 0 second
//! 0 millisecond and 0 microsecond
Standard_EXPORT void Values (Standard_Integer& dd, Standard_Integer& hh, Standard_Integer& mn, Standard_Integer& ss, Standard_Integer& mis, Standard_Integer& mics) const;
//! Returns the number of seconds in Ss and the
//! number of remainding microseconds in Mics of this period.
//! Example of return values: 3600 seconds and 0 microseconds
Standard_EXPORT void Values (Standard_Integer& ss, Standard_Integer& mics) const;
//! Assigns to this period the time interval defined
//! - with dd days, hh hours, mn minutes, ss
//! seconds, mis (defaulted to 0) milliseconds and
//! mics (defaulted to 0) microseconds; or
Standard_EXPORT void SetValues (const Standard_Integer dd, 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 period the time interval defined
//! - with Ss seconds and Mics (defaulted to 0) microseconds.
//! Exceptions
//! Quantity_PeriodDefinitionError:
//! - if the number of seconds expressed either by:
//! - dd days, hh hours, mn minutes and ss seconds, or
//! - Ss
//! is less than 0.
//! - if the number of microseconds expressed either by:
//! - mis milliseconds and mics microseconds, or
//! - Mics
//! is less than 0.
Standard_EXPORT void SetValues (const Standard_Integer ss, const Standard_Integer mics = 0);
//! Subtracts one Period from another and returns the difference.
Standard_EXPORT Quantity_Period Subtract (const Quantity_Period& anOther) const;
Quantity_Period operator - (const Quantity_Period& anOther) const
{
return Subtract(anOther);
}
//! Adds one Period to another one.
Standard_EXPORT Quantity_Period Add (const Quantity_Period& anOther) const;
Quantity_Period operator + (const Quantity_Period& anOther) const
{
return Add(anOther);
}
//! Returns TRUE if both <me> and <other> are equal.
Standard_EXPORT Standard_Boolean IsEqual (const Quantity_Period& anOther) const;
Standard_Boolean operator == (const Quantity_Period& anOther) const
{
return IsEqual(anOther);
}
//! Returns TRUE if <me> is shorter than <other>.
Standard_EXPORT Standard_Boolean IsShorter (const Quantity_Period& anOther) const;
Standard_Boolean operator < (const Quantity_Period& anOther) const
{
return IsShorter(anOther);
}
//! Returns TRUE if <me> is longer then <other>.
Standard_EXPORT Standard_Boolean IsLonger (const Quantity_Period& anOther) const;
Standard_Boolean operator > (const Quantity_Period& anOther) const
{
return IsLonger(anOther);
}
//! Checks the validity of a Period in form (dd,hh,mn,ss,mil,mic)
//! With: 0 <= dd
//! 0 <= hh
//! 0 <= mn
//! 0 <= ss
//! 0 <= mis
//! 0 <= mics
Standard_EXPORT static Standard_Boolean IsValid (const Standard_Integer dd, 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 Period in form (ss,mic)
//! With: 0 <= ss
//! 0 <= mics
Standard_EXPORT static Standard_Boolean IsValid (const Standard_Integer ss, const Standard_Integer mics = 0);
private:
Standard_Integer mySec;
Standard_Integer myUSec;
};
#endif // _Quantity_Period_HeaderFile