I need to create a map, from integers to sets of tuples, the tuples in a single set have the same size. The problem is that the size of a tuple and its parameter types can be determined at runtime, not compile time. I am imagining something like:
std::map<int, std::set<boost::tuple> >
but not exctly sure how to exactly do this, bossibly using pointers.
The purpose of this is to create temporary relations (tables), each with a unique identifier (key), maybe you have another approach.
If the parameter types have something in common, capture that into an abstract base class and make the tuple contain pointers to this base class:
(boost::tuple omitted for brevity. Not sure why you need a set of tuples.)
You can then derive the concrete parameter types from MyParamBase and create and insert them into the map:
If the parameter types have nothing in common - do not put them into the same map. Quite likely they do not belong together.
You can only store these different sets in the same collection if you have some common base class for them. You could write an abstract interface, and then implement that for each kind of table/tuple. The problem is, that usually such interfaces tend to be very messy, and you would possibly have class-explosion if you have many types of table/tuples. Boost.Any could be useful for such an interface (since you have to handle different datatypes dynamically).
As a modern side-note (as previous answers are circa 2010), today's Variadic Templates would be useful for this:
The purpose of
boost::tuple
is to mix arbitrary types. If, as you say,then you should use
map< int, set< vector< int > > >
. (If I were you, I'd throw sometypedef
s at that.)To answer the original question, though,
boost::tuple
doesn't allow arbitrary types at runtime.boost::any
does. However,any
does not support comparison so there's a little more work if you want to use it in aset
.