MessageCallback: Tolerate being created with nullptr filter
Communication does this in waitForMessageSync if a filter is not passed in. This fixes a crash in icsneoWaitForRxMessagesWithTimeOut for the legacy API. For good measure, creation with an empty std::function will immediately throw an std::bad_function_call back at the caller, rather than letting that happen on the callback thread. I'm also making the members const here so they are provably always non-null (and not empty, for the function).v0.3.0-dev
parent
ac7b2d5106
commit
c32d027b2d
|
|
@ -14,12 +14,20 @@ class MessageCallback {
|
||||||
public:
|
public:
|
||||||
typedef std::function< void( std::shared_ptr<Message> ) > fn_messageCallback;
|
typedef std::function< void( std::shared_ptr<Message> ) > fn_messageCallback;
|
||||||
|
|
||||||
MessageCallback(fn_messageCallback cb, std::shared_ptr<MessageFilter> f) : callback(cb), filter(f) {}
|
MessageCallback(fn_messageCallback cb, std::shared_ptr<MessageFilter> f)
|
||||||
MessageCallback(fn_messageCallback cb, MessageFilter f = MessageFilter()) : callback(cb), filter(std::make_shared<MessageFilter>(f)) {}
|
: callback(cb), filter(f ? f : std::make_shared<MessageFilter>()) {
|
||||||
|
if(!cb)
|
||||||
|
throw std::bad_function_call();
|
||||||
|
}
|
||||||
|
|
||||||
|
MessageCallback(fn_messageCallback cb, MessageFilter f = MessageFilter())
|
||||||
|
: MessageCallback(cb, std::make_shared<MessageFilter>(f)) {}
|
||||||
|
|
||||||
// Allow the filter to be placed first if the user wants (maybe in the case of a lambda)
|
// Allow the filter to be placed first if the user wants (maybe in the case of a lambda)
|
||||||
MessageCallback(std::shared_ptr<MessageFilter> f, fn_messageCallback cb) : callback(cb), filter(f) {}
|
MessageCallback(std::shared_ptr<MessageFilter> f, fn_messageCallback cb)
|
||||||
MessageCallback(MessageFilter f, fn_messageCallback cb) : callback(cb), filter(std::make_shared<MessageFilter>(f)) {}
|
: MessageCallback(cb, f) {}
|
||||||
|
MessageCallback(MessageFilter f, fn_messageCallback cb)
|
||||||
|
: MessageCallback(cb, std::make_shared<MessageFilter>(f)) {}
|
||||||
|
|
||||||
virtual bool callIfMatch(const std::shared_ptr<Message>& message) const {
|
virtual bool callIfMatch(const std::shared_ptr<Message>& message) const {
|
||||||
bool ret = filter->match(message);
|
bool ret = filter->match(message);
|
||||||
|
|
@ -31,8 +39,8 @@ public:
|
||||||
const fn_messageCallback& getCallback() const { return callback; }
|
const fn_messageCallback& getCallback() const { return callback; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
fn_messageCallback callback;
|
const fn_messageCallback callback;
|
||||||
std::shared_ptr<MessageFilter> filter;
|
const std::shared_ptr<MessageFilter> filter;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue