can't extend boost::any on windows
data:image/s3,"s3://crabby-images/2a6d7/2a6d770d5505aecf8f2432579255b1a85cce8819" alt=""
Hi, I've implemented a simple, low level json formatting utility to
complement tinyjson's lightweight parser. To do this, I've extended
boost::any only to add a "format()" function to it that is aware of what
types the content can take in a json structure and produces the
appropriate string. The default constructor and the constructor with a
value are the only things I implemented, aside from the format
function. Both just call the base constructor. Compiled in gcc,
everything works fabulously. Apparently, a functioning assignment
operator and copy constructor are appropriately inherited and everything
runs great. On windows, however, some subtle difference causes
assignment and copies to seg-fault. The real problem is that, for the
life of me, I can't find a way to implement assignment or copies
explicitly, that doesn't also bomb out. I can probably come up with a
work around that stores my type in shared pointers so they're never
actually copied, but I'm really curious if anyone could explain what
causes this. Here are some code snippets to illustrate the behavior:
void test(){
std::cout<<"messing around with boost
any"<
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG Michael Linck wrote:
Hi, I've implemented a simple, low level json formatting utility to complement tinyjson's lightweight parser. To do this, I've extended boost::any only to add a "format()" function to it that is aware of what types the content can take in a json structure and produces the appropriate string. The default constructor and the constructor with a value are the only things I implemented, aside from the format function. Both just call the base constructor. Compiled in gcc, everything works fabulously. Apparently, a functioning assignment operator and copy constructor are appropriately inherited and everything runs great. On windows, however, some subtle difference causes assignment and copies to seg-fault. The real problem is that, for the life of me, I can't find a way to implement assignment or copies explicitly, that doesn't also bomb out. I can probably come up with a work around that stores my type in shared pointers so they're never actually copied, but I'm really curious if anyone could explain what causes this. Here are some code snippets to illustrate the behavior:
<snip>
I'm not going to list the different ways I've attempted to implement copy and assignment, some more plausible than others, out of respect for brevity. If you try a build on windows, VC8, you should be able to mess around with this to your hearts content. It's really annoying because it was a factor in the fundamental elegance of the parsing implementation, because I see no reason why it shouldn't work, because it worked fine in linux, and because it put my windows port at least a day behind customer expectations.
msvc gets the copy constructor and assignment operator wrong in
the presence of a templated base class constructor/assignment operator.
You need to define them explicitly.
class Value : public boost::any {
public:
// <snip>
Value(const Value& arg) : boost::any(static_cast
data:image/s3,"s3://crabby-images/2a6d7/2a6d770d5505aecf8f2432579255b1a85cce8819" alt=""
msvc gets the copy constructor and assignment operator wrong in the presence of a templated base class constructor/assignment operator.
You need to define them explicitly.
class Value : public boost::any { public: // <snip> Value(const Value& arg) : boost::any(static_cast
(arg)){} Value& operator=(const Value& arg) { static_cast (*this) = static_cast (arg); } };
thanks, I was trying to do about the same thing, but using reinterpret_cast, which also caused unrecoverable errors. I guess I'm not sure what the semantic difference between the two is, but that's probably a question for a different list and a different day. In the meantime, I made my type non-copyable, wrapped it in shared_ptrs which is faster anyway, and got it working that way. But your I definitely appreciate the answer since that would have been bugging me for days otherwise. mike
data:image/s3,"s3://crabby-images/901b9/901b92bedbe00b09b23de814be508bc893a8e94d" alt=""
-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 On Tuesday 16 December 2008 13:49 pm, Steven Watanabe wrote:
Value& operator=(const Value& arg) { static_cast
(*this) = static_cast (arg);
Shouldn't the left hand side cast be "static_castboost::any&(*this)" ?
} };
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.6 (GNU/Linux) iD8DBQFJSA9t5vihyNWuA4URAqiWAJ9645ffY4wvfxQgcwKF/rvOwVztPgCfTz8U 8dNQyxoP2rmc1i1u/hA+m3c= =ayUi -----END PGP SIGNATURE-----
participants (3)
-
Frank Mori Hess
-
Michael Linck
-
Steven Watanabe