susumu.yata
null+****@clear*****
Wed Aug 21 13:59:44 JST 2013
susumu.yata 2013-08-21 13:59:44 +0900 (Wed, 21 Aug 2013) New Revision: bd3f936e0ccbc43cd7415ba5fdfa89357d729026 https://github.com/groonga/grnxx/commit/bd3f936e0ccbc43cd7415ba5fdfa89357d729026 Message: Do nothing if the pool is empty. Modified files: lib/grnxx/map/hash_table.cpp Modified: lib/grnxx/map/hash_table.cpp (+15 -7) =================================================================== --- lib/grnxx/map/hash_table.cpp 2013-08-21 12:30:41 +0900 (9875c78) +++ lib/grnxx/map/hash_table.cpp 2013-08-21 13:59:44 +0900 (523fe9e) @@ -688,6 +688,10 @@ void HashTable<T>::rebuild_table() { template <typename T> void HashTable<T>::defrag() { refresh_if_possible(); + if (max_key_id() < MAP_MIN_KEY_ID) { + // Nothing to do. + return; + } pool_->defrag(); rebuild_table(); } @@ -706,6 +710,10 @@ void HashTable<T>::sweep(Duration lifetime) { template <typename T> void HashTable<T>::truncate() { refresh_if_possible(); + if (max_key_id() < MAP_MIN_KEY_ID) { + // Nothing to do. + return; + } std::unique_ptr<Pool> new_pool(Pool::create(storage_, storage_node_id_)); std::unique_ptr<Impl> new_impl; try { @@ -741,11 +749,11 @@ template <typename T> void HashTable<T>::create_map(Storage *storage, uint32_t storage_node_id, const MapOptions &) { storage_ = storage; - StorageNode storage_node = + StorageNode header_node = storage->create_node(storage_node_id, sizeof(Header)); - storage_node_id_ = storage_node.id(); + storage_node_id_ = header_node.id(); try { - header_ = static_cast<Header *>(storage_node.body()); + header_ = static_cast<Header *>(header_node.body()); *header_ = Header(); pool_.reset(Pool::create(storage, storage_node_id_)); impl_.reset(Impl::create(storage, storage_node_id_, pool_.get())); @@ -762,14 +770,14 @@ void HashTable<T>::create_map(Storage *storage, uint32_t storage_node_id, template <typename T> void HashTable<T>::open_map(Storage *storage, uint32_t storage_node_id) { storage_ = storage; - StorageNode storage_node = storage->open_node(storage_node_id); - if (storage_node.size() < sizeof(Header)) { - GRNXX_ERROR() << "invalid format: size = " << storage_node.size() + StorageNode header_node = storage->open_node(storage_node_id); + if (header_node.size() < sizeof(Header)) { + GRNXX_ERROR() << "invalid format: size = " << header_node.size() << ", header_size = " << sizeof(Header); throw LogicError(); } storage_node_id_ = storage_node_id; - header_ = static_cast<Header *>(storage_node.body()); + header_ = static_cast<Header *>(header_node.body()); if (!*header_) { GRNXX_ERROR() << "wrong format: expected = " << FORMAT_STRING << ", actual = " << header_->common_header.format(); -------------- next part -------------- HTML����������������������������... 下載