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:
parent
3fb6005c3f
commit
203a02cb2d
@ -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.
|
||||||
*/
|
*/
|
||||||
|
@ -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
Loading…
x
Reference in New Issue
Block a user