Program Listing for File Annotation.hpp
↰ Return to documentation for file (/tmp/ws/src/fastrtps/include/dds/core/xtypes/Annotation.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_ANNOTATION_HPP_
#define OMG_DDS_CORE_XTYPES_ANNOTATION_HPP_
#ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC
#include <dds/core/xtypes/detail/Annotation.hpp>
#include <dds/core/xtypes/TypeKind.hpp>
#include <dds/core/SafeEnumeration.hpp>
#include <dds/core/Reference.hpp>
namespace dds {
namespace core {
namespace xtypes {
template<typename DELEGATE>
class TIdAnnotation;
template<typename DELEGATE>
class TAnnotation : public Reference<DELEGATE>
{
OMG_DDS_REF_TYPE_BASE(
TAnnotation,
dds::core::Reference,
DELEGATE)
public:
virtual ~TAnnotation();
TypeKind kind() const;
template<typename Q,
template <typename> class K>
operator K<Q>&()
{
return reinterpret_cast<K<Q>&>(*this);
}
const AnnotationKind& akind() const
{
return impl()->akind();
}
protected:
TAnnotation(
const TypeKind& kind);
};
template<typename DELEGATE>
class TIdAnnotation : public TAnnotation<DELEGATE>
{
using TAnnotation<DELEGATE>::impl;
public:
TIdAnnotation(
uint32_t id)
: TAnnotation<DELEGATE>(TypeKind::ANNOTATION_TYPE)
{
impl()->id(id);
}
uint32_t id() const
{
return impl()->id();
}
};
template<typename DELEGATE>
class TKeyAnnotation : public TAnnotation<DELEGATE>
{
using TAnnotation<DELEGATE>::impl;
public:
TKeyAnnotation()
{
}
};
template<typename DELEGATE>
class TSharedAnnotation : public TAnnotation<DELEGATE>
{
public:
TSharedAnnotation()
{
}
};
template<typename DELEGATE>
class TNestedAnnotation : public TAnnotation<DELEGATE>
{
public:
TNestedAnnotation()
{
}
};
template<typename DELEGATE>
class TExtensibilityAnnotation : public TAnnotation<DELEGATE>
{
using TAnnotation<DELEGATE>::impl;
public:
TExtensibilityAnnotation(
ExtensibilityKind xkind)
{
impl()->xKind();
}
ExtensibilityKind extensibility_kind() const
{
return impl()->xKind();
}
};
template<typename DELEGATE>
class TMustUnderstandAnnotation : public TAnnotation<DELEGATE>
{
public:
TMustUnderstandAnnotation()
{
}
};
template<typename DELEGATE>
class TVerbatimAnnotation : public TAnnotation<DELEGATE>
{
using TAnnotation<DELEGATE>::impl;
public:
TVerbatimAnnotation(
const std::string& text)
{
impl()->vbt(text);
}
const std::string& verbatim_text() const
{
return impl()->vbt();
}
};
template<typename DELEGATE>
class TBitsetAnnotation : public TAnnotation<DELEGATE>
{
public:
TBitsetAnnotation()
{
}
};
template<typename DELEGATE>
class TBitBoundAnnotation : public TAnnotation<DELEGATE>
{
using TAnnotation<DELEGATE>::impl;
public:
TBitBoundAnnotation(
uint32_t bound)
{
impl()->bsb(bound);
}
virtual uint32_t bound() const
{
return impl()->bsb();
}
void bound(
uint32_t bound)
{
impl()->bsb(bound);
}
};
typedef TAnnotation<detail::Annotation> Annotation;
typedef TIdAnnotation<detail::IdAnnotation> IdAnnotation;
typedef TKeyAnnotation<detail::KeyAnnotation> KeyAnnotation;
typedef TSharedAnnotation<detail::SharedAnnotation> SharedAnnotation;
typedef TNestedAnnotation<detail::NestedAnnotation> NestedAnnotation;
typedef TExtensibilityAnnotation<detail::ExtensibilityAnnotation> ExtensibilityAnnotation;
typedef TMustUnderstandAnnotation<detail::MustUnderstandAnnotation> MustUnderstandAnnotation;
typedef TVerbatimAnnotation<detail::VerbatimAnnotation> VerbatimAnnotation;
typedef TBitsetAnnotation<detail::BitsetAnnotation> BitsetAnnotation;
typedef TBitBoundAnnotation<detail::BitBoundAnnotation> BitBoundAnnotation;
//FRANAVA We must think about the fact that previous API has a way of creating a
//dynamically defined Annotation.
/*
namespace converter
{
IdAnnotation convert(const Annotation& a)
{
uint32_t idav = reinterpret_cast<const IdAnnotation&>(a).id();
return IdAnnotation(idav);
}
}
*/
namespace annotation {
// These functions can be used to get cached instances,
// to avoid the proliferation of small annotation objects.
IdAnnotation id(
uint32_t);
KeyAnnotation key();
SharedAnnotation shared();
NestedAnnotation nested();
ExtensibilityAnnotation extensibility(
ExtensibilityKind kind);
ExtensibilityAnnotation get_final();
ExtensibilityAnnotation extensible();
ExtensibilityAnnotation get_mutable();
MustUnderstandAnnotation must_understand();
VerbatimAnnotation verbatim(
const std::string& text);
BitsetAnnotation bitset();
BitsetAnnotation bit_bound(
uint32_t bound);
} //namespace annotation
} //namespace xtypes
} //namespace core
} //namespace dds
#endif
#endif //OMG_DDS_CORE_XTYPES_TANNOTATION_HPP_