// Copyright 2016 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. /** * @file TopicAttributes.h */ #ifndef TOPICPARAMETERS_H_ #define TOPICPARAMETERS_H_ #include <string> #include <fastdds/rtps/common/Types.h> #include <fastrtps/qos/QosPolicies.h> namespace eprosima { namespace fastrtps{ /** * Class TopicAttributes, used by the user to define the attributes of the topic associated with a Publisher or Subscriber. * @ingroup FASTRTPS_ATTRIBUTES_MODULE */ class TopicAttributes { public: /** * Default constructor */ TopicAttributes() : topicKind(rtps::NO_KEY) , topicName("UNDEF") , topicDataType("UNDEF") , auto_fill_type_object(true) , auto_fill_type_information(true) { } //!Constructor, you need to provide the topic name and the topic data type. TopicAttributes( const char* name, const char* dataType, rtps::TopicKind_t tKind= rtps::NO_KEY) { topicKind = tKind; topicName = name; topicDataType = dataType; auto_fill_type_object = true; auto_fill_type_information = true; } virtual ~TopicAttributes() {} bool operator==(const TopicAttributes& b) const { return (this->topicKind == b.topicKind) && (this->topicName == b.topicName) && (this->topicDataType == b.topicDataType) && (this->historyQos == b.historyQos); } /** * Get the topic data type * @return Topic data type */ const string_255& getTopicDataType() const { return topicDataType; } /** * Get the topic kind * @return Topic kind */ rtps::TopicKind_t getTopicKind() const { return topicKind; } /** * Get the topic name * @return Topic name */ const string_255& getTopicName() const { return topicName; } //! TopicKind_t, default value NO_KEY. rtps::TopicKind_t topicKind; //! Topic Name. string_255 topicName; //!Topic Data Type. string_255 topicDataType; //!QOS Regarding the History to be saved. HistoryQosPolicy historyQos; //!QOS Regarding the resources to allocate. ResourceLimitsQosPolicy resourceLimitsQos; //!Type Identifier XTYPES 1.1 TypeIdV1 type_id; //!Type Object XTYPES 1.1 TypeObjectV1 type; //!XTYPES 1.2 xtypes::TypeInformation type_information; //!Tries to complete type identifier and type object (TypeObjectV1) bool auto_fill_type_object; //!Tries to complete type information (TypeObjectV2) bool auto_fill_type_information; /** * Method to check whether the defined QOS are correct. * @return True if they are valid. */ bool checkQos() const; }; #ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC /** * Check if two topic attributes are not equal * @param t1 First instance of TopicAttributes to compare * @param t2 Second instance of TopicAttributes to compare * @return True if the instances are not equal. False if the instances are equal. */ bool inline operator!=(const TopicAttributes& t1, const TopicAttributes& t2) { if(t1.topicKind != t2.topicKind || t1.topicName != t2.topicName || t1.topicDataType != t2.topicDataType || t1.historyQos.kind != t2.historyQos.kind || (t1.historyQos.kind == KEEP_LAST_HISTORY_QOS && t1.historyQos.depth != t2.historyQos.depth)) { return true; } return false; } #endif } /* namespace fastrtps */ } /* namespace eprosima */ #endif /* TOPICPARAMETERS_H_ */