From 1b3b0686ac30a5966a57e2331a72493182ff1e49 Mon Sep 17 00:00:00 2001 From: Iker Luengo Date: Thu, 13 Feb 2020 10:37:48 +0100 Subject: [PATCH] Refs #7552. Delete history_record when endpoint is unmatched This is a port of #1006 from 1.8.x Only a partial port is done, as the main issue was already corrected during a refactoring * Ensure persistence_guid_count_ is deleted when it reaches to zero to free memory * Change the condition to delete the records from count == 0 to count <= 0 for robustness --- src/cpp/rtps/reader/RTPSReader.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/cpp/rtps/reader/RTPSReader.cpp b/src/cpp/rtps/reader/RTPSReader.cpp index cf5acd3240b..5896da026a5 100644 --- a/src/cpp/rtps/reader/RTPSReader.cpp +++ b/src/cpp/rtps/reader/RTPSReader.cpp @@ -125,11 +125,12 @@ void RTPSReader::remove_persistence_guid( GUID_t persistence_guid_stored = (c_Guid_Unknown == persistence_guid) ? guid : persistence_guid; history_state_->persistence_guid_map.erase(guid); auto count = --history_state_->persistence_guid_count[persistence_guid_stored]; - if (count == 0) + if (count <= 0) { if (m_att.durabilityKind < TRANSIENT) { history_state_->history_record.erase(persistence_guid_stored); + history_state_->persistence_guid_count.erase(persistence_guid_stored); } } }