mirror of
				https://github.com/VCMP-SqMod/SqMod.git
				synced 2025-10-25 12:27:18 +02:00 
			
		
		
		
	Compare commits
	
		
			15 Commits
		
	
	
		
			4090b558ad
			...
			151077c799
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 151077c799 | ||
|  | a99e926088 | ||
|  | 490f80d1e9 | ||
|  | 1d2a78c91e | ||
|  | f23a8bc8f5 | ||
|  | 11f3c52319 | ||
|  | 2b1c76a05d | ||
|  | a36e85d9b7 | ||
|  | 2fb0f851c0 | ||
|  | 7655c1cb98 | ||
|  | 9d62233cfc | ||
|  | 503b61c3df | ||
|  | 181b0f4377 | ||
|  | cb359ed61e | ||
|  | ec01a80486 | 
| @@ -264,7 +264,12 @@ struct AABB | ||||
|     */ | ||||
|     SQMOD_NODISCARD int32_t Cmp(SQFloat s) const | ||||
|     { | ||||
| #ifdef SQUSEDOUBLE | ||||
|         auto f = static_cast< Value >(s); | ||||
|         return Cmp(AABB(f, f, f, f, f, f)); | ||||
| #else | ||||
|         return Cmp(AABB(s, s, s, s, s, s)); | ||||
| #endif | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|   | ||||
| @@ -476,16 +476,16 @@ Array Circle::ToPointsArray(SQInteger num_segments) const | ||||
|         if (i >= num_segments) return false; | ||||
|         // Get the current angle | ||||
| #ifdef SQUSEDOUBLE | ||||
|         SQFloat theta = 2.0d * SQMOD_PI64 * static_cast< SQFloat >(i) / static_cast< SQFloat >(num_segments); | ||||
|         SQFloat theta = 2.0 * SQMOD_PI64 * static_cast< SQFloat >(i) / static_cast< SQFloat >(num_segments); | ||||
| #else | ||||
|         SQFloat theta = 2.0f * SQMOD_PI * static_cast< SQFloat >(i) / static_cast< SQFloat >(num_segments); | ||||
| #endif // SQUSEDOUBLE | ||||
|         // Calculate the x component | ||||
|         SQFloat x = (rad * cosf(theta)) + pos.x; | ||||
|         SQFloat x = (rad * std::cos(theta)) + pos.x; | ||||
|         // Calculate the y component | ||||
|         SQFloat y = (rad * sinf(theta)) + pos.y; | ||||
|         SQFloat y = (rad * std::sin(theta)) + pos.y; | ||||
|         // Push the Vector2 instance on the stack | ||||
|         Var< Vector2 >::push(vm, Vector2{x, y}); | ||||
|         Var< Vector2 >::push(vm, Vector2{static_cast< Vector2::Value >(x), static_cast< Vector2::Value >(y)}); | ||||
|         // Insert the element on the stack into the array | ||||
|         return true; | ||||
|     }, num_segments); | ||||
|   | ||||
| @@ -807,7 +807,7 @@ static SQInteger SqPackARGB(SQInteger r, SQInteger g, SQInteger b, SQInteger a) | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| static SQInteger SqNameFilterCheck(HSQUIRRELVM vm) | ||||
| { | ||||
|     const int32_t top = sq_gettop(vm); | ||||
|     SQInteger top = sq_gettop(vm); | ||||
|     // Was the filter string specified? | ||||
|     if (top <= 1) | ||||
|     { | ||||
| @@ -1031,7 +1031,7 @@ const String CmpGE::FSTRV("Assertion failed. Value mismatch: {0} >= {1}"); // NO | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| static SQInteger SqNameFilterCheckInsensitive(HSQUIRRELVM vm) | ||||
| { | ||||
|     const int32_t top = sq_gettop(vm); | ||||
|     SQInteger top = sq_gettop(vm); | ||||
|     // Was the filter string specified? | ||||
|     if (top <= 1) | ||||
|     { | ||||
|   | ||||
| @@ -53,7 +53,7 @@ void Area::AddCircleEx(SQFloat cx, SQFloat cy, SQFloat cr, SQInteger num_segment | ||||
|         CheckLock(); | ||||
|         // Get the current angle | ||||
| #ifdef SQUSEDOUBLE | ||||
|         SQFloat theta = 2.0d * SQMOD_PI64 * static_cast< SQFloat >(i) / static_cast< SQFloat >(num_segments); | ||||
|         SQFloat theta = 2.0 * SQMOD_PI64 * static_cast< SQFloat >(i) / static_cast< SQFloat >(num_segments); | ||||
| #else | ||||
|         SQFloat theta = 2.0f * SQMOD_PI * static_cast< SQFloat >(i) / static_cast< SQFloat >(num_segments); | ||||
| #endif // SQUSEDOUBLE | ||||
| @@ -62,9 +62,9 @@ void Area::AddCircleEx(SQFloat cx, SQFloat cy, SQFloat cr, SQInteger num_segment | ||||
|         // Calculate the y component | ||||
|         SQFloat y = (cr * std::sin(theta)) + cy; | ||||
|         // Insert the point into the list | ||||
|         mPoints.emplace_back(x, y); | ||||
|         mPoints.emplace_back(static_cast< Vector2::Value >(x), static_cast< Vector2::Value >(y)); | ||||
|         // Update the bounding box | ||||
|         Expand(x, y); | ||||
|         Expand(static_cast< Vector2::Value >(x), static_cast< Vector2::Value >(y)); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -171,7 +171,7 @@ void OutputMessage(const char * msg, ...); | ||||
| void OutputError(const char * msg, ...); | ||||
|  | ||||
| /* ------------------------------------------------------------------------------------------------ | ||||
|  * Generate a formatted string and throw it as a sqrat exception. | ||||
|  * Generate a formatted string and throw it as a Sqrat exception. | ||||
| */ | ||||
| template < class... Args > void SqThrowF(Args &&... args) | ||||
| { | ||||
|   | ||||
| @@ -1743,7 +1743,7 @@ void Core::EmitEntityPool(vcmpEntityPool entity_type, int32_t entity_id, bool is | ||||
|         break; | ||||
|         case vcmpEntityPoolRadio: | ||||
|             // @TODO Implement... | ||||
|         //break; | ||||
|         break; | ||||
| #if SQMOD_SDK_LEAST(2, 1) | ||||
|         case vcmpEntityPoolPlayer: | ||||
|             // @TODO Implement... | ||||
|   | ||||
| @@ -31,6 +31,8 @@ template < class Key, class T, class Pred = std::equal_to< Key > > struct VecMap | ||||
|     using difference_type       = typename storage_type::difference_type; | ||||
|     using iterator              = typename storage_type::iterator; | ||||
|     using const_iterator        = typename storage_type::const_iterator; | ||||
|     using reverse_iterator          = typename storage_type::reverse_iterator; | ||||
|     using const_reverse_iterator    = typename storage_type::const_reverse_iterator; | ||||
|     using insert_return_type    = std::pair< iterator, pointer >; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
| @@ -100,12 +102,12 @@ template < class Key, class T, class Pred = std::equal_to< Key > > struct VecMap | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Retrieve a reverse iterator to the beginning (const). See: std::vector::[c]rbegin() | ||||
|     */ | ||||
|     const_iterator rbegin() const noexcept { return m_Storage.rbegin(); } | ||||
|     reverse_iterator rbegin() const noexcept { return m_Storage.rbegin(); } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Retrieve a reverse iterator to the beginning (const). See: std::vector::crbegin() | ||||
|     */ | ||||
|     const_iterator crbegin() const noexcept { return m_Storage.crbegin(); } | ||||
|     const_reverse_iterator crbegin() const noexcept { return m_Storage.crbegin(); } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Retrieve a reverse iterator to the beginning. See: std::vector::rend() | ||||
| @@ -115,12 +117,12 @@ template < class Key, class T, class Pred = std::equal_to< Key > > struct VecMap | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Retrieve a reverse iterator to the beginning (const). See: std::vector::[c]rend() | ||||
|     */ | ||||
|     const_iterator rend() const noexcept { return m_Storage.rend(); } | ||||
|     reverse_iterator rend() const noexcept { return m_Storage.rend(); } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Retrieve a reverse iterator to the beginning (const). See: std::vector::crend() | ||||
|     */ | ||||
|     const_iterator crend() const noexcept { return m_Storage.crend(); } | ||||
|     const_reverse_iterator crend() const noexcept { return m_Storage.crend(); } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Check if elements are stored in the container. | ||||
|   | ||||
| @@ -3,6 +3,9 @@ | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| #include "Core/Common.hpp" | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| #include <ctime> | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| namespace SqMod { | ||||
|  | ||||
|   | ||||
| @@ -12,6 +12,19 @@ SQMOD_DECL_TYPENAME(Typename, _SC("SqDate")) | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| SQChar Date::Delimiter = '-'; | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Date::Date(int64_t ts) | ||||
|     : Date() | ||||
| { | ||||
|     const auto y = static_cast< uint16_t >(std::lround(std::floor(ts / 3.17098e-14))); | ||||
|     ts -= int64_t{y} * 3.17098e-14; | ||||
|     const auto m = static_cast< uint8_t >(std::lround(std::floor(ts / 2.628e+12))); | ||||
|     ts -= int64_t{m} * 2.628e+12; | ||||
|     const auto d = static_cast< uint8_t >(std::lround(std::floor(ts / 8.64e+10))); | ||||
|     // Set the specified date | ||||
|     Set(y, m, d); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| int32_t Date::Compare(const Date & o) const | ||||
| { | ||||
| @@ -363,6 +376,12 @@ Timestamp Date::GetTimestamp() const | ||||
|     return Timestamp(static_cast< int64_t >(days * 86400000000LL)); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| std::time_t Date::ToTimeT() const | ||||
| { | ||||
|     return GetTimestamp().ToTimeT(); | ||||
| } | ||||
|  | ||||
| // ================================================================================================ | ||||
| void Register_ChronoDate(HSQUIRRELVM vm, Table & /*cns*/) | ||||
| { | ||||
|   | ||||
| @@ -83,6 +83,11 @@ public: | ||||
|         SetStr(str); | ||||
|     } | ||||
|  | ||||
|     /* ------------------------------------------------------------------------------------------------ | ||||
|      * Time-stamp constructor. | ||||
|     */ | ||||
|     explicit Date(int64_t ts); | ||||
|  | ||||
|     /* ------------------------------------------------------------------------------------------------ | ||||
|      * Copy constructor. | ||||
|     */ | ||||
| @@ -349,6 +354,11 @@ public: | ||||
|      * Convert this date instance to a time-stamp. | ||||
|     */ | ||||
|     SQMOD_NODISCARD Timestamp GetTimestamp() const; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     std::time_t ToTimeT() const; | ||||
| }; | ||||
|  | ||||
| } // Namespace:: SqMod | ||||
|   | ||||
| @@ -16,6 +16,26 @@ SQChar Datetime::Delimiter = ' '; | ||||
| SQChar Datetime::DateDelim = '-'; | ||||
| SQChar Datetime::TimeDelim = ':'; | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Datetime::Datetime(int64_t ts) | ||||
|     : Datetime() | ||||
| { | ||||
|     const auto y = static_cast< uint16_t >(std::lround(std::floor(ts / 3.17098e-14))); | ||||
|     ts -= int64_t{y} * 3.17098e-14; | ||||
|     const auto mo = static_cast< uint8_t >(std::lround(std::floor(ts / 2.628e+12))); | ||||
|     ts -= int64_t{mo} * 2.628e+12; | ||||
|     const auto d = static_cast< uint8_t >(std::lround(std::floor(ts / 8.64e+10))); | ||||
|     ts -= int64_t{d} * 8.64e+10; | ||||
|     const auto h = static_cast< uint8_t >(std::lround(std::floor(ts / 3.6e+9))); | ||||
|     ts -= int64_t{h} * 3.6e+9; | ||||
|     const auto mi = static_cast< uint8_t >(std::lround(std::floor(ts / 6e+7))); | ||||
|     ts -= int64_t{mi} * 6e+7; | ||||
|     const auto s = static_cast< uint8_t >(std::lround(std::floor(ts / 1e+6))); | ||||
|     ts -= int64_t{s} * 1e+6; | ||||
|     // Set the specified date-time | ||||
|     Set(y, mo, d, h, mi, s, static_cast< uint16_t >(ts / 1000LL)); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| int32_t Datetime::Compare(const Datetime & o) const | ||||
| { | ||||
| @@ -745,6 +765,12 @@ Timestamp Datetime::GetTimestamp() const | ||||
|     return Timestamp(ms); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| std::time_t Datetime::ToTimeT() const | ||||
| { | ||||
|     return GetTimestamp().ToTimeT(); | ||||
| } | ||||
|  | ||||
| // ================================================================================================ | ||||
| void Register_ChronoDatetime(HSQUIRRELVM vm, Table & /*cns*/) | ||||
| { | ||||
|   | ||||
| @@ -140,6 +140,11 @@ public: | ||||
|         Set(year, month, day, hour, minute, second, millisecond); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Time-stamp constructor. | ||||
|     */ | ||||
|     explicit Datetime(int64_t ts); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * Copy constructor. | ||||
|     */ | ||||
| @@ -572,6 +577,11 @@ public: | ||||
|      * Convert this date-time instance to a time-stamp. | ||||
|     */ | ||||
|     SQMOD_NODISCARD Timestamp GetTimestamp() const; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     std::time_t ToTimeT() const; | ||||
| }; | ||||
|  | ||||
| } // Namespace:: SqMod | ||||
|   | ||||
| @@ -12,6 +12,20 @@ SQMOD_DECL_TYPENAME(Typename, _SC("SqTime")) | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| SQChar Time::Delimiter = ':'; | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Time::Time(int64_t ts) | ||||
|     : Time() | ||||
| { | ||||
|     const auto h = static_cast< uint8_t >(std::lround(std::floor(ts / 3.6e+9))); | ||||
|     ts -= int64_t{h} * 3.6e+9; | ||||
|     const auto m = static_cast< uint8_t >(std::lround(std::floor(ts / 6e+7))); | ||||
|     ts -= int64_t{m} * 6e+7; | ||||
|     const auto s = static_cast< uint8_t >(std::lround(std::floor(ts / 1e+6))); | ||||
|     ts -= int64_t{s} * 1e+6; | ||||
|     // Set the specified time | ||||
|     Set(h, m, s, static_cast< uint16_t >(ts / 1000LL)); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| int32_t Time::Compare(const Time & o) const | ||||
| { | ||||
| @@ -410,6 +424,12 @@ Timestamp Time::GetTimestamp() const | ||||
|     return Timestamp(ms); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| std::time_t Time::ToTimeT() const | ||||
| { | ||||
|     return GetTimestamp().ToTimeT(); | ||||
| } | ||||
|  | ||||
| // ================================================================================================ | ||||
| void Register_ChronoTime(HSQUIRRELVM vm, Table & /*cns*/) | ||||
| { | ||||
|   | ||||
| @@ -26,10 +26,10 @@ protected: | ||||
| private: | ||||
|  | ||||
|     // ------------------------------------------------------------------------------------------------ | ||||
|     uint8_t   m_Hour{}; // Hour | ||||
|     uint8_t   m_Minute{}; // Minute | ||||
|     uint8_t   m_Second{}; // Second | ||||
|     uint16_t  m_Millisecond{}; // Millisecond | ||||
|     uint8_t   m_Hour{0}; // Hour | ||||
|     uint8_t   m_Minute{0}; // Minute | ||||
|     uint8_t   m_Second{0}; // Second | ||||
|     uint16_t  m_Millisecond{0}; // Millisecond | ||||
|  | ||||
|     // ------------------------------------------------------------------------------------------------ | ||||
|     SQChar  m_Delimiter; // Component delimiter when generating strings. | ||||
| @@ -94,6 +94,11 @@ public: | ||||
|         SetStr(str); | ||||
|     } | ||||
|  | ||||
|     /* ------------------------------------------------------------------------------------------------ | ||||
|      * Time-stamp constructor. | ||||
|     */ | ||||
|     explicit Time(int64_t ts); | ||||
|  | ||||
|     /* ------------------------------------------------------------------------------------------------ | ||||
|      * Copy constructor. | ||||
|     */ | ||||
| @@ -354,6 +359,11 @@ public: | ||||
|      * Convert this time instance to a time-stamp. | ||||
|     */ | ||||
|     SQMOD_NODISCARD Timestamp GetTimestamp() const; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     std::time_t ToTimeT() const; | ||||
| }; | ||||
|  | ||||
| } // Namespace:: SqMod | ||||
|   | ||||
| @@ -1,9 +1,14 @@ | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| #include "Library/Chrono/Timestamp.hpp" | ||||
| #include "Library/Chrono/Timer.hpp" | ||||
| #include "Library/Chrono/Time.hpp" | ||||
| #include "Library/Chrono/Date.hpp" | ||||
| #include "Library/Chrono/Datetime.hpp" | ||||
| #include "Library/Numeric/Long.hpp" | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| #include <chrono> | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| namespace SqMod { | ||||
|  | ||||
| @@ -58,6 +63,10 @@ void Timestamp::SetMicroseconds(const SLongInt & amount) | ||||
|     m_Timestamp = amount.GetNum(); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::AddMicroseconds(const SLongInt & amount) { m_Timestamp += amount.GetNum(); return *this; } | ||||
| Timestamp & Timestamp::SubMicroseconds(const SLongInt & amount) { m_Timestamp -= amount.GetNum(); return *this; } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| SLongInt Timestamp::GetMilliseconds() const | ||||
| { | ||||
| @@ -70,6 +79,127 @@ void Timestamp::SetMilliseconds(const SLongInt & amount) | ||||
|     m_Timestamp = (amount.GetNum() * 1000L); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::AddMilliseconds(const SLongInt & amount) { m_Timestamp += (amount.GetNum() * 1000L); return *this; } | ||||
| Timestamp & Timestamp::SubMilliseconds(const SLongInt & amount) { m_Timestamp -= (amount.GetNum() * 1000L); return *this; } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Time Timestamp::GetTime() const | ||||
| { | ||||
|     return Time(m_Timestamp); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| void Timestamp::SetTime(const Time & t) | ||||
| { | ||||
|     SetHoursI(t.GetHour()); | ||||
|     AddMinutesI(t.GetMinute()); | ||||
|     AddSecondsI(t.GetSecond()); | ||||
|     AddMillisecondsRaw(t.GetMillisecond()); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::AddTime(const Time & t) | ||||
| { | ||||
|     AddHoursI(t.GetHour()); | ||||
|     AddMinutesI(t.GetMinute()); | ||||
|     AddSecondsI(t.GetSecond()); | ||||
|     AddMillisecondsRaw(t.GetMillisecond()); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::SubTime(const Time & t) | ||||
| { | ||||
|     SubMillisecondsRaw(t.GetMillisecond()); | ||||
|     SubSecondsI(t.GetSecond()); | ||||
|     SubMinutesI(t.GetMinute()); | ||||
|     SubHoursI(t.GetHour()); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Date Timestamp::GetDate() const | ||||
| { | ||||
|     return Date(m_Timestamp); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| void Timestamp::SetDate(const Date & d) | ||||
| { | ||||
|     SetYearsI(d.GetYear()); | ||||
|     AddDaysF(d.GetMonth() * 30.4167); | ||||
|     AddDaysI(d.GetDay()); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::AddDate(const Date & d) | ||||
| { | ||||
|     AddYearsI(d.GetYear()); | ||||
|     AddDaysF(d.GetMonth() * 30.4167); | ||||
|     AddDaysI(d.GetDay()); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::SubDate(const Date & d) | ||||
| { | ||||
|     SubDaysI(d.GetDay()); | ||||
|     SubDaysF(d.GetMonth() * 30.4167); | ||||
|     SubYearsI(d.GetYear()); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Datetime Timestamp::GetDatetime() const | ||||
| { | ||||
|     return Datetime(m_Timestamp); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| void Timestamp::SetDatetime(const Datetime & dt) | ||||
| { | ||||
|     SetYearsI(dt.GetYear()); | ||||
|     AddDaysF(dt.GetMonth() * 30.4167); | ||||
|     AddDaysI(dt.GetDay()); | ||||
|     AddHoursI(dt.GetHour()); | ||||
|     AddMinutesI(dt.GetMinute()); | ||||
|     AddSecondsI(dt.GetSecond()); | ||||
|     AddMillisecondsRaw(dt.GetMillisecond()); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::AddDatetime(const Datetime & dt) | ||||
| { | ||||
|     AddYearsI(dt.GetYear()); | ||||
|     AddDaysF(dt.GetMonth() * 30.4167); | ||||
|     AddDaysI(dt.GetDay()); | ||||
|     AddHoursI(dt.GetHour()); | ||||
|     AddMinutesI(dt.GetMinute()); | ||||
|     AddSecondsI(dt.GetSecond()); | ||||
|     AddMillisecondsRaw(dt.GetMillisecond()); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| Timestamp & Timestamp::SubDatetime(const Datetime & dt) | ||||
| { | ||||
|     SubMillisecondsRaw(dt.GetMillisecond()); | ||||
|     SubSecondsI(dt.GetSecond()); | ||||
|     SubMinutesI(dt.GetMinute()); | ||||
|     SubHoursI(dt.GetHour()); | ||||
|     SubDaysI(dt.GetDay()); | ||||
|     SubDaysF(dt.GetMonth() * 30.4167); | ||||
|     SubYearsI(dt.GetYear()); | ||||
|     return *this; | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| std::time_t Timestamp::ToTimeT() const | ||||
| { | ||||
|     return std::chrono::system_clock::to_time_t(std::chrono::time_point< std::chrono::system_clock >{std::chrono::microseconds{m_Timestamp}}); | ||||
| } | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| static Timestamp SqGetEpochTimeNow() | ||||
| { | ||||
| @@ -156,8 +286,46 @@ void Register_ChronoTimestamp(HSQUIRRELVM vm, Table & /*cns*/) | ||||
|         .Prop(_SC("DaysI"), &Timestamp::GetDaysI, &Timestamp::SetDaysI) | ||||
|         .Prop(_SC("YearsF"), &Timestamp::GetYearsF, &Timestamp::SetYearsF) | ||||
|         .Prop(_SC("YearsI"), &Timestamp::GetYearsI, &Timestamp::SetYearsI) | ||||
|         .Prop(_SC("Time"), &Timestamp::GetTime, &Timestamp::SetTime) | ||||
|         .Prop(_SC("Date"), &Timestamp::GetDate, &Timestamp::SetDate) | ||||
|         .Prop(_SC("Datetime"), &Timestamp::GetDatetime, &Timestamp::SetDatetime) | ||||
|         // Member Methods | ||||
|         .Func(_SC("SetNow"), &Timestamp::SetNow) | ||||
|         // Properties | ||||
|         .Func(_SC("AddMicroseconds"), &Timestamp::AddMicroseconds) | ||||
|         .Func(_SC("SubMicroseconds"), &Timestamp::SubMicroseconds) | ||||
|         .Func(_SC("AddMicrosecondsRaw"), &Timestamp::AddMicrosecondsRaw) | ||||
|         .Func(_SC("SubMicrosecondsRaw"), &Timestamp::SubMicrosecondsRaw) | ||||
|         .Func(_SC("AddMilliseconds"), &Timestamp::AddMilliseconds) | ||||
|         .Func(_SC("SubMilliseconds"), &Timestamp::SubMilliseconds) | ||||
|         .Func(_SC("AddMillisecondsRaw"), &Timestamp::AddMillisecondsRaw) | ||||
|         .Func(_SC("SubMillisecondsRaw"), &Timestamp::SubMillisecondsRaw) | ||||
|         .Func(_SC("AddSecondsF"), &Timestamp::AddSecondsF) | ||||
|         .Func(_SC("SubSecondsF"), &Timestamp::SubSecondsF) | ||||
|         .Func(_SC("AddSecondsI"), &Timestamp::AddSecondsI) | ||||
|         .Func(_SC("SubSecondsI"), &Timestamp::SubSecondsI) | ||||
|         .Func(_SC("AddMinutesF"), &Timestamp::AddMinutesF) | ||||
|         .Func(_SC("SubMinutesF"), &Timestamp::SubMinutesF) | ||||
|         .Func(_SC("AddMinutesI"), &Timestamp::AddMinutesI) | ||||
|         .Func(_SC("SubMinutesI"), &Timestamp::SubMinutesI) | ||||
|         .Func(_SC("AddHoursF"), &Timestamp::AddHoursF) | ||||
|         .Func(_SC("SubHoursF"), &Timestamp::SubHoursF) | ||||
|         .Func(_SC("AddHoursI"), &Timestamp::AddHoursI) | ||||
|         .Func(_SC("SubHoursI"), &Timestamp::SubHoursI) | ||||
|         .Func(_SC("AddDaysF"), &Timestamp::AddDaysF) | ||||
|         .Func(_SC("SubDaysF"), &Timestamp::SubDaysF) | ||||
|         .Func(_SC("AddDaysI"), &Timestamp::AddDaysI) | ||||
|         .Func(_SC("SubDaysI"), &Timestamp::SubDaysI) | ||||
|         .Func(_SC("AddYearsF"), &Timestamp::AddYearsF) | ||||
|         .Func(_SC("SubYearsF"), &Timestamp::SubYearsF) | ||||
|         .Func(_SC("AddYearsI"), &Timestamp::AddYearsI) | ||||
|         .Func(_SC("SubYearsI"), &Timestamp::SubYearsI) | ||||
|         .Func(_SC("AddTime"), &Timestamp::AddTime) | ||||
|         .Func(_SC("SubTime"), &Timestamp::SubTime) | ||||
|         .Func(_SC("AddDate"), &Timestamp::AddDate) | ||||
|         .Func(_SC("SubDate"), &Timestamp::SubDate) | ||||
|         .Func(_SC("AddDatetime"), &Timestamp::AddDatetime) | ||||
|         .Func(_SC("SubDatetime"), &Timestamp::SubDatetime) | ||||
|         // Static Functions | ||||
|         .StaticFunc(_SC("GetNow"), &SqGetEpochTimeNow) | ||||
|         .StaticFunc(_SC("GetMicrosRaw"), &SqGetMicrosecondsRaw) | ||||
|   | ||||
| @@ -7,7 +7,10 @@ | ||||
| namespace SqMod { | ||||
|  | ||||
| // ------------------------------------------------------------------------------------------------ | ||||
| class Date; | ||||
| class Time; | ||||
| class Timer; | ||||
| class Datetime; | ||||
|  | ||||
| /* ------------------------------------------------------------------------------------------------ | ||||
|  * | ||||
| @@ -126,6 +129,12 @@ public: | ||||
|     */ | ||||
|     void SetMicroseconds(const SLongInt & amount); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddMicroseconds(const SLongInt & amount); | ||||
|     Timestamp & SubMicroseconds(const SLongInt & amount); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -142,6 +151,12 @@ public: | ||||
|         m_Timestamp = amount; | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddMicrosecondsRaw(SQInteger amount) { m_Timestamp += amount; return *this; } | ||||
|     Timestamp & SubMicrosecondsRaw(SQInteger amount) { m_Timestamp -= amount; return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -152,6 +167,12 @@ public: | ||||
|     */ | ||||
|     void SetMilliseconds(const SLongInt & amount); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddMilliseconds(const SLongInt & amount); | ||||
|     Timestamp & SubMilliseconds(const SLongInt & amount); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -168,6 +189,12 @@ public: | ||||
|         m_Timestamp = int64_t(int64_t(amount) * 1000L); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddMillisecondsRaw(SQInteger amount) { m_Timestamp += int64_t(int64_t(amount) * 1000L); return *this; } | ||||
|     Timestamp & SubMillisecondsRaw(SQInteger amount) { m_Timestamp -= int64_t(int64_t(amount) * 1000L); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -184,6 +211,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 1000000L); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddSecondsF(SQFloat amount) { m_Timestamp += int64_t(double(amount) * 1000000L); return *this; } | ||||
|     Timestamp & SubSecondsF(SQFloat amount) { m_Timestamp -= int64_t(double(amount) * 1000000L); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -200,6 +233,12 @@ public: | ||||
|         m_Timestamp = int64_t(int64_t(amount) * 1000000L); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddSecondsI(SQInteger amount) { m_Timestamp += int64_t(int64_t(amount) * 1000000L); return *this; } | ||||
|     Timestamp & SubSecondsI(SQInteger amount) { m_Timestamp -= int64_t(int64_t(amount) * 1000000L); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -216,6 +255,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 60000000L); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddMinutesF(SQFloat amount) { m_Timestamp += int64_t(double(amount) * 60000000L); return *this; } | ||||
|     Timestamp & SubMinutesF(SQFloat amount) { m_Timestamp -= int64_t(double(amount) * 60000000L); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -232,6 +277,12 @@ public: | ||||
|         m_Timestamp = int64_t(int64_t(amount) * 60000000L); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddMinutesI(SQInteger amount) { m_Timestamp += int64_t(int64_t(amount) * 60000000L); return *this; } | ||||
|     Timestamp & SubMinutesI(SQInteger amount) { m_Timestamp -= int64_t(int64_t(amount) * 60000000L); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -248,6 +299,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 3600000000LL); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddHoursF(SQFloat amount) { m_Timestamp += int64_t(double(amount) * 3600000000LL); return *this; } | ||||
|     Timestamp & SubHoursF(SQFloat amount) { m_Timestamp -= int64_t(double(amount) * 3600000000LL); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -264,6 +321,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 3600000000LL); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddHoursI(SQInteger amount) { m_Timestamp += int64_t(double(amount) * 3600000000LL); return *this; } | ||||
|     Timestamp & SubHoursI(SQInteger amount) { m_Timestamp -= int64_t(double(amount) * 3600000000LL); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -280,6 +343,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 86400000000LL); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddDaysF(SQFloat amount) { m_Timestamp += int64_t(double(amount) * 86400000000LL); return *this; } | ||||
|     Timestamp & SubDaysF(SQFloat amount) { m_Timestamp -= int64_t(double(amount) * 86400000000LL); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -296,6 +365,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 86400000000LL); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddDaysI(SQInteger amount) { m_Timestamp += int64_t(double(amount) * 86400000000LL); return *this; } | ||||
|     Timestamp & SubDaysI(SQInteger amount) { m_Timestamp -= int64_t(double(amount) * 86400000000LL); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -312,6 +387,12 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 31557600000000LL); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddYearsF(SQFloat amount) { m_Timestamp += int64_t(double(amount) * 31557600000000LL); return *this; } | ||||
|     Timestamp & SubYearsF(SQFloat amount) { m_Timestamp -= int64_t(double(amount) * 31557600000000LL); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
| @@ -328,6 +409,65 @@ public: | ||||
|         m_Timestamp = int64_t(double(amount) * 31557600000000LL); | ||||
|     } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddYearsI(SQInteger amount) { m_Timestamp += int64_t(double(amount) * 31557600000000LL); return *this; } | ||||
|     Timestamp & SubYearsI(SQInteger amount) { m_Timestamp -= int64_t(double(amount) * 31557600000000LL); return *this; } | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     SQMOD_NODISCARD Time GetTime() const; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     void SetTime(const Time & t); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddTime(const Time & t); | ||||
|     Timestamp & SubTime(const Time & t); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     SQMOD_NODISCARD Date GetDate() const; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     void SetDate(const Date & d); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddDate(const Date & d); | ||||
|     Timestamp & SubDate(const Date & d); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     SQMOD_NODISCARD Datetime GetDatetime() const; | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     void SetDatetime(const Datetime & dt); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     Timestamp & AddDatetime(const Datetime & dt); | ||||
|     Timestamp & SubDatetime(const Datetime & dt); | ||||
|  | ||||
|     /* -------------------------------------------------------------------------------------------- | ||||
|      * | ||||
|     */ | ||||
|     std::time_t ToTimeT() const; | ||||
|  | ||||
| private: | ||||
|  | ||||
|     // -------------------------------------------------------------------------------------------- | ||||
|   | ||||
| @@ -444,7 +444,7 @@ void SockAddr::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid sockaddr structure handle =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid sockaddr structure handle =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -551,7 +551,7 @@ void Database::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -687,7 +687,7 @@ void Description::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -708,7 +708,7 @@ Description::Pointer Description::GetValid(const SQChar * file, int32_t line) co | ||||
|     // Validate the referenced description | ||||
|     if (!m_Description) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind meta-data description reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind meta-data description reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Return the description pointer | ||||
|     return m_Description; | ||||
| @@ -747,7 +747,7 @@ void EntryData::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -768,7 +768,7 @@ EntryData::ConstRef EntryData::GetValid(const SQChar * file, int32_t line) const | ||||
|     // See if the entry has any data | ||||
|     if (!m_Entry.has_data) | ||||
|     { | ||||
|         SqThrowF("The referenced entry has no data =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("The referenced entry has no data =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Return the entry | ||||
|     return m_Entry; | ||||
| @@ -821,7 +821,7 @@ void EntryDataList::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -842,7 +842,7 @@ EntryDataList::Pointer EntryDataList::GetValid(const SQChar * file, int32_t line | ||||
|     // Validate the managed list | ||||
|     if (!m_List) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind entry data list reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind entry data list reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // return the list | ||||
|     return m_List; | ||||
| @@ -869,7 +869,7 @@ EntryDataList::Pointer EntryDataList::GetValidElem(const SQChar * file, int32_t | ||||
|     // Validate the current element | ||||
|     if (!m_List) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind entry data element reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind entry data element reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // return the element | ||||
|     return m_Elem; | ||||
| @@ -979,7 +979,7 @@ void LookupResult::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1139,7 +1139,7 @@ void Metadata::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1160,7 +1160,7 @@ Metadata::Pointer Metadata::GetValid(const SQChar * file, int32_t line) const | ||||
|     // Validate the referenced meta-data | ||||
|     if (!m_Metadata) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind meta-data reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind meta-data reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Return the meta-data pointer | ||||
|     return m_Metadata; | ||||
| @@ -1211,7 +1211,7 @@ void SearchNode::Validate(const SQChar * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid Maxmind database reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid Maxmind database reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
|   | ||||
| @@ -1623,7 +1623,7 @@ void Connection::Validate(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL connection reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL connection reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1642,11 +1642,11 @@ void Connection::ValidateCreated(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL connection reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL connection reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL connection =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL connection =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1962,12 +1962,12 @@ void Field::Validate(const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Are we pointing to a valid index? | ||||
|     else if (m_Index >= m_Handle->mFieldCount) | ||||
|     { | ||||
|         SqThrowF("Field index is out of range: {} >= {} =>[{}:{}]", m_Index, m_Handle->mFieldCount, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Field index is out of range: {} >= {} =>[{}:{}]"), m_Index, m_Handle->mFieldCount, file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1993,7 +1993,7 @@ void Field::ValidateCreated(const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Are we pointing to a valid index? | ||||
|     m_Handle->ValidateField(m_Index, file, line); | ||||
| @@ -2018,12 +2018,12 @@ void Field::ValidateStepped(const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Do we have a valid row available? | ||||
|     else if (m_Handle->mRow == nullptr) | ||||
|     { | ||||
|         SqThrowF("No row available in MySQL result-set =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("No row available in MySQL result-set =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Are we pointing to a valid index? | ||||
|     m_Handle->ValidateField(m_Index, file, line); | ||||
| @@ -2098,7 +2098,7 @@ void Field::ValidateField(uint32_t idx, const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Validate the specified field index | ||||
|     m_Handle->ValidateField(idx, file, line); | ||||
| @@ -2471,7 +2471,7 @@ void ResultSet::Validate(const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2492,11 +2492,11 @@ void ResultSet::ValidateCreated(const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2521,12 +2521,12 @@ void ResultSet::ValidateStepped(const char * file, int32_t line) const | ||||
|     // Do we have a valid result-set handle? | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL result-set reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL result-set reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     // Do we have a valid row available? | ||||
|     else if (m_Handle->mRow == nullptr) | ||||
|     { | ||||
|         SqThrowF("No row available in MySQL result-set =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("No row available in MySQL result-set =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2753,7 +2753,7 @@ void Statement::Validate(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2772,11 +2772,11 @@ void Statement::ValidateCreated(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid MySQL statement =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid MySQL statement =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
|   | ||||
| @@ -650,7 +650,7 @@ public: | ||||
|      * Grab the current error in the associated statement or connection handle and throw it. | ||||
|     */ | ||||
| #if defined(_DEBUG) || defined(SQMOD_EXCEPTLOC) | ||||
|     void ThrowCurrent(const char * act, const char * file, int32_t line); | ||||
|     void ThrowCurrent(const char * act, const char * file, int32_t line) const; | ||||
| #else | ||||
|     void ThrowCurrent(const char * act) const; | ||||
| #endif // _DEBUG | ||||
|   | ||||
| @@ -895,7 +895,7 @@ void SQLiteConnection::Validate(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite connection reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite connection reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -914,11 +914,11 @@ void SQLiteConnection::ValidateCreated(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite connection reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite connection reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite connection =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite connection =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1227,12 +1227,12 @@ void SQLiteParameter::Validate(const char * file, int32_t line) const | ||||
|     // Are we pointing to a valid index? | ||||
|     if (m_Index < 0) | ||||
|     { | ||||
|         SqThrowF("Invalid column index: {} < 0 =>[{}:{}]", m_Index, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid column index: {} < 0 =>[{}:{}]"), m_Index, file, line); | ||||
|     } | ||||
|     // Do we have a valid statement handle? | ||||
|     else if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1258,15 +1258,15 @@ void SQLiteParameter::ValidateCreated(const char * file, int32_t line) const | ||||
|     // Are we pointing to a valid index? | ||||
|     if (m_Index < 0) | ||||
|     { | ||||
|         SqThrowF("Invalid column index: {} < 0 =>[{}:{}]", m_Index, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid column index: {} < 0 =>[{}:{}]"), m_Index, file, line); | ||||
|     } | ||||
|     else if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1326,7 +1326,7 @@ void SQLiteParameter::ValidateParam(int32_t idx, const char * file, int32_t line | ||||
|     // Is the specified index in range? | ||||
|     if (!m_Handle->CheckParameter(idx)) | ||||
|     { | ||||
|         SqThrowF("Parameter index is out of range ({}:{}) =>[{}:{}]", idx, m_Handle->mParameters, | ||||
|         SqThrowF(SQMOD_RTFMT("Parameter index is out of range ({}:{}) =>[{}:{}]"), idx, m_Handle->mParameters, | ||||
|                     file, line); | ||||
|     } | ||||
| } | ||||
| @@ -1933,12 +1933,12 @@ void SQLiteColumn::Validate(const char * file, int32_t line) const | ||||
|     // Are we pointing to a valid index? | ||||
|     if (m_Index < 0) | ||||
|     { | ||||
|         SqThrowF("Invalid column index: {} < 0 =>[{}:{}]", m_Index, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid column index: {} < 0 =>[{}:{}]"), m_Index, file, line); | ||||
|     } | ||||
|     // Do we have a valid statement handle? | ||||
|     else if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -1964,15 +1964,15 @@ void SQLiteColumn::ValidateCreated(const char * file, int32_t line) const | ||||
|     // Are we pointing to a valid index? | ||||
|     if (m_Index < 0) | ||||
|     { | ||||
|         SqThrowF("Invalid column index: {} < 0 =>[{}:{}]", m_Index, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid column index: {} < 0 =>[{}:{}]"), m_Index, file, line); | ||||
|     } | ||||
|     else if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2032,7 +2032,7 @@ void SQLiteColumn::ValidateColumn(int32_t idx, const char * file, int32_t line) | ||||
|     // Is the specified index in range? | ||||
|     if (!m_Handle->CheckColumn(idx)) | ||||
|     { | ||||
|         SqThrowF("Column index is out of range: {}:{} =>[{}:{}]", idx, m_Handle->mColumns, | ||||
|         SqThrowF(SQMOD_RTFMT("Column index is out of range: {}:{} =>[{}:{}]"), idx, m_Handle->mColumns, | ||||
|                     file, line); | ||||
|     } | ||||
| } | ||||
| @@ -2407,7 +2407,7 @@ void SQLiteStatement::Validate(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2426,11 +2426,11 @@ void SQLiteStatement::ValidateCreated(const char * file, int32_t line) const | ||||
| { | ||||
|     if (!m_Handle) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement reference =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement reference =>[{}:{}]"), file, line); | ||||
|     } | ||||
|     else if (m_Handle->mPtr == nullptr) | ||||
|     { | ||||
|         SqThrowF("Invalid SQLite statement =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Invalid SQLite statement =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2485,7 +2485,7 @@ void SQLiteStatement::ValidateColumn(int32_t idx, const char * file, int32_t lin | ||||
|     // Is the specified index in range? | ||||
|     if (!m_Handle->CheckColumn(idx)) | ||||
|     { | ||||
|         SqThrowF("Column index is out of range: {}:{} =>[{}:{}]", idx, m_Handle->mColumns, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Column index is out of range: {}:{} =>[{}:{}]"), idx, m_Handle->mColumns, file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2508,7 +2508,7 @@ void SQLiteStatement::ValidateParam(int32_t idx, const char * file, int32_t line | ||||
|     // Is the specified index in range? | ||||
|     if (!m_Handle->CheckParameter(idx)) | ||||
|     { | ||||
|         SqThrowF("Parameter index is out of range: {}:{} =>[{}:{}]", idx, m_Handle->mParameters, file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("Parameter index is out of range: {}:{} =>[{}:{}]"), idx, m_Handle->mParameters, file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
| @@ -2531,7 +2531,7 @@ void SQLiteStatement::ValidateRow(const char * file, int32_t line) const | ||||
|     // Do we have any rows available? | ||||
|     if (!m_Handle->mGood) | ||||
|     { | ||||
|         SqThrowF("No row available =>[{}:{}]", file, line); | ||||
|         SqThrowF(SQMOD_RTFMT("No row available =>[{}:{}]"), file, line); | ||||
|     } | ||||
| } | ||||
| #else | ||||
|   | ||||
| @@ -506,6 +506,44 @@ enum EntityType | ||||
|     #define SQMOD_NODISCARD | ||||
| #endif | ||||
|  | ||||
| /* ------------------------------------------------------------------------------------------------ | ||||
|  * FLOAT SELECTION | ||||
| */ | ||||
| #ifdef SQUSEDOUBLE | ||||
|     #define SQMOD_DOUBLE_ONLY(X) X | ||||
|     #define SQMOD_EXCEPT_DOUBLE(X) | ||||
|     #define SQMOD_FLOAT_ONLY(X) | ||||
|     #define SQMOD_EXCEPT_FLOAT(X) X | ||||
| #else | ||||
|     #define SQMOD_DOUBLE_ONLY(X) X | ||||
|     #define SQMOD_EXCEPT_DOUBLE(X) | ||||
|     #define SQMOD_FLOAT_ONLY(X) | ||||
|     #define SQMOD_EXCEPT_FLOAT(X) X | ||||
| #endif | ||||
|  | ||||
| #define SQMOD_DOUBLE_OR(D, F) SQMOD_DOUBLE_ONLY(D) SQMOD_EXCEPT_DOUBLE(F) | ||||
| #define SQMOD_FLOAT_OR(F, D) SQMOD_FLOAT_ONLY(F) SQMOD_EXCEPT_FLOAT(D) | ||||
|  | ||||
| /* ------------------------------------------------------------------------------------------------ | ||||
|  * DEBUG SELECTION | ||||
| */ | ||||
| #ifdef _DEBUG | ||||
|     #define SQMOD_DEBUG_ONLY(X) X | ||||
|     #define SQMOD_EXCEPT_DEBUG(X) | ||||
|     #define SQMOD_RELEASE_ONLY(X) | ||||
|     #define SQMOD_EXCEPT_RELEASE(X) X | ||||
|     #define SQMOD_RTFMT(X) fmt::runtime(X) | ||||
| #else | ||||
|     #define SQMOD_DEBUG_ONLY(X) | ||||
|     #define SQMOD_EXCEPT_DEBUG(X) X | ||||
|     #define SQMOD_RELEASE_ONLY(X) X | ||||
|     #define SQMOD_EXCEPT_RELEASE(X) | ||||
|     #define SQMOD_RTFMT(X) X | ||||
| #endif | ||||
|  | ||||
| #define SQMOD_DEBUG_OR(D, R) SQMOD_DEBUG_ONLY(D) SQMOD_EXCEPT_DEBUG(R) | ||||
| #define SQMOD_RELEASE_OR(R, D) SQMOD_RELEASE_ONLY(R) SQMOD_EXCEPT_RELEASE(D) | ||||
|  | ||||
| /* ------------------------------------------------------------------------------------------------ | ||||
|  * LOGGING LOCATION | ||||
| */ | ||||
| @@ -525,7 +563,7 @@ enum EntityType | ||||
|  | ||||
| #if defined(_DEBUG) || defined(SQMOD_EXCEPTLOC) | ||||
|     #define STHROW(e, m, ...) throw e(m " =>[" __FILE__ ":" SQMOD_STRINGIZEWRAP(__LINE__) "] ", ##__VA_ARGS__) | ||||
|     #define STHROWF(m, ...) SqThrowF(m " =>[" __FILE__ ":" SQMOD_STRINGIZEWRAP(__LINE__) "] ", ##__VA_ARGS__) | ||||
|     #define STHROWF(m, ...) SqThrowF(fmt::runtime(m " =>[" __FILE__ ":" SQMOD_STRINGIZEWRAP(__LINE__) "] "), ##__VA_ARGS__) | ||||
|     #define STHROWLASTF(m, ...) SqThrowLastF(m " =>[" __FILE__ ":" SQMOD_STRINGIZEWRAP(__LINE__) "] ", ##__VA_ARGS__) | ||||
| #else | ||||
|     #define STHROW(e, m, ...) throw e(m, ##__VA_ARGS__) | ||||
|   | ||||
							
								
								
									
										6
									
								
								vendor/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								vendor/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							| @@ -35,16 +35,16 @@ set(POCO_UNBUNDLED OFF CACHE INTERNAL "" FORCE) | ||||
| add_subdirectory(POCO) | ||||
| # Windows gets stupid sometimes | ||||
| if (WIN32 AND MINGW) | ||||
| 	target_compile_definitions(Foundation PUBLIC POCO_NO_FPENVIRONMENT=1) | ||||
|     target_compile_definitions(Foundation PUBLIC POCO_NO_FPENVIRONMENT=1) | ||||
| endif() | ||||
| # We have these on GCC | ||||
| if(MINGW OR GCC) | ||||
| 	set(ENABLE_INTRINSICS ON CACHE INTERNAL "" FORCE) | ||||
|     set(ENABLE_INTRINSICS ON CACHE INTERNAL "" FORCE) | ||||
| endif() | ||||
| set(BUILD_TESTS OFF CACHE INTERNAL "" FORCE) | ||||
| set(BUILD_SHARED OFF CACHE INTERNAL "" FORCE) | ||||
| set(BUILD_STATIC ON CACHE INTERNAL "" FORCE) | ||||
| if (WIN32 OR MINGW) | ||||
| 	set(ZMQ_HAVE_IPC OFF CACHE INTERNAL "" FORCE) | ||||
|     set(ZMQ_HAVE_IPC OFF CACHE INTERNAL "" FORCE) | ||||
| endif() | ||||
| add_subdirectory(ZMQ) | ||||
| @@ -36,7 +36,7 @@ | ||||
|  | ||||
| // Check debug/release settings consistency | ||||
| #if defined(NDEBUG) && defined(_DEBUG) | ||||
| 	#error Inconsistent build settings (check for /MD[d]) | ||||
| 	//#error Inconsistent build settings (check for /MD[d]) | ||||
| #endif | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								vendor/Squirrel/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/Squirrel/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							| @@ -48,7 +48,7 @@ else() | ||||
| endif() | ||||
| # Make sure Squirrel knows this is 64 bit | ||||
| if(CMAKE_SIZEOF_VOID_P EQUAL 8) | ||||
|     target_compile_definitions(Squirrel PUBLIC _SQ64) | ||||
|     target_compile_definitions(Squirrel PUBLIC _SQ64=1 SQUSEDOUBLE=1) | ||||
| endif() | ||||
| # Set specific compiler options | ||||
| if (GCC OR MINGW) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user