boost::serialization::null_deleter
data:image/s3,"s3://crabby-images/c7773/c7773ea3d0da878608e57b8f0ec0983286401768" alt=""
Hi!
I am using boost::serialization::detail::null_deleter in combination
with shared_ptr (on boost 1.34/35) - and I am having a user of my
program compiling my program (on boost 1.41) who says he has to change
that line to just boost::serialization::null_deleter to get it to work.
Should I work around this with pre-processor checks, and in that case -
what versions should I look for?
Or is there a simpler fix?
thanks in advance
--
Andreas Ronnquist
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG Andreas Ronnquist wrote:
I am using boost::serialization::detail::null_deleter in combination with shared_ptr (on boost 1.34/35) - and I am having a user of my program compiling my program (on boost 1.41) who says he has to change that line to just boost::serialization::null_deleter to get it to work.
Should I work around this with pre-processor checks, and in that case - what versions should I look for?
Or is there a simpler fix?
If something in boost is in a namespace called detail, it's considered an implementation detail. If you use it, you're on your own as far as compatibility goes. In Christ, Steven Watanabe
data:image/s3,"s3://crabby-images/3e82c/3e82ccc202ec258b0b6ee3d319246dddb1f0ae3c" alt=""
Hmmm - I'd have to spend more time on it to give a good answer. In any case, the latest version in the trunk - and maybe release - I forgot has null_deleter replaced with something else to fix a bug. Robert Ramey Andreas Ronnquist wrote:
Hi!
I am using boost::serialization::detail::null_deleter in combination with shared_ptr (on boost 1.34/35) - and I am having a user of my program compiling my program (on boost 1.41) who says he has to change that line to just boost::serialization::null_deleter to get it to work.
Should I work around this with pre-processor checks, and in that case - what versions should I look for?
Or is there a simpler fix?
thanks in advance
data:image/s3,"s3://crabby-images/c7773/c7773ea3d0da878608e57b8f0ec0983286401768" alt=""
Thanks guys (both Robert and Steven) - I managed to work my way around
it by providing a null_deleter of my own:
template<typename T>
struct null_deleter
{
void operator()(T *) const {}
};
which of course makes me able to compile/run no matter what boost
version (in this case anyway).
Thanks!
On Mon, 21 Dec 2009 16:13:02 -0800
"Robert Ramey"
Hmmm - I'd have to spend more time on it to give a good answer.
In any case, the latest version in the trunk - and maybe release - I forgot has null_deleter replaced with something else to fix a bug.
Robert Ramey
<snip>
data:image/s3,"s3://crabby-images/9ad60/9ad60a4d1f52e43cc8e1c6cdc198dca641b34916" alt=""
Andreas Rönnquist wrote:
Thanks guys (both Robert and Steven) - I managed to work my way around it by providing a null_deleter of my own:
template<typename T> struct null_deleter { void operator()(T *) const {} };
This is what I was going to suggest :-) but you may find one of the following null deleters better: struct null_deleter { template<class T> void operator()(T *) const {} }; struct null_deleter { void operator()(void const *) const {} };
participants (5)
-
Andreas Ronnquist
-
Andreas Rönnquist
-
Peter Dimov
-
Robert Ramey
-
Steven Watanabe