// 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. /** * @file LocatorSelectorEntry.hpp */ #ifndef _FASTDDS_RTPS_COMMON_LOCATORSELECTORENTRY_HPP_ #define _FASTDDS_RTPS_COMMON_LOCATORSELECTORENTRY_HPP_ #ifndef DOXYGEN_SHOULD_SKIP_THIS_PUBLIC #include #include #include namespace eprosima { namespace fastrtps { namespace rtps { /** * An entry for the @ref LocatorSelector. * * This class holds the locators of a remote endpoint along with data required for the locator selection algorithm. * Can be easyly integrated inside other classes, such as @ref ReaderProxyData and @ref WriterProxyData. */ struct LocatorSelectorEntry { /** * Holds the selection state of the locators held by a LocatorSelectorEntry */ struct EntryState { /** * Construct an EntryState object. * * @param max_unicast_locators Maximum number of unicast locators to held by parent LocatorSelectorEntry. * @param max_multicast_locators Maximum number of multicast locators to held by parent LocatorSelectorEntry. */ EntryState( size_t max_unicast_locators, size_t max_multicast_locators) : unicast(ResourceLimitedContainerConfig::fixed_size_configuration(max_unicast_locators)) , multicast(ResourceLimitedContainerConfig::fixed_size_configuration(max_multicast_locators)) { } //! Unicast locators selection state ResourceLimitedVector unicast; //! Multicast locators selection state ResourceLimitedVector multicast; }; /** * Construct a LocatorSelectorEntry. * * @param max_unicast_locators Maximum number of unicast locators to hold. * @param max_multicast_locators Maximum number of multicast locators to hold. */ LocatorSelectorEntry( size_t max_unicast_locators, size_t max_multicast_locators) : remote_guid(c_Guid_Unknown) , unicast(ResourceLimitedContainerConfig::fixed_size_configuration(max_unicast_locators)) , multicast(ResourceLimitedContainerConfig::fixed_size_configuration(max_multicast_locators)) , state(max_unicast_locators, max_multicast_locators) , enabled(false) , transport_should_process(false) { } /** * Set the enabled value. * * @param should_enable Whether this entry should be enabled. */ void enable(bool should_enable) { enabled = should_enable && remote_guid != c_Guid_Unknown; } /** * Reset the selections. */ void reset() { state.unicast.clear(); state.multicast.clear(); } //! GUID of the remote entity. GUID_t remote_guid; //! List of unicast locators to send data to the remote entity. ResourceLimitedVector unicast; //! List of multicast locators to send data to the remote entity. ResourceLimitedVector multicast; //! State of the entry EntryState state; //! Indicates whether this entry should be taken into consideration. bool enabled; //! A temporary value for each transport to help optimizing some use cases. bool transport_should_process; }; } /* namespace rtps */ } /* namespace fastrtps */ } /* namespace eprosima */ #endif /* DOXYGEN_SHOULD_SKIP_THIS_PUBLIC */ #endif /* _FASTDDS_RTPS_COMMON_LOCATORSELECTORENTRY_HPP_ */