Boost logo

Boost Users :

From: Marc Mutz (marc_at_[hidden])
Date: 2006-03-14 02:34:47


Hi,

In 1.33.1, comparing an optional<T> to it's T fails, since although T
implicitly converts to optional<T>, op== being templated, implicit
conversions are not considered. Is this by design? If so, what's the
rationale for this? I repeatedly find myself in the need to compare an
optional<T> member to a passed in T, e.g. in a setT( const T & ), in order to
check for a no-op operation and suppress notifications in this case, e.g.:

class Foo {
  boost::optional<T> mT;
  boost::signal< void(const optional<T>&) > tChangedSignal;
  void setT( const T & t ) {
    if ( t == mT ) return;
    mT = t;
    tChangedSignal( mT );
    // mark cached values dirty, etc, etc...
  }
};

-- 
Marc Mutz -- marc_at_[hidden], mutz_at_[hidden]
Klarälvdalens Datakonsult AB, Platform-independent software solutions

Boost-users list run by williamkempf at hotmail.com, kalb at libertysoft.com, bjorn.karlsson at readsoft.com, gregod at cs.rpi.edu, wekempf at cox.net