1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-01-19 03:57:14 +01:00

Refactor ZMQ to be simpler.

Fixed a meory leak.
This commit is contained in:
Sandu Liviu Catalin 2021-02-03 11:49:35 +02:00
parent 3fb6005c3f
commit 203a02cb2d
3 changed files with 213 additions and 561 deletions

View File

@ -144,6 +144,14 @@ public:
return m_Buffer; return m_Buffer;
} }
/* --------------------------------------------------------------------------------------------
* Retrieve a reference to the managed memory buffer.
*/
SQMOD_NODISCARD Buffer & GetInst() const
{
return *m_Buffer;
}
/* -------------------------------------------------------------------------------------------- /* --------------------------------------------------------------------------------------------
* Validate the managed memory buffer reference. * Validate the managed memory buffer reference.
*/ */

View File

@ -9,24 +9,33 @@ namespace SqMod {
// ------------------------------------------------------------------------------------------------ // ------------------------------------------------------------------------------------------------
SQMOD_DECL_TYPENAME(SqZContext, _SC("SqZmqContext")) SQMOD_DECL_TYPENAME(SqZContext, _SC("SqZmqContext"))
SQMOD_DECL_TYPENAME(SqZMessage, _SC("SqZmqMessage"))
SQMOD_DECL_TYPENAME(SqZSocket, _SC("SqZmqSocket")) SQMOD_DECL_TYPENAME(SqZSocket, _SC("SqZmqSocket"))
// ------------------------------------------------------------------------------------------------ // ------------------------------------------------------------------------------------------------
void ZSkt::Flush(HSQUIRRELVM vm) void ZSkt::Flush(HSQUIRRELVM vm)
{ {
// Need someone to receive the message // Need someone to receive the message
ZMsg msg; Item data;
// Try to get a message from the queue // Try to get a message from the queue
while (mOutputQueue.try_dequeue(msg)) while (mOutputQueue.try_dequeue(data))
{ {
// Is there a callback to receive the message? // Is there a callback to receive the message?
if (!mOnData.IsNull()) if (!mOnData.IsNull())
{ {
// Transform the message into a script object // Transform the message into a script object
LightObj o(SqTypeIdentity< ZMessage >{}, vm, std::make_shared< ZMsg >(std::move(msg))); if (mStringMessages)
// Forward it to the callback {
mOnData(o); LightObj o(static_cast< const SQChar * >(data->Get()),
static_cast< SQInteger >(data->Size< SQChar >()));
// Forward it to the callback
mOnData(o);
}
else
{
LightObj o(SqTypeIdentity< SqBuffer >{}, vm, std::move(*data));
// Forward it to the callback
mOnData(o);
}
} }
} }
} }
@ -37,9 +46,11 @@ LightObj ZContext::Socket(int type) const
return LightObj(SqTypeIdentity< ZSocket >{}, SqVM(), *this, type); return LightObj(SqTypeIdentity< ZSocket >{}, SqVM(), *this, type);
} }
// ------------------------------------------------------------------------------------------------ // ------------------------------------------------------------------------------------------------
LightObj ZSocket::GetOpt(int opt) const LightObj ZSocket::GetOpt(int opt)
{ {
int r = 0; int r = 0;
// Acquire exclusive access to the socket
std::lock_guard< std::mutex > guard(Valid().mMtx);
// Identify option // Identify option
switch (opt) switch (opt)
{ {
@ -177,7 +188,7 @@ LightObj ZSocket::GetOpt(int opt) const
// Validate result // Validate result
if (r != 0) if (r != 0)
{ {
STHROWF("Unable to retrieve socket option: [%d] %s", r, zmq_strerror(errno)); STHROWF("Unable to retrieve socket option: [{}] {}", r, zmq_strerror(errno));
} }
SQ_UNREACHABLE; SQ_UNREACHABLE;
// Never reaches here // Never reaches here
@ -188,6 +199,8 @@ LightObj ZSocket::GetOpt(int opt) const
void ZSocket::SetOpt(int opt, LightObj & value) void ZSocket::SetOpt(int opt, LightObj & value)
{ {
int r = 0; int r = 0;
// Acquire exclusive access to the socket
std::lock_guard< std::mutex > guard(Valid().mMtx);
// Identify option // Identify option
switch (opt) switch (opt)
{ {
@ -297,7 +310,7 @@ void ZSocket::SetOpt(int opt, LightObj & value)
// Validate result // Validate result
if (r != 0) if (r != 0)
{ {
STHROWF("Unable to modify socket option: [%d] %s", r, zmq_strerror(errno)); STHROWF("Unable to modify socket option: [{}] {}", r, zmq_strerror(errno));
} }
// Never reaches here // Never reaches here
SQ_UNREACHABLE; SQ_UNREACHABLE;
@ -359,29 +372,6 @@ void Register_ZMQ(HSQUIRRELVM vm)
.Func(_SC("Socket"), &ZContext::Socket) .Func(_SC("Socket"), &ZContext::Socket)
); );
// --------------------------------------------------------------------------------------------
ns.Bind(_SC("Message"),
Class< ZMessage, NoCopy< ZMessage > >(vm, SqZMessage::Str)
// Constructors
.Ctor()
.Ctor< StackStrF & >()
// Meta-methods
.SquirrelFunc(_SC("_typename"), &SqZMessage::Fn)
// Properties
.Prop(_SC("IsNull"), &ZMessage::IsNull)
.Prop(_SC("More"), &ZMessage::More)
.Prop(_SC("Size"), &ZMessage::GetSize)
// Member Methods
.Func(_SC("Get"), &ZMessage::Get)
.Func(_SC("Set"), &ZMessage::Set)
.Func(_SC("Meta"), &ZMessage::Meta)
.Func(_SC("Copy"), &ZMessage::Copy)
.Func(_SC("ToString"), &ZMessage::ToString)
.Func(_SC("FromString"), &ZMessage::FromString)
.Func(_SC("ToBuffer"), &ZMessage::ToBuffer)
.Func(_SC("FromBuffer"), &ZMessage::FromBuffer)
);
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
ns.Bind(_SC("Socket"), ns.Bind(_SC("Socket"),
Class< ZSocket, NoCopy< ZSocket > >(vm, SqZSocket::Str) Class< ZSocket, NoCopy< ZSocket > >(vm, SqZSocket::Str)
@ -391,16 +381,16 @@ void Register_ZMQ(HSQUIRRELVM vm)
.SquirrelFunc(_SC("_typename"), &SqZSocket::Fn) .SquirrelFunc(_SC("_typename"), &SqZSocket::Fn)
// Properties // Properties
.Prop(_SC("IsNull"), &ZSocket::IsNull) .Prop(_SC("IsNull"), &ZSocket::IsNull)
.Prop(_SC("StringMessages"), &ZSocket::GetStringMessages, &ZSocket::SetStringMessages)
// Member Methods // Member Methods
.CbFunc(_SC("OnData"), &ZSocket::OnData) .CbFunc(_SC("OnData"), &ZSocket::OnData)
.FmtFunc(_SC("Bind"), &ZSocket::Bind) .FmtFunc(_SC("Bind"), &ZSocket::Bind)
.FmtFunc(_SC("Connect"), &ZSocket::Connect) .FmtFunc(_SC("Connect"), &ZSocket::Connect)
.FmtFunc(_SC("Disconnect"), &ZSocket::Disconnect) .FmtFunc(_SC("Disconnect"), &ZSocket::Disconnect)
.Func(_SC("Run"), &ZSocket::Run)
.Func(_SC("Close"), &ZSocket::Close) .Func(_SC("Close"), &ZSocket::Close)
.Func(_SC("SendMessage"), &ZSocket::SendMessage) .Func(_SC("SendBuffer"), &ZSocket::SendBuffer)
.FmtFunc(_SC("SendString"), &ZSocket::SendString) .FmtFunc(_SC("SendString"), &ZSocket::SendString)
.Func(_SC("SendMessages"), &ZSocket::SendMessages) .Func(_SC("SendBuffers"), &ZSocket::SendBuffers)
.Func(_SC("SendStrings"), &ZSocket::SendStrings) .Func(_SC("SendStrings"), &ZSocket::SendStrings)
.Func(_SC("GetOpt"), &ZSocket::GetOpt) .Func(_SC("GetOpt"), &ZSocket::GetOpt)
.Func(_SC("SetOpt"), &ZSocket::SetOpt) .Func(_SC("SetOpt"), &ZSocket::SetOpt)

File diff suppressed because it is too large Load Diff