mirror of
https://github.com/FairRootGroup/FairMQ.git
synced 2025-10-16 01:51:45 +00:00
Fix copy constructor & assignment operator warning in FairMQChannel
Fix Weffc++ warnings - Add missing copy constructors and assignment operators . - Hide the warning from FairMQStateMachine.h where it is produced by boost and/or is intended. - Some code cleanup.
This commit is contained in:
committed by
Florian Uhlig
parent
9a0a8c7516
commit
e4fed2fa1b
@@ -6,7 +6,7 @@
|
||||
*/
|
||||
|
||||
#ifndef BASEPROCESSORTASKPOLICY_H
|
||||
#define BASEPROCESSORTASKPOLICY_H
|
||||
#define BASEPROCESSORTASKPOLICY_H
|
||||
|
||||
|
||||
#include <type_traits>
|
||||
@@ -14,31 +14,27 @@
|
||||
template <typename TDerived >
|
||||
class BaseProcessorTaskPolicy
|
||||
{
|
||||
public:
|
||||
BaseProcessorTaskPolicy()
|
||||
{}
|
||||
public:
|
||||
BaseProcessorTaskPolicy() {}
|
||||
|
||||
virtual ~BaseProcessorTaskPolicy()
|
||||
{}
|
||||
virtual ~BaseProcessorTaskPolicy() {}
|
||||
|
||||
template<typename C = TDerived>
|
||||
auto GetOutputData() -> decltype(static_cast<C*>(this)->GetOutputData() )
|
||||
auto GetOutputData() -> decltype(static_cast<C*>(this)->GetOutputData())
|
||||
{
|
||||
static_assert(std::is_same<C, TDerived>{}, "BaseProcessorTaskPolicy::GetOutputData hack broken");
|
||||
return static_cast<TDerived*>(this)->GetOutputData();
|
||||
static_assert(std::is_same<C, TDerived>{}, "BaseProcessorTaskPolicy::GetOutputData hack broken");
|
||||
return static_cast<TDerived*>(this)->GetOutputData();
|
||||
}
|
||||
|
||||
template<typename CONTAINER_TYPE, typename C = TDerived>
|
||||
auto ExecuteTask(CONTAINER_TYPE container) -> decltype( static_cast<C*>(this)->ExecuteTask(container) )
|
||||
auto ExecuteTask(CONTAINER_TYPE container) -> decltype( static_cast<C*>(this)->ExecuteTask(container))
|
||||
{
|
||||
static_assert(std::is_same<C, TDerived>{}, "BaseProcessorTaskPolicy::ExecuteTask hack broken");
|
||||
return static_cast<TDerived*>(this)->ExecuteTask(container);
|
||||
static_assert(std::is_same<C, TDerived>{}, "BaseProcessorTaskPolicy::ExecuteTask hack broken");
|
||||
return static_cast<TDerived*>(this)->ExecuteTask(container);
|
||||
}
|
||||
|
||||
|
||||
};
|
||||
|
||||
/*
|
||||
/*
|
||||
|
||||
// c++14 code only
|
||||
// CRTP base class
|
||||
@@ -65,5 +61,5 @@ public:
|
||||
|
||||
};
|
||||
*/
|
||||
#endif /* BASEPROCESSORTASKPOLICY_H */
|
||||
|
||||
#endif /* BASEPROCESSORTASKPOLICY_H */
|
||||
|
Reference in New Issue
Block a user