From d72d79bb05a2392ce20ea9ae12dadfc7cc319b3e Mon Sep 17 00:00:00 2001 From: Thomas Goyne Date: Fri, 4 Sep 2015 11:34:02 -0700 Subject: [PATCH] Make Realm::compact() more robust Throw if it's called on a read-only Realm and ensure the Realm is left in a valid state regardless of the starting state. --- shared_realm.cpp | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/shared_realm.cpp b/shared_realm.cpp index 93e1aa13..ab72b638 100644 --- a/shared_realm.cpp +++ b/shared_realm.cpp @@ -291,20 +291,21 @@ bool Realm::compact() { verify_thread(); - bool success = false; + if (m_config.read_only) { + throw InvalidTransactionException("Can't compact a read-only Realm"); + } if (m_in_transaction) { throw InvalidTransactionException("Can't compact a Realm within a write transaction"); } + Group* group = read_group(); for (auto &object_schema : *m_config.schema) { - ObjectStore::table_for_object_type(read_group(), object_schema.name)->optimize(); + ObjectStore::table_for_object_type(group, object_schema.name)->optimize(); } - m_shared_group->end_read(); - success = m_shared_group->compact(); - m_shared_group->begin_read(); + m_group = nullptr; - return success; + return m_shared_group->compact(); } void Realm::notify()