From: Adam Norton Date: Thu, 3 Aug 2017 17:08:17 +0000 (-0700) Subject: Reduce Code Duplication In NotificationQueue With Universal Reference X-Git-Tag: v2017.08.07.00~6 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=11a4437937caea6149d93c97782e635b83c15415;p=folly.git Reduce Code Duplication In NotificationQueue With Universal Reference Summary: Remove a bunch of identical code that only exists to provide interfaces for both `const MessageT&` and `MessageT&&` arguments. Reviewed By: ot Differential Revision: D5540560 fbshipit-source-id: ae7b9345b64130fc748033be2e0587c4f83345a7 --- diff --git a/folly/io/async/NotificationQueue.h b/folly/io/async/NotificationQueue.h index 048d0f9b..e1b1cb36 100644 --- a/folly/io/async/NotificationQueue.h +++ b/folly/io/async/NotificationQueue.h @@ -352,11 +352,9 @@ class NotificationQueue { * may throw any other exception thrown by the MessageT move/copy * constructor. */ - void tryPutMessage(MessageT&& message) { - putMessageImpl(std::move(message), advisoryMaxQueueSize_); - } - void tryPutMessage(const MessageT& message) { - putMessageImpl(message, advisoryMaxQueueSize_); + template + void tryPutMessage(MessageTT&& message) { + putMessageImpl(std::forward(message), advisoryMaxQueueSize_); } /** @@ -367,11 +365,10 @@ class NotificationQueue { * (which indicates that the queue is being drained) are prevented from being * thrown. User code must still catch std::bad_alloc errors. */ - bool tryPutMessageNoThrow(MessageT&& message) { - return putMessageImpl(std::move(message), advisoryMaxQueueSize_, false); - } - bool tryPutMessageNoThrow(const MessageT& message) { - return putMessageImpl(message, advisoryMaxQueueSize_, false); + template + bool tryPutMessageNoThrow(MessageTT&& message) { + return putMessageImpl( + std::forward(message), advisoryMaxQueueSize_, false); } /** @@ -386,11 +383,9 @@ class NotificationQueue { * - std::runtime_error if the queue is currently draining * - any other exception thrown by the MessageT move/copy constructor. */ - void putMessage(MessageT&& message) { - putMessageImpl(std::move(message), 0); - } - void putMessage(const MessageT& message) { - putMessageImpl(message, 0); + template + void putMessage(MessageTT&& message) { + putMessageImpl(std::forward(message), 0); } /** @@ -570,7 +565,8 @@ class NotificationQueue { } } - bool putMessageImpl(MessageT&& message, size_t maxSize, bool throws=true) { + template + bool putMessageImpl(MessageTT&& message, size_t maxSize, bool throws = true) { checkPid(); bool signal = false; { @@ -583,27 +579,8 @@ class NotificationQueue { if (numActiveConsumers_ < numConsumers_) { signal = true; } - queue_.emplace_back(std::move(message), RequestContext::saveContext()); - if (signal) { - ensureSignalLocked(); - } - } - return true; - } - - bool putMessageImpl( - const MessageT& message, size_t maxSize, bool throws=true) { - checkPid(); - bool signal = false; - { - folly::SpinLockGuard g(spinlock_); - if (checkDraining(throws) || !checkQueueSize(maxSize, throws)) { - return false; - } - if (numActiveConsumers_ < numConsumers_) { - signal = true; - } - queue_.emplace_back(message, RequestContext::saveContext()); + queue_.emplace_back( + std::forward(message), RequestContext::saveContext()); if (signal) { ensureSignalLocked(); }