data:image/s3,"s3://crabby-images/fd9e7/fd9e7f4a62db3e94906bf16ea96114b87e42e616" alt=""
On Mar 10, 2006, at 2:41 PM, Scott Meyers wrote:
It took me a little while to figure out that get<T> on a variant is really just the moral equivalent of dynamic_cast<T> with a funny syntax. I'd like to understand why, given a variant v, this syntax is used
T* p = get<T>(&v); T& r = get<T>(v);
instead of this:
T* p = variant_cast
(&v); T& r = variant_cast (v); [snip] Maybe there are problems to these approaches -- I've hardly investigated them. But I would be interested to know if there is a good reason for the syntaxes for dynamic_cast, any_cast, and get to vary so much.
I think the answer is more archeological than technical :)
We can't overload dynamic_cast, which is too bad: that's the right
name for this sort of thing. If only someone would go ahead and write
the C++0x proposal to add overloading of the cast operators, smart
pointers, any, variant, python::object, and many other classes would
get much more intuitive syntax. But I digress...
any_cast() came around first. It probably should have had the syntax
"T* p = any_cast