Program Listing for File refmacros.hpp

Return to documentation for file (/tmp/ws/src/fastrtps/include/dds/core/refmacros.hpp)

/*
 * Copyright 2010, Object Management Group, Inc.
 * Copyright 2010, PrismTech, Corp.
 * Copyright 2010, Real-Time Innovations, Inc.
 * Copyright 2019, Proyectos y Sistemas de Mantenimiento SL (eProsima).
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef OMG_DDS_CORE_REFMACROS_HPP_
#define OMG_DDS_CORE_REFMACROS_HPP_

// Macros

#define DECLARE_TYPE_TRAITS(TYPE) \
    typedef TYPE TYPE ## _T; \
    typedef typename ::dds::core::smart_ptr_traits<TYPE>::ref_type TYPE ## _REF_T; \
    typedef typename ::dds::core::smart_ptr_traits<TYPE>::weak_ref_type TYPE ## _WEAK_REF_T;


/*
 * This macro defines all the functions that Reference Types have to implement.
 */
// Defines all the types, functions and attributes required for a Reference type
// without default ctor.
//

#define OMG_DDS_REF_TYPE_BASE(TYPE, BASE, DELEGATE)     \
public: \
    typedef typename ::dds::core::smart_ptr_traits< DELEGATE >::ref_type DELEGATE_REF_T; \
    typedef typename ::dds::core::smart_ptr_traits< DELEGATE >::weak_ref_type DELEGATE_WEAK_REF_T; \
    \
protected: \
    const typename ::dds::core::Reference< DELEGATE >::DELEGATE_REF_T& impl() const \
    { return ::dds::core::Reference< DELEGATE >::impl_; } \
    typename ::dds::core::Reference< DELEGATE >::DELEGATE_REF_T& impl() \
    { return ::dds::core::Reference< DELEGATE >::impl_; } \
    \
public: \
    typedef BASE< DELEGATE >                                                  BASE_T; \
    \
public: \
    TYPE(const dds::core::null_type&) : dds::core::Reference< DELEGATE >(static_cast<DELEGATE*>(NULL)) { } \
    \
    TYPE& operator =( \
    const dds::core::null_type& rhs) { \
        *this = TYPE(rhs); \
        return *this; \
    } \
    \
public: \
    TYPE(const DELEGATE_REF_T &ref) \
        : dds::core::Reference< DELEGATE >(ref) \
    { }

#define OMG_DDS_IMPLICIT_REF_BASE(TYPE)         \
public: \
    template<typename H__> \
    TYPE(const H__ &h)    \
    { \
        if (h.is_nil()){ \
            /* We got a null object and are not really able to do a typecheck here. */ \
            /* So, just set a null object. */ \
            *this = dds::core::null; \
        } else { \
            this->impl_ = h.delegate(); \
            if (h.delegate() != this->::dds::core::Reference< DELEGATE_T >::impl_){ \
                throw dds::core::IllegalOperationError(std::string( \
                                  "Attempted invalid cast: ") + typeid(h).name() + " to " + typeid(*this).name()); \
            } \
        } \
    } \
    \
    template<typename T__> \
    TYPE& \
    operator =( \
    const T__& rhs) { \
        if (this != (TYPE*)&rhs){ \
            if (rhs.is_nil()){ \
                /* We got a null object and are not really able to do a typecheck here. */ \
                /* So, just set a null object. */ \
                *this = dds::core::null; \
            } else { \
                TYPE other(rhs); \
                /* Dont have to copy when the delegate impl is the same. */ \
                if (other.delegate() != this->::dds::core::Reference< DELEGATE_T >::impl_){ \
                    *this = other; \
                } \
            } \
        } \
        return *this; \
    }

#define OMG_DDS_EXPLICIT_REF_BASE_DECL(TYPE, FROM)         \
public: \
    TYPE(const FROM &h);    \
    \
    TYPE& \
    operator =( \
    const FROM& rhs);

#define OMG_DDS_EXPLICIT_REF_BASE(TYPE, FROM)         \
public: \
    /* We need to support both const and non-const conversion explicitly, because it could */ \
    /* be that the class has a constructor that takes a single non-const template argument. */ \
    /* That non-const templated constructor is a closer match than TYPE(const FROM& h); when */ \
    /* creating the TYPE class from a non-const FROM object. */ \
    TYPE(FROM & h) { this->explicit_conversion(const_cast<const FROM&>(h)); }    \
    TYPE(const FROM &h) { this->explicit_conversion(h); }    \
private: \
    void explicit_conversion(const FROM &h) \
    { \
        if (h.is_nil()){ \
            /* We got a null object and are not really able to do a typecheck here. */ \
            /* So, just set a null object. */ \
            *this = dds::core::null; \
        } else { \
            this->impl_ = h.delegate(); \
            if (h.delegate() != this->::dds::core::Reference< DELEGATE_T >::impl_){ \
                throw dds::core::IllegalOperationError(std::string( \
                                  "Attempted invalid cast: ") + typeid(h).name() + " to " + typeid(*this).name()); \
            } \
        } \
    } \
    \
public: \
    TYPE& \
    operator =( \
    const FROM& rhs) { \
        if (this != (TYPE*)&rhs){ \
            if (rhs.is_nil()){ \
                /* We got a null object and are not really able to do a typecheck here. */ \
                /* So, just set a null object. */ \
                *this = dds::core::null; \
            } else { \
                TYPE other(rhs); \
                /* Dont have to copy when the delegate is the same. */ \
                if (other.delegate() != this->::dds::core::Reference< DELEGATE_T >::impl_){ \
                    *this = other; \
                } \
            } \
        } \
        return *this; \
    }

// Declares a reference type equipped with a default ctor.
//
#define OMG_DDS_REF_TYPE_PROTECTED_DC(TYPE, BASE, DELEGATE)                 \
public:                                                                     \
    typedef DELEGATE DELEGATE_T;                                 \
    OMG_DDS_REF_TYPE_BASE(TYPE, BASE, DELEGATE_T)                           \
protected:                                                                  \
    TYPE() { }

#define OMG_DDS_REF_TYPE_PROTECTED_DC_T(TYPE, BASE, T_PARAM, DELEGATE)      \
public:                                                                     \
    typedef DELEGATE<T_PARAM>   DELEGATE_T;                                 \
    OMG_DDS_REF_TYPE_BASE(TYPE, BASE, DELEGATE_T)                           \
protected:                                                                  \
    TYPE() { }

#define OMG_DDS_REF_TYPE_NO_DC(TYPE, BASE, DELEGATE)                        \
public:                                                                     \
    typedef DELEGATE DELEGATE_T;                                 \
    OMG_DDS_REF_TYPE_BASE(TYPE, BASE, DELEGATE_T)

#define OMG_DDS_REF_TYPE_DELEGATE_C(TYPE, BASE, DELEGATE)                   \
    OMG_DDS_REF_TYPE_PROTECTED_DC(TYPE, BASE, DELEGATE)                     \
public:                                                                     \
    TYPE(DELEGATE_T * impl) : dds::core::Reference< DELEGATE_T >(impl) { }

#endif //OMG_DDS_CORE_REFMACROS_HPP_