Program Listing for File DynamicType.hpp
↰ Return to documentation for file (/tmp/ws/src/fastrtps/include/dds/core/xtypes/DynamicType.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_XTYPES_DYNAMIC_TYPE_HPP_
#define OMG_DDS_CORE_XTYPES_DYNAMIC_TYPE_HPP_
#include <dds/core/xtypes/detail/DynamicType.hpp>
#include <dds/core/Reference.hpp>
#include <dds/core/xtypes/TypeKind.hpp>
namespace dds {
namespace core {
namespace xtypes {
template<typename DELEGATE>
class TDynamicType : public Reference<DELEGATE>
{
OMG_DDS_REF_TYPE_PROTECTED_DC(
TDynamicType,
Reference,
DELEGATE)
public:
const std::string& name() const
{
return impl()->name();
}
TypeKind kind() const
{
return impl()->kind();
}
const std::vector<Annotation>& annotations() const
{
return impl()->annotations();
}
bool operator ==(
const TDynamicType& that) const
{
return *(impl()) == *(that.impl());
}
bool operator !=(
const TDynamicType& that) const
{
return !(*this == that);
}
bool is_primitive_type()
{
return (impl()->kind().underlying() & 0x4000 ) != 0;
}
bool is_collection_type()
{
return (impl()->kind().underlying() & 0x0200 ) != 0;
}
bool is_aggregation_type()
{
return (impl()->kind().underlying() & 0x0100 ) != 0;
}
bool is_constructed_type()
{
return (impl()->kind().underlying() & 0x8000 ) != 0;
}
protected:
TDynamicType(
const std::string& name,
TypeKind kind)
{
impl()->name(name);
impl()->kind(kind);
}
TDynamicType(
const std::string& name,
TypeKind kind,
const Annotation& annotation)
{
impl()->name(name);
impl()->kind(kind);
impl()->annotation(annotation);
}
TDynamicType(
const std::string& name,
TypeKind kind,
const std::vector<Annotation>& annotations)
{
impl()->name(name);
impl()->kind(kind);
impl()->annotation(annotations);
}
template<typename AnnotationIter>
TDynamicType(
const std::string& name,
TypeKind kind,
const AnnotationIter& begin,
const AnnotationIter& end)
{
impl()->name(name);
impl()->kind(kind);
impl()->annotation(begin, end);
}
public:
TDynamicType(
const TDynamicType& other) = default;
};
template<typename T>
bool is_primitive_type(
const TDynamicType<T>& t)
{
return t.is_primitive_type();
}
template<typename T>
bool is_constructed_type(
const TDynamicType<T>& t)
{
return t.is_constructed_type();
}
template<typename T>
bool is_collection_type(
const TDynamicType<T>& t)
{
return t.is_collection_type();
}
template<typename T>
bool is_aggregation_type(
const TDynamicType<T>& t)
{
return t.is_aggregation_type();
}
typedef TDynamicType<detail::DynamicType> DynamicType;
} //namespace xtypes
} //namespace core
} //namespace dds
#endif //OMG_DDS_CORE_XTYPES_DYNAMIC_TYPE_HPP_