Skip to content

iceoryx_utils/internal/cxx/newtype.inl🔗

Namespaces🔗

Name
iox
building block to easily create free function for logging in a library context
iox::cxx

Defines🔗

Name
IOX_UTILS_CXX_NEWTYPE_INL

Macro Documentation🔗

define IOX_UTILS_CXX_NEWTYPE_INL🔗

#define IOX_UTILS_CXX_NEWTYPE_INL

Source code🔗

// Copyright (c) 2020 by Robert Bosch GmbH. All rights reserved.
//
// 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.
//
// SPDX-License-Identifier: Apache-2.0
#ifndef IOX_UTILS_CXX_NEWTYPE_INL
#define IOX_UTILS_CXX_NEWTYPE_INL

namespace iox
{
namespace cxx
{
template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>::NewType() noexcept
{
    static_assert(algorithm::doesContainType<newtype::DefaultConstructable<T>, Policies<T>...>(),
                  "This type is not default constructable, please add the newtype::DefaultConstructable policy.");
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>::NewType(newtype::internal::ProtectedConstructor_t, const T& rhs) noexcept
    : m_value(rhs)
{
    static_assert(algorithm::doesContainType<newtype::ProtectedConstructByValueCopy<T>, Policies<T>...>(),
                  "This type is not protected constructable with value copy, please add the "
                  "newtype::ProtectedConstructByValueCopy policy.");
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>::NewType(const T& rhs) noexcept
    : m_value(rhs)
{
    static_assert(
        algorithm::doesContainType<newtype::ConstructByValueCopy<T>, Policies<T>...>(),
        "This type is not constructable with value copy, please add the newtype::ConstructByValueCopy policy.");
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>::NewType(const NewType& rhs) noexcept
    : m_value(rhs.m_value)
{
    static_assert(algorithm::doesContainType<newtype::CopyConstructable<T>, Policies<T>...>(),
                  "This type is not copy constructable, please add the newtype::CopyConstructable policy.");
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>::NewType(NewType&& rhs) noexcept
    : m_value(std::move(rhs.m_value))
{
    static_assert(algorithm::doesContainType<newtype::MoveConstructable<T>, Policies<T>...>(),
                  "This type is not move constructable, please add the newtype::MoveConstructable policy.");
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>& NewType<T, Policies...>::operator=(const NewType& rhs) noexcept
{
    m_value = rhs.m_value;
    static_assert(algorithm::doesContainType<newtype::CopyAssignable<T>, Policies<T>...>(),
                  "This type is not copy assignable, please add the newtype::CopyAssignable policy.");
    return *this;
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>& NewType<T, Policies...>::operator=(NewType&& rhs) noexcept
{
    if (this != &rhs)
    {
        m_value = std::move(rhs.m_value);
    }
    static_assert(algorithm::doesContainType<newtype::MoveAssignable<T>, Policies<T>...>(),
                  "This type is not move assignable, please add the newtype::MoveAssignable policy.");
    return *this;
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>& NewType<T, Policies...>::operator=(const T& rhs) noexcept
{
    m_value = rhs;
    static_assert(algorithm::doesContainType<newtype::AssignByValueCopy<T>, Policies<T>...>(),
                  "This type is not assignable by value copy, please add the newtype::AssignByValueCopy policy.");
    return *this;
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>& NewType<T, Policies...>::operator=(T&& rhs) noexcept
{
    m_value = std::move(rhs);
    static_assert(algorithm::doesContainType<newtype::AssignByValueMove<T>, Policies<T>...>(),
                  "This type is not assignable by value move, please add the newtype::AssignByValueMove policy.");
    return *this;
}

template <typename T, template <typename> class... Policies>
inline NewType<T, Policies...>::operator T() const noexcept
{
    static_assert(algorithm::doesContainType<newtype::Convertable<T>, Policies<T>...>(),
                  "This type is not convertable, please add the newtype::Convertable policy.");
    return m_value;
}

} // namespace cxx
} // namespace iox

#endif

Updated on 31 May 2022 at 15:29:15 CEST