aboutsummaryrefslogtreecommitdiff
path: root/src/function/detail/apply.h
diff options
context:
space:
mode:
authorAdrian Kummerlaender2015-02-19 21:07:57 +0100
committerAdrian Kummerlaender2015-02-19 21:07:57 +0100
commit397264a5e0046d9c84d8de41b9683ae695c516e0 (patch)
treebebe4e2438e1ee26a25fb3861fd3aed12768096e /src/function/detail/apply.h
parenta07999f7436802f15fc21bebd083006c9e681638 (diff)
downloadTypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.tar
TypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.tar.gz
TypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.tar.bz2
TypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.tar.lz
TypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.tar.xz
TypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.tar.zst
TypeAsValue-397264a5e0046d9c84d8de41b9683ae695c516e0.zip
Moved `Apply`'s placeholder into separate detail header
* separate actual `Apply` specializations in `detail/apply.h` from placeholder details
Diffstat (limited to 'src/function/detail/apply.h')
-rw-r--r--src/function/detail/apply.h32
1 files changed, 3 insertions, 29 deletions
diff --git a/src/function/detail/apply.h b/src/function/detail/apply.h
index aca0af4..2f4c782 100644
--- a/src/function/detail/apply.h
+++ b/src/function/detail/apply.h
@@ -1,38 +1,11 @@
#ifndef TYPEASVALUE_SRC_FUNCTION_DETAIL_APPLY_H_
#define TYPEASVALUE_SRC_FUNCTION_DETAIL_APPLY_H_
-#include <type_traits>
-
-#include "list/list.h"
-#include "list/operation/nth.h"
-#include "list/operation/higher/query.h"
+#include "placeholder.h"
namespace tav {
-namespace detail {
-
-struct placeholder_tag { };
-
-template <typename Type>
-using is_placeholder = Eval<std::is_base_of<placeholder_tag, Type>>;
-
-template <int Index>
-struct placeholder : placeholder_tag { };
-
-template <typename, typename Argument>
-struct resolve_placeholder {
- typedef Argument type;
-};
-template <
- typename Partials,
- int Index
->
-struct resolve_placeholder<Partials, placeholder<Index>> {
- typedef Nth<Size<Index>, Partials> type;
-};
-
-template <typename... Arguments>
-using count_placeholders = Count<is_placeholder, List<Arguments...>>;
+namespace detail {
template <
template<typename...> class Function,
@@ -81,6 +54,7 @@ struct apply_pair : apply_variadic<Function, Arguments...> {
};
}
+
}
#endif // TYPEASVALUE_SRC_FUNCTION_DETAIL_APPLY_H_