123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629 |
- // Copyright 2019 Proyectos y Sistemas de Mantenimiento SL (eProsima).
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- /**
- * @file Time_t.h
- */
- #ifndef _FASTDDS_RTPS_TIME_T_H_
- #define _FASTDDS_RTPS_TIME_T_H_
- #include <fastrtps/fastrtps_dll.h>
- #include <cmath>
- #include <cstdint>
- #include <iostream>
- // defines to avoid the "static initialization order fiasco"
- #define TIME_T_INFINITE_SECONDS 0x7fffffff
- #define TIME_T_INFINITE_NANOSECONDS 0xffffffff
- namespace eprosima {
- namespace fastrtps {
- /**
- * Structure Time_t, used to describe times.
- * @ingroup COMMON_MODULE
- */
- struct RTPS_DllAPI Time_t
- {
- int32_t seconds;
- uint32_t nanosec;
- //! Default constructor. Sets values to zero.
- Time_t();
- /**
- * @param sec Seconds
- * @param nsec Nanoseconds
- */
- Time_t(
- int32_t sec,
- uint32_t nsec);
- /**
- * @param sec Seconds. The fractional part is converted to nanoseconds.
- */
- Time_t(
- long double sec);
- void fraction(
- uint32_t frac);
- uint32_t fraction() const;
- /**
- * Returns stored time as nanoseconds (including seconds)
- */
- int64_t to_ns() const;
- /**
- * Fills a Time_t struct with a representation of the current time.
- *
- * @param ret Reference to the structure to be filled in.
- */
- static void now(
- Time_t& ret);
- };
- using Duration_t = Time_t;
- namespace rtps {
- /**
- * Structure Time_t, used to describe times at RTPS protocol.
- * @ingroup COMMON_MODULE
- */
- class RTPS_DllAPI Time_t
- {
- public:
- //! Default constructor. Sets values to zero.
- Time_t();
- /**
- * @param sec Seconds
- * @param frac Fraction of second
- */
- Time_t(
- int32_t sec,
- uint32_t frac);
- /**
- * @param sec Seconds. The fractional part is converted to nanoseconds.
- */
- Time_t(
- long double sec);
- /**
- * @param time fastrtps::Time_t, aka. Duration_t.
- */
- Time_t(
- const eprosima::fastrtps::Time_t& time);
- /**
- * Returns stored time as nanoseconds (including seconds)
- */
- int64_t to_ns() const;
- /**
- * Retrieve the seconds field.
- */
- int32_t seconds() const;
- /**
- * Retrieve the seconds field by ref.
- */
- int32_t& seconds();
- /**
- * Sets seconds field.
- */
- void seconds(
- int32_t sec);
- /**
- * Retrieve the nanosec field.
- */
- uint32_t nanosec() const;
- /**
- * Sets nanoseconds field and updates the fraction.
- */
- void nanosec(
- uint32_t nanos);
- /**
- * Retrieve the fraction field.
- */
- uint32_t fraction() const;
- /**
- * Sets fraction field and updates the nanoseconds.
- */
- void fraction(
- uint32_t frac);
- Duration_t to_duration_t() const;
- void from_duration_t(const Duration_t& duration);
- /**
- * Fills a Time_t struct with a representation of the current time.
- *
- * @param ret Reference to the structure to be filled in.
- */
- static void now(
- Time_t& ret);
- private:
- //!Seconds
- int32_t seconds_;
- //!Fraction of second (1 fraction = 1/(2^32) seconds)
- uint32_t fraction_;
- //!Nanoseconds
- uint32_t nanosec_;
- void set_fraction(
- uint32_t frac);
- void set_nanosec(
- uint32_t nanos);
- };
- #ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC
- /**
- * Comparison assignment
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if equal
- */
- static inline bool operator==(
- const Time_t& t1,
- const Time_t& t2)
- {
- if(t1.seconds() != t2.seconds())
- {
- return false;
- }
- if(t1.fraction() != t2.fraction())
- {
- return false;
- }
- return true;
- }
- /**
- * Comparison assignment
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if not equal
- */
- static inline bool operator!=(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds() != t2.seconds())
- {
- return true;
- }
- if (t1.fraction() != t2.fraction())
- {
- return true;
- }
- return false;
- }
- /**
- * Checks if a Time_t is less than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is less than the second
- */
- static inline bool operator<(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds() < t2.seconds())
- {
- return true;
- }
- else if (t1.seconds() > t2.seconds())
- {
- return false;
- }
- else
- {
- if (t1.fraction() < t2.fraction())
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- /**
- * Checks if a Time_t is greather than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is greather than the second
- */
- static inline bool operator>(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds() > t2.seconds())
- {
- return true;
- }
- else if (t1.seconds() < t2.seconds())
- {
- return false;
- }
- else
- {
- if (t1.fraction() > t2.fraction())
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- /**
- * Checks if a Time_t is less or equal than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is less or equal than the second
- */
- static inline bool operator<=(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds() < t2.seconds())
- {
- return true;
- }
- else if (t1.seconds() > t2.seconds())
- {
- return false;
- }
- else
- {
- if (t1.fraction() <= t2.fraction())
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- /**
- * Checks if a Time_t is greather or equal than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is greather or equal than the second
- */
- static inline bool operator>=(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds() > t2.seconds())
- {
- return true;
- }
- else if (t1.seconds() < t2.seconds())
- {
- return false;
- }
- else
- {
- if (t1.fraction() >= t2.fraction())
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- inline std::ostream& operator<<(
- std::ostream& output,
- const Time_t& t)
- {
- long double t_aux = t.seconds() + (((long double)t.nanosec()) / 1000000000ULL);
- return output << t_aux;
- }
- /**
- * Adds two Time_t.
- * @param ta First Time_t to add
- * @param tb Second Time_t to add
- * @return A new Time_t with the result.
- */
- static inline Time_t operator+(
- const Time_t &ta,
- const Time_t &tb)
- {
- Time_t result(ta.seconds() + tb.seconds(), ta.fraction() + tb.fraction());
- if (result.fraction() < ta.fraction()) // Overflow is detected by any of them
- {
- ++result.seconds();
- }
- return result;
- }
- /**
- * Substracts two Time_t.
- * @param ta First Time_t to substract
- * @param tb Second Time_t to substract
- * @return A new Time_t with the result.
- */
- static inline Time_t operator-(
- const Time_t &ta,
- const Time_t &tb)
- {
- Time_t result(ta.seconds() - tb.seconds(), ta.fraction() - tb.fraction());
- if (result.fraction() > ta.fraction()) // Overflow is detected by ta
- {
- --result.seconds();
- }
- return result;
- }
- #endif
- const Time_t c_RTPSTimeInfinite(0x7fffffff,0xffffffff);
- const Time_t c_RTPSTimeZero(0,0);
- const Time_t c_RTPSTimeInvalid(-1,0xffffffff);
- } // namespace rtps
- #ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC
- /**
- * Comparison assignment
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if equal
- */
- static inline bool operator==(
- const Time_t& t1,
- const Time_t& t2)
- {
- if(t1.seconds != t2.seconds)
- {
- return false;
- }
- if(t1.nanosec != t2.nanosec)
- {
- return false;
- }
- return true;
- }
- /**
- * Comparison assignment
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if not equal
- */
- static inline bool operator!=(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds != t2.seconds)
- {
- return true;
- }
- if (t1.nanosec != t2.nanosec)
- {
- return true;
- }
- return false;
- }
- /**
- * Checks if a Time_t is less than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is less than the second
- */
- static inline bool operator<(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds < t2.seconds)
- {
- return true;
- }
- else if (t1.seconds > t2.seconds)
- {
- return false;
- }
- else
- {
- if (t1.nanosec < t2.nanosec)
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- /**
- * Checks if a Time_t is greather than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is greather than the second
- */
- static inline bool operator>(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds > t2.seconds)
- {
- return true;
- }
- else if (t1.seconds < t2.seconds)
- {
- return false;
- }
- else
- {
- if (t1.nanosec > t2.nanosec)
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- /**
- * Checks if a Time_t is less or equal than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is less or equal than the second
- */
- static inline bool operator<=(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds < t2.seconds)
- {
- return true;
- }
- else if (t1.seconds > t2.seconds)
- {
- return false;
- }
- else
- {
- if (t1.nanosec <= t2.nanosec)
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- /**
- * Checks if a Time_t is greather or equal than other.
- * @param t1 First Time_t to compare
- * @param t2 Second Time_t to compare
- * @return True if the first Time_t is greather or equal than the second
- */
- static inline bool operator>=(
- const Time_t& t1,
- const Time_t& t2)
- {
- if (t1.seconds > t2.seconds)
- {
- return true;
- }
- else if (t1.seconds < t2.seconds)
- {
- return false;
- }
- else
- {
- if (t1.nanosec >= t2.nanosec)
- {
- return true;
- }
- else
- {
- return false;
- }
- }
- }
- inline std::ostream& operator<<(
- std::ostream& output,
- const Time_t& t)
- {
- long double t_aux = t.seconds + (((long double)t.nanosec) / 1000000000ULL);
- return output << t_aux;
- }
- /**
- * Adds two Time_t.
- * @param ta First Time_t to add
- * @param tb Second Time_t to add
- * @return A new Time_t with the result.
- */
- static inline Time_t operator+(
- const Time_t &ta,
- const Time_t &tb)
- {
- Time_t result(ta.seconds + tb.seconds, ta.nanosec + tb.nanosec);
- if (result.nanosec < ta.nanosec) // Overflow is detected by any of them
- {
- ++result.seconds;
- }
- return result;
- }
- /**
- * Substracts two Time_t.
- * @param ta First Time_t to substract
- * @param tb Second Time_t to substract
- * @return A new Time_t with the result.
- */
- static inline Time_t operator-(
- const Time_t &ta,
- const Time_t &tb)
- {
- Time_t result(ta.seconds - tb.seconds, ta.nanosec - tb.nanosec);
- if (result.nanosec > ta.nanosec) // Overflow is detected by ta
- {
- --result.seconds;
- }
- return result;
- }
- #endif
- //! Time_t (Duration_t) representing an infinite time. DONT USE IT IN CONSTRUCTORS
- const Time_t c_TimeInfinite(TIME_T_INFINITE_SECONDS, TIME_T_INFINITE_NANOSECONDS);
- //! Time_t (Duration_t) representing a zero time. DONT USE IT IN CONSTRUCTORS
- const Time_t c_TimeZero(0,0);
- //! Time_t (Duration_t) representing an invalid time. DONT USE IT IN CONSTRUCTORS
- const Time_t c_TimeInvalid(-1, TIME_T_INFINITE_NANOSECONDS);
- } // namespace fastrtps
- } // namespace eprosima
- #endif /* _FASTDDS_RTPS_TIME_T_H_ */
|