mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2024-11-08 00:37:15 +01: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__)
|
||||
|
@ -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)
|
||||
|
Loading…
Reference in New Issue
Block a user