mirror of
https://github.com/zeromq/cppzmq.git
synced 2025-01-19 00:46:05 +01:00
Problem: implicit conversion operators in context
Solution: add handle() and mark operators as deprecated
This commit is contained in:
parent
a3e5b54c3c
commit
5a3dee082e
@ -15,16 +15,16 @@ TEST_CASE("context create, close and destroy", "[context]")
|
|||||||
{
|
{
|
||||||
zmq::context_t context;
|
zmq::context_t context;
|
||||||
context.close();
|
context.close();
|
||||||
CHECK(NULL == (void *) context);
|
CHECK(NULL == context.handle());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("context shutdown", "[context]")
|
TEST_CASE("context shutdown", "[context]")
|
||||||
{
|
{
|
||||||
zmq::context_t context;
|
zmq::context_t context;
|
||||||
context.shutdown();
|
context.shutdown();
|
||||||
CHECK(NULL != (void *) context);
|
CHECK(NULL != context.handle());
|
||||||
context.close();
|
context.close();
|
||||||
CHECK(NULL == (void *) context);
|
CHECK(NULL == context.handle());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("context shutdown again", "[context]")
|
TEST_CASE("context shutdown again", "[context]")
|
||||||
@ -32,9 +32,9 @@ TEST_CASE("context shutdown again", "[context]")
|
|||||||
zmq::context_t context;
|
zmq::context_t context;
|
||||||
context.shutdown();
|
context.shutdown();
|
||||||
context.shutdown();
|
context.shutdown();
|
||||||
CHECK(NULL != (void *) context);
|
CHECK(NULL != context.handle());
|
||||||
context.close();
|
context.close();
|
||||||
CHECK(NULL == (void *) context);
|
CHECK(NULL == context.handle());
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ZMQ_CPP11
|
#ifdef ZMQ_CPP11
|
||||||
|
7
zmq.hpp
7
zmq.hpp
@ -788,6 +788,9 @@ class context_t
|
|||||||
|
|
||||||
ZMQ_EXPLICIT operator void const *() const ZMQ_NOTHROW { return ptr; }
|
ZMQ_EXPLICIT operator void const *() const ZMQ_NOTHROW { return ptr; }
|
||||||
|
|
||||||
|
ZMQ_NODISCARD void *handle() ZMQ_NOTHROW { return ptr; }
|
||||||
|
|
||||||
|
ZMQ_DEPRECATED("from 4.7.0, use handle() != nullptr instead")
|
||||||
operator bool() const ZMQ_NOTHROW { return ptr != ZMQ_NULLPTR; }
|
operator bool() const ZMQ_NOTHROW { return ptr != ZMQ_NULLPTR; }
|
||||||
|
|
||||||
void swap(context_t &other) ZMQ_NOTHROW { std::swap(ptr, other.ptr); }
|
void swap(context_t &other) ZMQ_NOTHROW { std::swap(ptr, other.ptr); }
|
||||||
@ -2051,8 +2054,8 @@ class socket_t : public detail::socket_base
|
|||||||
socket_t() ZMQ_NOTHROW : detail::socket_base(ZMQ_NULLPTR), ctxptr(ZMQ_NULLPTR) {}
|
socket_t() ZMQ_NOTHROW : detail::socket_base(ZMQ_NULLPTR), ctxptr(ZMQ_NULLPTR) {}
|
||||||
|
|
||||||
socket_t(context_t &context_, int type_) :
|
socket_t(context_t &context_, int type_) :
|
||||||
detail::socket_base(zmq_socket(static_cast<void *>(context_), type_)),
|
detail::socket_base(zmq_socket(context_.handle(), type_)),
|
||||||
ctxptr(static_cast<void *>(context_))
|
ctxptr(context_.handle())
|
||||||
{
|
{
|
||||||
if (_handle == ZMQ_NULLPTR)
|
if (_handle == ZMQ_NULLPTR)
|
||||||
throw error_t();
|
throw error_t();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user