// 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 ResourceLimitedContainerConfig.hpp * */ #ifndef FASTRTPS_UTILS_COLLECTIONS_RESOURCELIMITEDCONTAINERCONFIG_HPP_ #define FASTRTPS_UTILS_COLLECTIONS_RESOURCELIMITEDCONTAINERCONFIG_HPP_ #include #include namespace eprosima { namespace fastrtps { /** * Specifies the configuration of a resource limited collection. * @ingroup UTILITIES_MODULE */ struct ResourceLimitedContainerConfig { ResourceLimitedContainerConfig( size_t ini = 0, size_t max = std::numeric_limits::max(), size_t inc = 1u) : initial(ini) , maximum(max) , increment(inc) { } //! Number of elements to be preallocated in the collection. size_t initial = 0; //! Maximum number of elements allowed in the collection. size_t maximum = std::numeric_limits::max(); //! Number of items to add when capacity limit is reached. size_t increment = 1u; /** * Return a resource limits configuration for a fixed size collection. * @param size Number of elements to allocate. * @return Resource limits configuration. */ inline static ResourceLimitedContainerConfig fixed_size_configuration(size_t size) { return ResourceLimitedContainerConfig(size, size, 0u); } /** * Return a resource limits configuration for a linearly growing, dynamically allocated collection. * @param increment Number of new elements to allocate when increasing the capacity of the collection. * @return Resource limits configuration. */ inline static ResourceLimitedContainerConfig dynamic_allocation_configuration(size_t increment = 1u) { return ResourceLimitedContainerConfig(0u, std::numeric_limits::max(), increment ? increment : 1u); } }; inline bool operator == ( const ResourceLimitedContainerConfig& lhs, const ResourceLimitedContainerConfig& rhs) { return lhs.maximum == rhs.maximum && lhs.initial == rhs.initial && lhs.increment == rhs.increment; } } // namespace fastrtps } // namespace eprosima #endif /* FASTRTPS_UTILS_COLLECTIONS_RESOURCELIMITEDCONTAINERCONFIG_HPP_ */