aboutsummaryrefslogtreecommitdiffstats
path: root/library/cpp/actors
diff options
context:
space:
mode:
authorkruall <kruall@ydb.tech>2023-11-10 13:05:28 +0300
committerkruall <kruall@ydb.tech>2023-11-10 13:41:58 +0300
commitd84527173e1f76f9a00ffdef14af1c49cb8a502d (patch)
tree14f3e683744ec9eee2d217e11d02d2257405abc9 /library/cpp/actors
parent4c800ac80af5ac83fcc772491904d0aa8e87949c (diff)
downloadydb-d84527173e1f76f9a00ffdef14af1c49cb8a502d.tar.gz
Check stateFunc type before assign it, KIKIMR-19280
Diffstat (limited to 'library/cpp/actors')
-rw-r--r--library/cpp/actors/core/actor.h43
1 files changed, 40 insertions, 3 deletions
diff --git a/library/cpp/actors/core/actor.h b/library/cpp/actors/core/actor.h
index 7452b50571..96a8f5d05a 100644
--- a/library/cpp/actors/core/actor.h
+++ b/library/cpp/actors/core/actor.h
@@ -651,6 +651,8 @@ namespace NActors {
template <typename TDerived>
class TActor: public IActorCallback {
private:
+ using TDerivedReceiveFunc = void (TDerived::*)(TAutoPtr<IEventHandle>& ev);
+
template <typename T, typename = const char*>
struct HasActorName: std::false_type {};
template <typename T>
@@ -682,21 +684,56 @@ namespace NActors {
protected:
// static constexpr char ActorName[] = "UNNAMED";
- TActor(void (TDerived::* func)(TAutoPtr<IEventHandle>& ev))
+ TActor(TDerivedReceiveFunc func)
: IActorCallback(static_cast<TReceiveFunc>(func), GetActivityTypeIndex()) {
}
template <class TEnum = EActivityType>
- TActor(void (TDerived::* func)(TAutoPtr<IEventHandle>& ev), const TEnum activityEnumType = EActivityType::OTHER)
+ TActor(TDerivedReceiveFunc func, const TEnum activityEnumType = EActivityType::OTHER)
: IActorCallback(static_cast<TReceiveFunc>(func), activityEnumType) {
}
- TActor(void (TDerived::* func)(TAutoPtr<IEventHandle>& ev), const TString& actorName)
+ TActor(TDerivedReceiveFunc func, const TString& actorName)
: IActorCallback(static_cast<TReceiveFunc>(func), TLocalProcessKeyState<TActorActivityTag>::GetInstance().Register(actorName)) {
}
public:
typedef TDerived TThis;
+
+ // UnsafeBecome methods don't verify the bindings of the stateFunc to the TDerived
+ template <typename T>
+ void UnsafeBecome(T stateFunc) {
+ this->IActorCallback::Become(stateFunc);
+ }
+
+ template <typename T, typename... TArgs>
+ void UnsafeBecome(T stateFunc, const TActorContext& ctx, TArgs&&... args) {
+ this->IActorCallback::Become(stateFunc, ctx, std::forward<TArgs>(args)...);
+ }
+
+ template <typename T, typename... TArgs>
+ void UnsafeBecome(T stateFunc, TArgs&&... args) {
+ this->IActorCallback::Become(stateFunc, std::forward<TArgs>(args)...);
+ }
+
+ template <typename T>
+ void Become(T stateFunc) {
+ // TODO(kruall): have to uncomment asserts after end of sync contrib/ydb
+ // static_assert(std::is_convertible_v<T, TDerivedReceiveFunc>);
+ this->IActorCallback::Become(stateFunc);
+ }
+
+ template <typename T, typename... TArgs>
+ void Become(T stateFunc, const TActorContext& ctx, TArgs&&... args) {
+ // static_assert(std::is_convertible_v<T, TDerivedReceiveFunc>);
+ this->IActorCallback::Become(stateFunc, ctx, std::forward<TArgs>(args)...);
+ }
+
+ template <typename T, typename... TArgs>
+ void Become(T stateFunc, TArgs&&... args) {
+ // static_assert(std::is_convertible_v<T, TDerivedReceiveFunc>);
+ this->IActorCallback::Become(stateFunc, std::forward<TArgs>(args)...);
+ }
};