522 lines
24 KiB
C++
522 lines
24 KiB
C++
|
#ifndef OMG_TDDS_DOMAIN_DOMAIN_PARTICIPANT_HPP_
|
||
|
#define OMG_TDDS_DOMAIN_DOMAIN_PARTICIPANT_HPP_
|
||
|
|
||
|
/* Copyright 2010, Object Management Group, Inc.
|
||
|
* Copyright 2010, PrismTech, Corp.
|
||
|
* Copyright 2010, Real-Time Innovations, Inc.
|
||
|
* 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.
|
||
|
*/
|
||
|
|
||
|
#include <string>
|
||
|
|
||
|
#include <dds/ddsi/ddsi_config.h>
|
||
|
#include <dds/core/detail/conformance.hpp>
|
||
|
#include <dds/core/types.hpp>
|
||
|
#include <dds/core/Time.hpp>
|
||
|
#include <dds/core/Entity.hpp>
|
||
|
//#include <dds/core/cond/StatusCondition.hpp>
|
||
|
#include <dds/domain/qos/DomainParticipantQos.hpp>
|
||
|
|
||
|
#include <dds/topic/qos/TopicQos.hpp>
|
||
|
|
||
|
#include <dds/pub/qos/PublisherQos.hpp>
|
||
|
#include <dds/sub/qos/SubscriberQos.hpp>
|
||
|
|
||
|
|
||
|
namespace dds
|
||
|
{
|
||
|
namespace domain
|
||
|
{
|
||
|
|
||
|
template <typename DELEGATE>
|
||
|
class TDomainParticipant;
|
||
|
|
||
|
class DomainParticipantListener;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @brief
|
||
|
* A DomainParticipant represents the local membership of the application in a
|
||
|
* Domain.
|
||
|
*
|
||
|
* The DomainParticipant represents the participation of the application on
|
||
|
* a communication plane that isolates applications running on the same
|
||
|
* set of physical computers from each other. A domain establishes a virtual
|
||
|
* network linking all applications that share the same domainId and isolating
|
||
|
* them from applications running on different domains. In this way, several
|
||
|
* independent distributed applications can coexist in the same physical
|
||
|
* network without interfering, or even being aware of each other.
|
||
|
*
|
||
|
* @see for more information: @ref DCPS_Modules_DomainParticipant "Domain Participant"
|
||
|
*/
|
||
|
template <typename DELEGATE>
|
||
|
class dds::domain::TDomainParticipant : public ::dds::core::TEntity<DELEGATE>
|
||
|
{
|
||
|
public:
|
||
|
/**
|
||
|
* Local representation of the dds::domain::DomainParticipantListener
|
||
|
*/
|
||
|
typedef dds::domain::DomainParticipantListener Listener;
|
||
|
|
||
|
public:
|
||
|
OMG_DDS_REF_TYPE_PROTECTED_DC(TDomainParticipant, dds::core::TEntity, DELEGATE)
|
||
|
OMG_DDS_EXPLICIT_REF_BASE(TDomainParticipant, dds::core::Entity)
|
||
|
OMG_DDS_COMPLETE_RULE_OF_FIVE_VIRTUAL_DEFAULT(TDomainParticipant)
|
||
|
|
||
|
public:
|
||
|
/**
|
||
|
* Creates a new DomainParticipant object. The DomainParticipant signifies
|
||
|
* that the calling application intends to join the Domain identified by
|
||
|
* the domain_id argument.
|
||
|
*
|
||
|
* The DomainParticipant will be created with the QoS values specified on the last
|
||
|
* successful call to
|
||
|
* @link dds::domain::DomainParticipant::default_participant_qos(const ::dds::domain::qos::DomainParticipantQos& qos)
|
||
|
* DomainParticipant::default_publisher_qos(qos) @endlink or, if the call was never
|
||
|
* made, the @ref anchor_dds_domain_domainparticipant_qos_defaults "default" values.
|
||
|
*
|
||
|
* @param id the id of the domain joined by the new DomainParticipant
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
TDomainParticipant(uint32_t id);
|
||
|
|
||
|
/**
|
||
|
* Creates a new DomainParticipant object. The DomainParticipant signifies
|
||
|
* that the calling application intends to join the Domain identified by
|
||
|
* the domain_id argument.
|
||
|
*
|
||
|
* The DomainParticipant will be created with the DomainParticipantQos
|
||
|
* passed as an argument.
|
||
|
*
|
||
|
* It is possible to provide a specific configuration.
|
||
|
* Please be aware that the given domain_id always takes precedence over
|
||
|
* the configuration. Also, if a domain with the same ID was created
|
||
|
* previously (either through the config argument, environment var or
|
||
|
* default), that configuration is used.
|
||
|
*
|
||
|
* | id | config | in config | previous | result |
|
||
|
* +----+--------+-----------+----------+-------------------------------+
|
||
|
* | n | no | n.a. | no | n, environment/default config |
|
||
|
* | n | no | n.a. | yes | n, previous config |
|
||
|
* | n | yes | no | no | n, default config (with n id) |
|
||
|
* | n | yes | yes/any | no | n, given config |
|
||
|
* | n | yes | no | yes | n, previous config |
|
||
|
* | n | yes | yes/any | yes | n, previous config |
|
||
|
*
|
||
|
* @param id the id of the domain joined by the new DomainParticipant
|
||
|
* @param qos the QoS settings for the new DomainParticipant
|
||
|
* @param listener the listener
|
||
|
* @param event_mask the mask defining the events for which the listener
|
||
|
* will be notified.
|
||
|
* @param config when not empty, the value is used as either the name
|
||
|
* of the file containing the configuration or, when it
|
||
|
* starts with '<', taken to be the XML representation
|
||
|
* of the configuration. When not empty, the id argument of
|
||
|
* this constructor has to have a specific value and can not
|
||
|
* be org::eclipse::cyclonedds::domain::default_id().
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
TDomainParticipant(uint32_t id,
|
||
|
const dds::domain::qos::DomainParticipantQos& qos,
|
||
|
dds::domain::DomainParticipantListener* listener = NULL,
|
||
|
const dds::core::status::StatusMask& event_mask = dds::core::status::StatusMask::none(),
|
||
|
const std::string& config = std::string());
|
||
|
|
||
|
TDomainParticipant(uint32_t id,
|
||
|
const dds::domain::qos::DomainParticipantQos& qos,
|
||
|
dds::domain::DomainParticipantListener* listener,
|
||
|
const dds::core::status::StatusMask& event_mask,
|
||
|
const ddsi_config& config);
|
||
|
|
||
|
public:
|
||
|
|
||
|
/**
|
||
|
* Register a listener with the DomainParticipant.
|
||
|
*
|
||
|
* The notifications received by the listener depend on the
|
||
|
* status mask with which it was registered.
|
||
|
*
|
||
|
* Listener un-registration is performed by setting the listener to NULL.
|
||
|
*
|
||
|
* See also @ref DCPS_Modules_Infrastructure_Listener "listener information".
|
||
|
*
|
||
|
* @param listener the listener
|
||
|
* @param event_mask the mask defining the events for which the listener
|
||
|
* will be notified.
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::UnsupportedError
|
||
|
* A status was selected that cannot be supported because
|
||
|
* the infrastructure does not maintain the required connectivity information.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
void listener(Listener* listener,
|
||
|
const ::dds::core::status::StatusMask& event_mask);
|
||
|
|
||
|
/**
|
||
|
* Get the listener of this DomainParticipant.
|
||
|
*
|
||
|
* See also @ref DCPS_Modules_Infrastructure_Listener "listener information".
|
||
|
*
|
||
|
* @return the listener
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
*/
|
||
|
Listener* listener() const;
|
||
|
|
||
|
/**
|
||
|
* Gets the DomainParticipantQos setting for this instance.
|
||
|
*
|
||
|
* @return the qos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
const dds::domain::qos::DomainParticipantQos& qos() const;
|
||
|
|
||
|
/**
|
||
|
* Sets the DomainParticipantQos setting for this instance.
|
||
|
*
|
||
|
* @param qos the qos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
void qos(const dds::domain::qos::DomainParticipantQos& qos);
|
||
|
|
||
|
/**
|
||
|
* This operation retrieves the domain_id used to create the
|
||
|
* DomainParticipant. The domain_id identifies the DDS domain
|
||
|
* to which the DomainParticipant belongs.
|
||
|
*
|
||
|
* Each DDS domain represents a separate data communication
|
||
|
* plane isolated from other domains.
|
||
|
*
|
||
|
* @return the domain id
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
*/
|
||
|
uint32_t domain_id() const;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* This operation will manually assert the liveliness for the DomainParticipant.
|
||
|
*
|
||
|
* This way, the Data Distribution Service is informed that the DomainParticipant
|
||
|
* is still alive. This operation only needs to be used when the DomainParticipant
|
||
|
* contains DataWriters with the dds:core::policy::LivelinessQosPolicy::ManualByParticipant(),
|
||
|
* and it will only affect the liveliness of those DataWriters.
|
||
|
*
|
||
|
* Writing data via the write operation of a DataWriter will assert the liveliness on
|
||
|
* the DataWriter itself and its DomainParticipant. Therefore,
|
||
|
* assert_liveliness is only needed when not writing regularly.
|
||
|
* The liveliness should be asserted by the application, depending on the
|
||
|
* LivelinessQosPolicy.
|
||
|
*
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
*/
|
||
|
void assert_liveliness();
|
||
|
|
||
|
|
||
|
/**
|
||
|
* This operation checks whether or not the given handle represents
|
||
|
* an Entity that was created by using this DomainParticipant.
|
||
|
*
|
||
|
* The containment applies recursively. That is, it applies both to
|
||
|
* entities (TopicDescription, Publisher, or Subscriber) created directly
|
||
|
* using the DomainParticipant as well as entities created using a
|
||
|
* contained Publisher, or Subscriber as the factory, and so forth.
|
||
|
*
|
||
|
* @param handle the instance handle for which the containement
|
||
|
* relationship has to be checked
|
||
|
* @return true if the handle belongs to an Entity belonging
|
||
|
* to this DomainParticipant
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
*/
|
||
|
bool contains_entity(const ::dds::core::InstanceHandle& handle);
|
||
|
|
||
|
/**
|
||
|
* This operation returns the current value of the time that the service
|
||
|
* uses to time-stamp data writes and to set the reception timestamp
|
||
|
* for the data updates it receives.
|
||
|
*
|
||
|
* @return the current time
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
*/
|
||
|
dds::core::Time current_time() const;
|
||
|
|
||
|
/** @copydoc dds::domain::DomainParticipant::qos(const dds::domain::qos::DomainParticipantQos& qos) */
|
||
|
TDomainParticipant& operator << (const dds::domain::qos::DomainParticipantQos& qos);
|
||
|
|
||
|
/** @copydoc dds::domain::DomainParticipant::qos() */
|
||
|
const TDomainParticipant& operator >> (dds::domain::qos::DomainParticipantQos& qos) const;
|
||
|
|
||
|
public:
|
||
|
/**
|
||
|
* Gets the default DomainParticipantQos.
|
||
|
*
|
||
|
* This operation gets an object with the default global DomainParticipant
|
||
|
* QosPolicy settings which is used for newly
|
||
|
* created DomainParticipant objects, in case no QoS was provided during the creation.
|
||
|
*
|
||
|
* The values retrieved by this operation match the set of values specified on the last
|
||
|
* successful call to
|
||
|
* dds::domain::DomainParticipant::default_participant_qos(const ::dds::domain::qos::DomainParticipantQos& qos),
|
||
|
* or, if the call was never made, the @ref anchor_dds_domain_domainparticipant_qos_defaults "default" values.
|
||
|
*
|
||
|
* @return the default DomainParticipantQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
static dds::domain::qos::DomainParticipantQos default_participant_qos();
|
||
|
|
||
|
/**
|
||
|
* Sets the default DomainParticipantQos.
|
||
|
*
|
||
|
* This QoS will be used by all following DomainParticipant creations when no
|
||
|
* QoS was given during those creations or the QoS is given that was returned
|
||
|
* by dds::domain::DomainParticipant::default_participant_qos().
|
||
|
*
|
||
|
* @param qos the default DomainParticipantQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
static void default_participant_qos(const ::dds::domain::qos::DomainParticipantQos& qos);
|
||
|
|
||
|
/**
|
||
|
* Gets the default PublisherQos of the DomainParticipant.
|
||
|
*
|
||
|
* This operation gets an object with the default Publisher QosPolicy settings of
|
||
|
* the DomainParticipant (that is the PublisherQos) which is used for newly
|
||
|
* created Publisher objects, in case no QoS was provided during the creation.
|
||
|
*
|
||
|
* The values retrieved by this operation match the set of values specified on the last
|
||
|
* successful call to
|
||
|
* dds::domain::DomainParticipant::default_publisher_qos(const ::dds::pub::qos::PublisherQos& qos),
|
||
|
* or, if the call was never made, the @ref anchor_dds_pub_publisher_qos_defaults "default" values.
|
||
|
*
|
||
|
* @return the default PublisherQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
dds::pub::qos::PublisherQos default_publisher_qos() const;
|
||
|
|
||
|
/**
|
||
|
* Sets the default PublisherQos of the DomainParticipant.
|
||
|
*
|
||
|
* This operation sets the default PublisherQos of the DomainParticipant which
|
||
|
* is used for newly created Publisher objects, when no QoS is provided.
|
||
|
*
|
||
|
* The PublisherQos is always self consistent, because its policies do not depend on each
|
||
|
* other. This means that this operation never throws dds::core::InconsistentPolicyError.
|
||
|
*
|
||
|
* The values set by this operation are returned by dds::domain::DomainParticipant::default_publisher_qos().
|
||
|
*
|
||
|
* @param qos the default PublisherQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::UnsupportedError
|
||
|
* One or more of the selected QosPolicy values are
|
||
|
* currently not supported by OpenSplice.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
TDomainParticipant& default_publisher_qos(const ::dds::pub::qos::PublisherQos& qos);
|
||
|
|
||
|
/**
|
||
|
* Gets the default SubscriberQos of the DomainParticipant.
|
||
|
*
|
||
|
* This operation gets an object with the default Subscriber QosPolicy settings of
|
||
|
* the DomainParticipant (that is the SubscriberQos) which is used for newly
|
||
|
* created Subscriber objects, in case no QoS was provided during the creation.
|
||
|
*
|
||
|
* The values retrieved by this operation match the set of values specified on the last
|
||
|
* successful call to
|
||
|
* dds::domain::DomainParticipant::default_subscriber_qos(const :dds::sub::qos::SubscriberQos& qos),
|
||
|
* or, if the call was never made, the @ref anchor_dds_sub_subscriber_qos_defaults "default" values.
|
||
|
*
|
||
|
* @return the default SubscriberQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
dds::sub::qos::SubscriberQos default_subscriber_qos() const;
|
||
|
|
||
|
/**
|
||
|
* Sets the default SubscriberQos of the DomainParticipant.
|
||
|
*
|
||
|
* This operation sets the default SubscriberQos of the DomainParticipant which
|
||
|
* is used for newly created Subscriber objects, when no QoS is provided.
|
||
|
*
|
||
|
* The SubscriberQos is always self consistent, because its policies do not depend on each
|
||
|
* other. This means that this operation never throws dds::core::InconsistentPolicyError.
|
||
|
*
|
||
|
* The values set by this operation are returned by dds::domain::DomainParticipant::default_subscriber_qos().
|
||
|
*
|
||
|
* @param qos the default SubscriberQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::UnsupportedError
|
||
|
* One or more of the selected QosPolicy values are
|
||
|
* currently not supported by OpenSplice.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
TDomainParticipant& default_subscriber_qos(const ::dds::sub::qos::SubscriberQos& qos);
|
||
|
|
||
|
/**
|
||
|
* Gets the default TopicQos of the DomainParticipant.
|
||
|
*
|
||
|
* This operation gets an object with the default Topic QosPolicy settings of
|
||
|
* the DomainParticipant (that is the TopicQos) which is used for newly
|
||
|
* created Topic objects, in case no QoS was provided during the creation.
|
||
|
*
|
||
|
* The values retrieved by this operation match the set of values specified on the last
|
||
|
* successful call to
|
||
|
* dds::domain::DomainParticipant::default_topic_qos(const dds::topic::qos::TopicQos& qos),
|
||
|
* or, if the call was never made, the @ref anchor_dds_topic_qos_defaults "default" values.
|
||
|
*
|
||
|
* @return the default TopicQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
dds::topic::qos::TopicQos default_topic_qos() const;
|
||
|
|
||
|
/**
|
||
|
* Sets the default TopicQos of the DomainParticipant.
|
||
|
*
|
||
|
* This operation sets the default SubscriberQos of the DomainParticipant which
|
||
|
* is used for newly created Subscriber objects, when no QoS is provided.
|
||
|
*
|
||
|
* This operation checks if the TopicQos is self consistent. If it is not, the
|
||
|
* operation has no effect and throws dds::core::InconsistentPolicyError.
|
||
|
*
|
||
|
* The values set by this operation are returned by dds::domain::DomainParticipant::default_topic_qos().
|
||
|
*
|
||
|
* @param qos the default TopicQos
|
||
|
* @throws dds::core::Error
|
||
|
* An internal error has occurred.
|
||
|
* @throws dds::core::NullReferenceError
|
||
|
* The entity was not properly created and references to dds::core::null.
|
||
|
* @throws dds::core::AlreadyClosedError
|
||
|
* The entity has already been closed.
|
||
|
* @throws dds::core::UnsupportedError
|
||
|
* One or more of the selected QosPolicy values are
|
||
|
* currently not supported by OpenSplice.
|
||
|
* @throws dds::core::InconsistentPolicyError
|
||
|
* The parameter qos contains conflicting QosPolicy settings,
|
||
|
* e.g. a history depth that is higher than the specified resource limits.
|
||
|
* @throws dds::core::OutOfResourcesError
|
||
|
* The Data Distribution Service ran out of resources to
|
||
|
* complete this operation.
|
||
|
*/
|
||
|
TDomainParticipant& default_topic_qos(const dds::topic::qos::TopicQos& qos);
|
||
|
|
||
|
//=============================================================================
|
||
|
};
|
||
|
|
||
|
|
||
|
#endif /* OMG_TDDS_DOMAIN_DOMAIN_PARTICIPANT_HPP_ */
|