add constness policy to doc
git-svn-id: svn://svn.code.sf.net/p/loki-lib/code/trunk@556 7ec92016-0320-0410-acc4-a06ded1c099a
This commit is contained in:
parent
fdea0be349
commit
8139b0efdb
1 changed files with 36 additions and 31 deletions
|
@ -791,7 +791,8 @@ namespace Loki
|
||||||
template <class> class OwnershipPolicy = RefCounted,
|
template <class> class OwnershipPolicy = RefCounted,
|
||||||
class ConversionPolicy = DisallowConversion,
|
class ConversionPolicy = DisallowConversion,
|
||||||
template <class> class CheckingPolicy = AssertCheck,
|
template <class> class CheckingPolicy = AssertCheck,
|
||||||
template <class> class StoragePolicy = DefaultSPStorage
|
template <class> class StoragePolicy = DefaultSPStorage,
|
||||||
|
template<class> class ConstnessPolicy = LOKI_DEFAULT_CONSTNESS
|
||||||
>
|
>
|
||||||
struct SmartPtrDef
|
struct SmartPtrDef
|
||||||
{
|
{
|
||||||
|
@ -801,7 +802,8 @@ namespace Loki
|
||||||
OwnershipPolicy,
|
OwnershipPolicy,
|
||||||
ConversionPolicy,
|
ConversionPolicy,
|
||||||
CheckingPolicy,
|
CheckingPolicy,
|
||||||
StoragePolicy
|
StoragePolicy,
|
||||||
|
ConstnessPolicy
|
||||||
>
|
>
|
||||||
type;
|
type;
|
||||||
};
|
};
|
||||||
|
@ -815,6 +817,7 @@ namespace Loki
|
||||||
/// \param ConversionPolicy default = DisallowConversion,
|
/// \param ConversionPolicy default = DisallowConversion,
|
||||||
/// \param CheckingPolicy default = AssertCheck,
|
/// \param CheckingPolicy default = AssertCheck,
|
||||||
/// \param StoragePolicy default = DefaultSPStorage
|
/// \param StoragePolicy default = DefaultSPStorage
|
||||||
|
/// \param ConstnessPolicy default = LOKI_DEFAULT_CONSTNESS
|
||||||
///
|
///
|
||||||
/// \par IMPORTANT NOTE
|
/// \par IMPORTANT NOTE
|
||||||
/// Due to threading issues, the OwnershipPolicy has been changed as follows:
|
/// Due to threading issues, the OwnershipPolicy has been changed as follows:
|
||||||
|
@ -852,9 +855,8 @@ namespace Loki
|
||||||
typedef typename SP::StoredType StoredType;
|
typedef typename SP::StoredType StoredType;
|
||||||
typedef typename SP::ReferenceType ReferenceType;
|
typedef typename SP::ReferenceType ReferenceType;
|
||||||
|
|
||||||
typedef typename Select<OP::destructiveCopy,
|
typedef typename Select<OP::destructiveCopy,SmartPtr, const SmartPtr>::Result
|
||||||
SmartPtr, const SmartPtr>::Result
|
CopyArg;
|
||||||
CopyArg;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
struct NeverMatched;
|
struct NeverMatched;
|
||||||
|
@ -1136,10 +1138,10 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator!=(const SmartPtr<T, OP, CP, KP, SP, CNP1 >& lhs,
|
inline bool operator!=(const SmartPtr<T, OP, CP, KP, SP, CNP >& lhs,
|
||||||
U* rhs)
|
U* rhs)
|
||||||
{ return !(lhs == rhs); }
|
{ return !(lhs == rhs); }
|
||||||
|
|
||||||
|
@ -1155,11 +1157,11 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator!=(U* lhs,
|
inline bool operator!=(U* lhs,
|
||||||
const SmartPtr<T, OP, CP, KP, SP, CNP1 >& rhs)
|
const SmartPtr<T, OP, CP, KP, SP, CNP >& rhs)
|
||||||
{ return rhs != lhs; }
|
{ return rhs != lhs; }
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -1174,10 +1176,10 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator<(const SmartPtr<T, OP, CP, KP, SP, CNP1 >& lhs,
|
inline bool operator<(const SmartPtr<T, OP, CP, KP, SP, CNP >& lhs,
|
||||||
U* rhs);
|
U* rhs);
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -1192,11 +1194,11 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator<(U* lhs,
|
inline bool operator<(U* lhs,
|
||||||
const SmartPtr<T, OP, CP, KP, SP, CNP1 >& rhs);
|
const SmartPtr<T, OP, CP, KP, SP, CNP >& rhs);
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// operator> for lhs = SmartPtr, rhs = raw pointer -- NOT DEFINED
|
// operator> for lhs = SmartPtr, rhs = raw pointer -- NOT DEFINED
|
||||||
|
@ -1210,10 +1212,10 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator>(const SmartPtr<T, OP, CP, KP, SP, CNP1 >& lhs,
|
inline bool operator>(const SmartPtr<T, OP, CP, KP, SP, CNP >& lhs,
|
||||||
U* rhs)
|
U* rhs)
|
||||||
{ return rhs < lhs; }
|
{ return rhs < lhs; }
|
||||||
|
|
||||||
|
@ -1229,11 +1231,11 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator>(U* lhs,
|
inline bool operator>(U* lhs,
|
||||||
const SmartPtr<T, OP, CP, KP, SP, CNP1 >& rhs)
|
const SmartPtr<T, OP, CP, KP, SP, CNP >& rhs)
|
||||||
{ return rhs < lhs; }
|
{ return rhs < lhs; }
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -1248,10 +1250,10 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator<=(const SmartPtr<T, OP, CP, KP, SP, CNP1 >& lhs,
|
inline bool operator<=(const SmartPtr<T, OP, CP, KP, SP, CNP >& lhs,
|
||||||
U* rhs)
|
U* rhs)
|
||||||
{ return !(rhs < lhs); }
|
{ return !(rhs < lhs); }
|
||||||
|
|
||||||
|
@ -1267,11 +1269,11 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator<=(U* lhs,
|
inline bool operator<=(U* lhs,
|
||||||
const SmartPtr<T, OP, CP, KP, SP, CNP1 >& rhs)
|
const SmartPtr<T, OP, CP, KP, SP, CNP >& rhs)
|
||||||
{ return !(rhs < lhs); }
|
{ return !(rhs < lhs); }
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -1286,10 +1288,10 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator>=(const SmartPtr<T, OP, CP, KP, SP, CNP1 >& lhs,
|
inline bool operator>=(const SmartPtr<T, OP, CP, KP, SP, CNP >& lhs,
|
||||||
U* rhs)
|
U* rhs)
|
||||||
{ return !(lhs < rhs); }
|
{ return !(lhs < rhs); }
|
||||||
|
|
||||||
|
@ -1305,11 +1307,11 @@ namespace Loki
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1,
|
template <class> class CNP,
|
||||||
typename U
|
typename U
|
||||||
>
|
>
|
||||||
inline bool operator>=(U* lhs,
|
inline bool operator>=(U* lhs,
|
||||||
const SmartPtr<T, OP, CP, KP, SP, CNP1 >& rhs)
|
const SmartPtr<T, OP, CP, KP, SP, CNP >& rhs)
|
||||||
{ return !(lhs < rhs); }
|
{ return !(lhs < rhs); }
|
||||||
|
|
||||||
} // namespace Loki
|
} // namespace Loki
|
||||||
|
@ -1328,14 +1330,14 @@ namespace std
|
||||||
class CP,
|
class CP,
|
||||||
template <class> class KP,
|
template <class> class KP,
|
||||||
template <class> class SP,
|
template <class> class SP,
|
||||||
template <class> class CNP1
|
template <class> class CNP
|
||||||
>
|
>
|
||||||
struct less< Loki::SmartPtr<T, OP, CP, KP, SP, CNP1 > >
|
struct less< Loki::SmartPtr<T, OP, CP, KP, SP, CNP > >
|
||||||
: public binary_function<Loki::SmartPtr<T, OP, CP, KP, SP, CNP1 >,
|
: public binary_function<Loki::SmartPtr<T, OP, CP, KP, SP, CNP >,
|
||||||
Loki::SmartPtr<T, OP, CP, KP, SP, CNP1 >, bool>
|
Loki::SmartPtr<T, OP, CP, KP, SP, CNP >, bool>
|
||||||
{
|
{
|
||||||
bool operator()(const Loki::SmartPtr<T, OP, CP, KP, SP, CNP1 >& lhs,
|
bool operator()(const Loki::SmartPtr<T, OP, CP, KP, SP, CNP >& lhs,
|
||||||
const Loki::SmartPtr<T, OP, CP, KP, SP, CNP1 >& rhs) const
|
const Loki::SmartPtr<T, OP, CP, KP, SP, CNP >& rhs) const
|
||||||
{ return less<T*>()(GetImpl(lhs), GetImpl(rhs)); }
|
{ return less<T*>()(GetImpl(lhs), GetImpl(rhs)); }
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1359,6 +1361,9 @@ namespace std
|
||||||
#endif // SMARTPTR_INC_
|
#endif // SMARTPTR_INC_
|
||||||
|
|
||||||
// $Log$
|
// $Log$
|
||||||
|
// Revision 1.20 2006/02/25 13:48:54 syntheticpp
|
||||||
|
// add constness policy to doc
|
||||||
|
//
|
||||||
// Revision 1.19 2006/02/25 13:01:40 syntheticpp
|
// Revision 1.19 2006/02/25 13:01:40 syntheticpp
|
||||||
// add const member function OnDereference to non static RejectNull policies
|
// add const member function OnDereference to non static RejectNull policies
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in a new issue