I've been on this problem all morning with no result whatsoever. Basically, I need a simple metaprogramming thing that allows me to branch to different specializations if the parameter passed is a kind of std::vector or not.
Some kind of is_base_of for templates.
Does such a thing exist ?
In C++11 you can also do it in a more generic way:
#include <type_traits> #include <iostream> #include <vector> #include <list>  template<typename Test, template<typename...> class Ref> struct is_specialization : std::false_type {};  template<template<typename...> class Ref, typename... Args> struct is_specialization<Ref<Args...>, Ref>: std::true_type {};   int main() {     typedef std::vector<int> vec;     typedef int not_vec;     std::cout << is_specialization<vec, std::vector>::value << is_specialization<not_vec, std::vector>::value;      typedef std::list<int> lst;     typedef int not_lst;     std::cout << is_specialization<lst, std::list>::value << is_specialization<not_lst, std::list>::value; } If you need a trait class it's pretty simple, you only need a general template and a specialization over any std::vector:
#include <type_traits> #include <iostream> #include <vector>  template<typename> struct is_std_vector : std::false_type {};  template<typename T, typename A> struct is_std_vector<std::vector<T,A>> : std::true_type {};  int main() {     typedef std::vector<int> vec;     typedef int not_vec;     std::cout << is_std_vector<vec>::value << is_std_vector<not_vec>::value; } If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With