Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to declare a self referencing template type

Tags:

c++

templates

I've a situation that is like this contrived example:

template<class TFeature> struct Controller {};

template<class TController,typename T> struct Feature {
  typedef Feature<TController,T> FeatureType;
};

typedef Controller<Feature::FeatureType,int> DefaultController;

The Controller is templated to accept features and my problem is that some of the features need the type of the controller as a template parameter. This makes the typedef on the last line of the sample not compile.

Is this possible or do I need to rethink the design?

like image 744
Andy Brown Avatar asked Oct 22 '22 05:10

Andy Brown


2 Answers

In order to accomplish this you should do some meta programming magic(and believe me it is not an easy task). But if you really nead it and using boost is an option for you take a look at boost::mpl and you can have something like this:

template< class ControlerT >
struct FeatureEx {
    typedef ControlerT controler_type;
};
template< class FeatureT >
struct ControlerEx {
    typedef ControlerEx<FeatureT> this_type;
    typedef typename boost::mpl::apply<
        FeatureT, boost::mpl::identity<this_type>
    >::type feature_type;

    feature_type const& get_feature() const {return f_;}

private:
    feature_type f_;
};

typedef ControlerEx<FeatureEx<boost::mpl::placeholders::_1> > DefaultControler;
like image 75
BigBoss Avatar answered Oct 31 '22 12:10

BigBoss


You are passing to the Controller class two template parameters, but you have declared it to take only one. Do you need something like the following?

typedef Controller<Feature<Controller<int>,int>::FeatureType> DefaultController;
like image 42
Rontogiannis Aristofanis Avatar answered Oct 31 '22 12:10

Rontogiannis Aristofanis