From 61cc9906f889f347ef4d8d4c8db17316ed4dc6c3 Mon Sep 17 00:00:00 2001 From: Xie Han <63350856@qq.com> Date: Thu, 12 Dec 2024 20:58:00 +0800 Subject: [PATCH] Fix function overload resolution. --- src/client/WFKafkaClient.cc | 2 +- src/factory/WFTaskFactory.h | 41 +++++++++++++++++++++++++++++++++++ src/factory/WFTaskFactory.inl | 1 + 3 files changed, 43 insertions(+), 1 deletion(-) diff --git a/src/client/WFKafkaClient.cc b/src/client/WFKafkaClient.cc index 8339aed961..6bf5aff2fd 100644 --- a/src/client/WFKafkaClient.cc +++ b/src/client/WFKafkaClient.cc @@ -312,7 +312,7 @@ void KafkaClientTask::kafka_rebalance_callback(__WFKafkaTask *task) snprintf(name, 64, "%p.cgroup", member); member->mutex.unlock(); - WFTaskFactory::signal_by_name(name, NULL, max); + WFTaskFactory::signal_by_name(name, (void *)NULL, max); } else { diff --git a/src/factory/WFTaskFactory.h b/src/factory/WFTaskFactory.h index d2f05d92d8..28c6397d22 100644 --- a/src/factory/WFTaskFactory.h +++ b/src/factory/WFTaskFactory.h @@ -382,6 +382,47 @@ class WFTaskFactory task->sub_series()->set_last_task(last); return task; } + +public: + /* The following functions are for overload resolution only. */ + + static int send_by_name(const std::string& mailbox_name, intptr_t msg, + size_t max) + { + return WFTaskFactory::send_by_name(mailbox_name, (void *)msg, max); + } + + static int send_by_name(const std::string& mailbox_name, std::nullptr_t msg, + size_t max) + { + return WFTaskFactory::send_by_name(mailbox_name, (void *)0, max); + } + + static int signal_by_name(const std::string& cond_name, intptr_t msg, + size_t max) + { + return WFTaskFactory::signal_by_name(cond_name, (void *)msg, max); + } + + static int signal_by_name(const std::string& cond_name, std::nullptr_t msg, + size_t max) + { + return WFTaskFactory::signal_by_name(cond_name, (void *)0, max); + } + +#ifdef _WIN64 + static int send_by_name(const std::string& mailbox_name, int msg, + size_t max) + { + return WFTaskFactory::send_by_name(mailbox_name, (void *)msg, max); + } + + static int signal_by_name(const std::string& cond_name, int msg, + size_t max) + { + return WFTaskFactory::signal_by_name(cond_name, (void *)msg, max); + } +#endif }; template diff --git a/src/factory/WFTaskFactory.inl b/src/factory/WFTaskFactory.inl index 1492074f71..8f11411490 100644 --- a/src/factory/WFTaskFactory.inl +++ b/src/factory/WFTaskFactory.inl @@ -18,6 +18,7 @@ Li Yingxin (liyingxin@sogou-inc.com) */ +#include #include #include #include