}
template <class SPolicy>
-prefix_ senf::SocketProtocol const & senf::SocketHandle<SPolicy>::protocol()
+prefix_ senf::SocketProtocol & senf::SocketHandle<SPolicy>::protocol()
const
{
return body().protocol();
template <class Target, class Source>
prefix_ Target senf::dynamic_socket_cast(Source handle)
{
- BOOST_STATIC_ASSERT((
- boost::is_convertible<Source*,FileHandle*>::value &&
- boost::is_convertible<Target*,FileHandle*>::value &&
- ( boost::is_convertible<Source,Target>::value ||
- boost::is_convertible<Target,Source>::value ) ));
+// BOOST_STATIC_ASSERT((
+// boost::is_convertible<Source*,FileHandle*>::value &&
+// boost::is_convertible<Target*,FileHandle*>::value &&
+// ( boost::is_convertible<Source,Target>::value ||
+// boost::is_convertible<Target,Source>::value ) ));
try {
return Target::cast_dynamic(handle);
}
template <class Target, class Source>
prefix_ bool senf::check_socket_cast(Source handle)
{
- BOOST_STATIC_ASSERT((
- boost::is_convertible<Source*,FileHandle*>::value &&
- boost::is_convertible<Target*,FileHandle*>::value &&
- ( boost::is_convertible<Source,Target>::value ||
- boost::is_convertible<Target,Source>::value ) ));
+// BOOST_STATIC_ASSERT((
+// boost::is_convertible<Source*,FileHandle*>::value &&
+// boost::is_convertible<Target*,FileHandle*>::value &&
+// ( boost::is_convertible<Source,Target>::value ||
+// boost::is_convertible<Target,Source>::value ) ));
// we don't have a non-throwing variant of cast_dynamic
// for two reasons:
// a) since the handle is passed back by value, we cannot return
template <class SPolicy>
template <class Facet>
-prefix_ Facet const & senf::SocketHandle<SPolicy>::facet()
+prefix_ Facet & senf::SocketHandle<SPolicy>::facet()
{
try {
- return dynamic_cast<Facet const &>(protocol());
+ return dynamic_cast<Facet &>(protocol());
}
SENF_WRAP_EXC(std::bad_cast)
}