我有以下类型的列表:
using ComponentList = brigand::list<TransformComponent, ObjectComponent, BodyComponent>如何将前一个列表转换为如下所示的新列表:
using ComponentHandleList = brigand::list<entityx::ComponentHandle<TransformComponent>, entityx::ComponentHandle<ObjectComponent>, entityx::ComponentHandle<BodyComponent>>;基本上,我想要生成一个新的列表,其中包含了前面列表中的每个元素的包装器。我试着用:
using ComponentHandleList = brigand::transform<ComponentList, AddComponentHandle<brigand::_1>>;但是我对元编程不太了解,并且未能实现struct AddComponentHandle<>,这将采用T类型并将其转换为entityx::ComponentHandle<T>。Brigand包含了有关通过使用文档将每个类型的T转换为T*的示例来转换类型列表的相关std::add_pointer<>。这也是我想要做的,但是从T到entityx::ComponentHandle<T>。如何转换第一个列表,使其看起来像第二个列表?
发布于 2018-11-19 06:54:30
#include <brigand/sequences/list.hpp>
#include <brigand/algorithms/transform.hpp>
#include <type_traits>
struct TransformComponent{};
struct ObjectComponent{};
struct BodyComponent{};
namespace entityx
{
template <typename Component>
struct ComponentHandle{};
}
using ComponentList = brigand::list<TransformComponent, ObjectComponent, BodyComponent>;
template <typename Comp>
using AddComponentHandle = entityx::ComponentHandle<Comp>;
template <typename Comp>
struct AddComponentHandle2
{
using type = entityx::ComponentHandle<Comp>;
};
using ComponentHandleList = brigand::transform<ComponentList, brigand::bind<AddComponentHandle,brigand::_1>>;
using ComponentHandleList2 = brigand::transform<ComponentList, AddComponentHandle2<brigand::_1>>;
int main()
{
static_assert(std::is_same<ComponentHandleList,
brigand::list<
entityx::ComponentHandle<TransformComponent>,
entityx::ComponentHandle<ObjectComponent>,
entityx::ComponentHandle<BodyComponent>
>
>::value
);
static_assert(std::is_same<ComponentHandleList2,
brigand::list<
entityx::ComponentHandle<TransformComponent>,
entityx::ComponentHandle<ObjectComponent>,
entityx::ComponentHandle<BodyComponent>
>
>::value
);
}发布于 2018-11-19 01:00:19
您可以使用
template<typename, template<typename...> class>
struct apply {};
template<template<typename...> class T, template<typename...> class List, typename ... Ts>
struct apply<List<Ts...>, T> {
using type = List<T<Ts>...>;
};它可以像这样使用
template<typename...>
struct A {};
template<typename...>
struct B {};
int main()
{
static_assert(std::is_same<apply<A<int, bool>, B>::type, A<B<int>, B<bool>>>::value);
}https://stackoverflow.com/questions/53366327
复制相似问题