From c341dc1dd2e886e882d0cc479d4e08c72d7733ef Mon Sep 17 00:00:00 2001 From: Crayon Date: Wed, 2 Nov 2022 11:19:48 -0400 Subject: [PATCH 1/2] Rebuild with string_view argument, like the constructor --- tests/message.cpp | 31 +++++++++++++++++++++++++++++++ zmq.hpp | 7 +++++++ 2 files changed, 38 insertions(+) diff --git a/tests/message.cpp b/tests/message.cpp index a841413..87655c3 100644 --- a/tests/message.cpp +++ b/tests/message.cpp @@ -179,6 +179,37 @@ TEST_CASE("message equality non equal lhs empty", "[message]") CHECK(msg_a != msg_b); } +TEST_CASE("message rebuild with size", "[message]") +{ + const zmq::message_t msg(); + msg.rebuild(5) + CHECK(msg.size() == 5); +} + +#if defined(ZMQ_CPP11) && !defined(ZMQ_CPP11_PARTIAL) +TEST_CASE("message rebuild with strings", "[message]") +{ + SECTION("string") + { + const std::string hi(data); + zmq::message_t hi_msg(); + hi_msg.rebuild(hi) + CHECK(2u == hi_msg.size()); + CHECK(0 == memcmp(data, hi_msg.data(), 2)); + } +#if CPPZMQ_HAS_STRING_VIEW + SECTION("string_view") + { + const std::string_view hi(data); + zmq::message_t hi_msg(); + hi_msg.rebuild(hi) + CHECK(2u == hi_msg.size()); + CHECK(0 == memcmp(data, hi_msg.data(), 2)); + } +#endif +} +#endif + TEST_CASE("message to string", "[message]") { const zmq::message_t a; diff --git a/zmq.hpp b/zmq.hpp index 775c6f6..473cbd7 100644 --- a/zmq.hpp +++ b/zmq.hpp @@ -544,6 +544,13 @@ class message_t rebuild(str.data(), str.size()); } +#if CPPZMQ_HAS_STRING_VIEW + void rebuild(std::string_view str) + { + rebuild(str.data(), str.size()); + } +#endif + void rebuild(void *data_, size_t size_, free_fn *ffn_, void *hint_ = ZMQ_NULLPTR) { int rc = zmq_msg_close(&msg); From 107c1bc4e273dfc6ad192c6a64e91e445b6dfa51 Mon Sep 17 00:00:00 2001 From: Crayon Date: Thu, 3 Nov 2022 03:36:30 -0400 Subject: [PATCH 2/2] Fix unit tests --- tests/message.cpp | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/tests/message.cpp b/tests/message.cpp index 87655c3..f148b9c 100644 --- a/tests/message.cpp +++ b/tests/message.cpp @@ -181,19 +181,27 @@ TEST_CASE("message equality non equal lhs empty", "[message]") TEST_CASE("message rebuild with size", "[message]") { - const zmq::message_t msg(); - msg.rebuild(5) + zmq::message_t msg; + msg.rebuild(5); CHECK(msg.size() == 5); } #if defined(ZMQ_CPP11) && !defined(ZMQ_CPP11_PARTIAL) +TEST_CASE("message rebuild with string literal", "[message]") +{ + zmq::message_t hi_msg; + hi_msg.rebuild("Hi"); + REQUIRE(2u == hi_msg.size()); + CHECK(0 == memcmp(data, hi_msg.data(), 2)); +} + TEST_CASE("message rebuild with strings", "[message]") { SECTION("string") { const std::string hi(data); - zmq::message_t hi_msg(); - hi_msg.rebuild(hi) + zmq::message_t hi_msg; + hi_msg.rebuild(hi); CHECK(2u == hi_msg.size()); CHECK(0 == memcmp(data, hi_msg.data(), 2)); } @@ -201,8 +209,8 @@ TEST_CASE("message rebuild with strings", "[message]") SECTION("string_view") { const std::string_view hi(data); - zmq::message_t hi_msg(); - hi_msg.rebuild(hi) + zmq::message_t hi_msg; + hi_msg.rebuild(hi); CHECK(2u == hi_msg.size()); CHECK(0 == memcmp(data, hi_msg.data(), 2)); }