From 6375e5f79a5f73ffa42edf53e76ef498f3b43ca2 Mon Sep 17 00:00:00 2001 From: Vraiment Date: Mon, 31 Jul 2017 00:16:42 -0700 Subject: [PATCH] Added class to identify EventHandlerFunctors with template metaprogramming --- CMakeLists.txt | 1 + SDL2pp/Private/EventHandlerFunctor.hh | 60 +++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 SDL2pp/Private/EventHandlerFunctor.hh diff --git a/CMakeLists.txt b/CMakeLists.txt index b31df9a..90d6c72 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -158,6 +158,7 @@ SET(LIBRARY_HEADERS SDL2pp/Texture.hh SDL2pp/Wav.hh SDL2pp/Window.hh + SDL2pp/Private/EventHandlerFunctor.hh SDL2pp/Private/Utility.hh ) diff --git a/SDL2pp/Private/EventHandlerFunctor.hh b/SDL2pp/Private/EventHandlerFunctor.hh new file mode 100644 index 0000000..17ca78b --- /dev/null +++ b/SDL2pp/Private/EventHandlerFunctor.hh @@ -0,0 +1,60 @@ +/* + libSDL2pp - C++11 bindings/wrapper for SDL2 + Copyright (C) 2017 Vraiment + + This software is provided 'as-is', without any express or implied + warranty. In no event will the authors be held liable for any damages + arising from the use of this software. + + Permission is granted to anyone to use this software for any purpose, + including commercial applications, and to alter it and redistribute it + freely, subject to the following restrictions: + + 1. The origin of this software must not be misrepresented; you must not + claim that you wrote the original software. If you use this software + in a product, an acknowledgment in the product documentation would be + appreciated but is not required. + 2. Altered source versions must be plainly marked as such, and must not be + misrepresented as being the original software. + 3. This notice may not be removed or altered from any source distribution. +*/ + +#ifndef SDL2PP_PRIVATE_EVENTHANDLERFUNCTOR_HH +#define SDL2PP_PRIVATE_EVENTHANDLERFUNCTOR_HH + +#include +#include + +namespace SDL2pp { +/* + * This is code not to be used directly by users of SDL2pp. + */ +namespace Private { + /* + * Helper alias to help identify a functor object with the correct signature + * to be used as an event handler. + */ + template + using EventHandlerFunctorSignature = std::function; + + /* + * Templated class to identify a class that is not an event handler functor. + */ + template + struct IsEventHandlerFunctor : std::false_type { }; + + /* + * Templated class to identify a class that is an event handler functor, the + * way this is done is by verifying if the functor is assignable to the + * expected signature. + */ + template + struct IsEventHandlerFunctor< + EventHandlerType, + EventType, + std::is_convertible> + > : std::true_type { }; +} +} + +#endif