1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-01-18 19:47:15 +01:00

Update Data.cpp

This commit is contained in:
Sandu Liviu Catalin 2021-01-31 14:09:10 +02:00
parent 4ca062d439
commit 1829668015

View File

@ -50,10 +50,10 @@ void SqDataSession::SetProperty(const LightObj & value, StackStrF & name)
setProperty(name.ToStr(), Poco::Any(nullptr)); setProperty(name.ToStr(), Poco::Any(nullptr));
} break; } break;
case OT_INTEGER: { case OT_INTEGER: {
setProperty(name.ToStr(), Poco::Any(value.Cast<SQInteger>())); setProperty(name.ToStr(), Poco::Any(value.Cast< SQInteger >()));
} break; } break;
case OT_FLOAT: { case OT_FLOAT: {
setProperty(name.ToStr(), Poco::Any(value.Cast<SQFloat>())); setProperty(name.ToStr(), Poco::Any(value.Cast< SQFloat >()));
} break; } break;
case OT_BOOL: { case OT_BOOL: {
setProperty(name.ToStr(), Poco::Any(value.Cast<bool>())); setProperty(name.ToStr(), Poco::Any(value.Cast<bool>()));
@ -159,24 +159,29 @@ SqDataStatement & SqDataStatement::UseEx(LightObj & obj, const std::string & nam
// ------------------------------------------------------------------------------------------------ // ------------------------------------------------------------------------------------------------
SqDataStatement & SqDataStatement::BindEx(LightObj & obj, const std::string & name, Poco::Data::AbstractBinding::Direction dir) SqDataStatement & SqDataStatement::BindEx(LightObj & obj, const std::string & name, Poco::Data::AbstractBinding::Direction dir)
{ {
// // Identify the object type
switch (obj.GetType()) switch (obj.GetType())
{ {
// Null?
case OT_NULL: { case OT_NULL: {
addBind(new Poco::Data::Binding<Poco::Data::NullData>(const_cast<Poco::Data::NullData&>(g_NullData), name, dir)); addBind(new Poco::Data::Binding<Poco::Data::NullData>(const_cast<Poco::Data::NullData&>(g_NullData), name, dir));
} break; } break;
// Integer?
case OT_INTEGER: { case OT_INTEGER: {
auto v = obj.Cast<SQInteger>(); auto v = obj.Cast< SQInteger >();
addBind(new Poco::Data::CopyBinding<SQInteger>(v, name, dir)); addBind(new Poco::Data::CopyBinding< SQInteger >(v, name, dir));
} break; } break;
// Float?
case OT_FLOAT: { case OT_FLOAT: {
auto v = obj.Cast<SQFloat>(); auto v = obj.Cast< SQFloat >();
addBind(new Poco::Data::CopyBinding<SQFloat>(v, name, dir)); addBind(new Poco::Data::CopyBinding< SQFloat >(v, name, dir));
} break; } break;
// Bool?
case OT_BOOL: { case OT_BOOL: {
auto v = obj.Cast<bool>(); auto v = obj.Cast<bool>();
addBind(new Poco::Data::CopyBinding<bool>(v, name, dir)); addBind(new Poco::Data::CopyBinding<bool>(v, name, dir));
} break; } break;
// String?
case OT_STRING: { case OT_STRING: {
Var< LightObj >::push(SqVM(), obj); Var< LightObj >::push(SqVM(), obj);
StackStrF str(SqVM(), -1); StackStrF str(SqVM(), -1);
@ -184,35 +189,36 @@ SqDataStatement & SqDataStatement::BindEx(LightObj & obj, const std::string & na
sq_poptop(SqVM()); sq_poptop(SqVM());
addBind(new Poco::Data::CopyBinding<const char *>(str.mPtr, name, dir)); addBind(new Poco::Data::CopyBinding<const char *>(str.mPtr, name, dir));
} break; } break;
// Special?
case OT_INSTANCE: { case OT_INSTANCE: {
auto type = static_cast< AbstractStaticClassData * >(obj.GetTypeTag()); auto type = static_cast< AbstractStaticClassData * >(obj.GetTypeTag());
// Integer reference? // Integer reference?
if (type == StaticClassTypeTag< SqDataBinding< SQInteger > >::Get()) if (type == StaticClassTypeTag< SqDataBinding< SQInteger > >::Get())
{ {
//addBind(new Poco::Data::ReferenceBinding< SQInteger >(obj.CastI< SqDataBinding< SQInteger > >()->mV, name, dir)); break; addBind(new Poco::Data::CopyBinding< SQInteger >(*obj.CastI< SqDataBinding< SQInteger > >()->mV, name, dir)); break;
} // Float reference? } // Float reference?
else if (type == StaticClassTypeTag< SqDataBinding< SQFloat > >::Get()) else if (type == StaticClassTypeTag< SqDataBinding< SQFloat > >::Get())
{ {
//addBind(new Poco::Data::ReferenceBinding< SQFloat >(obj.CastI< SqDataBinding< SQFloat > >()->mV, name, dir)); break; addBind(new Poco::Data::CopyBinding< SQFloat >(*obj.CastI< SqDataBinding< SQFloat > >()->mV, name, dir)); break;
} // String reference? } // String reference?
else if (type == StaticClassTypeTag< SqDataBinding< String > >::Get()) else if (type == StaticClassTypeTag< SqDataBinding< String > >::Get())
{ {
//addBind(new Poco::Data::ReferenceBinding< String >(obj.CastI< SqDataBinding< String > >()->mV, name, dir)); break; addBind(new Poco::Data::CopyBinding< String >(*obj.CastI< SqDataBinding< String > >()->mV, name, dir)); break;
} // Bool reference? } // Bool reference?
else if (type == StaticClassTypeTag< SqDataBinding< bool > >::Get()) else if (type == StaticClassTypeTag< SqDataBinding< bool > >::Get())
{ {
//addBind(new Poco::Data::ReferenceBinding< bool >(obj.CastI< SqDataBinding< bool > >()->mV, name, dir)); break; addBind(new Poco::Data::CopyBinding< bool >(*obj.CastI< SqDataBinding< bool > >()->mV, name, dir)); break;
} // Unknown! } // Unknown!
else else
{ {
Var< LightObj >::push(SqVM(), obj); Var< LightObj >::push(SqVM(), obj);
String type_name = SqTypeName(SqVM(), -1); String type_name = SqTypeName(SqVM(), -1);
sq_poptop(SqVM()); sq_poptop(SqVM());
STHROWF("Can't use (%s) values", type_name.c_str()); break; STHROWF("Can't bind (%s) values", type_name.c_str()); break;
} }
} break; } break;
default: STHROWF("Can't use (%s) values", SqTypeName(obj.GetType())); break; default: STHROWF("Can't bind (%s) values", SqTypeName(obj.GetType())); break;
} }
// //
return *this; return *this;