Adopt owning_lock in history_collection_t

This commit is contained in:
ridiculousfish 2017-01-29 13:21:50 -08:00
parent 017836cffa
commit 10a2275c34

View file

@ -177,20 +177,13 @@ class history_lru_cache_t : public lru_cache_t<history_lru_cache_t, history_lru_
} }
}; };
// The set of histories
// Note that histories are currently immortal
class history_collection_t { class history_collection_t {
pthread_mutex_t m_lock; owning_lock<std::map<wcstring, std::unique_ptr<history_t>>> histories;
std::map<wcstring, history_t *> m_histories;
public: public:
history_collection_t() { VOMIT_ON_FAILURE_NO_ERRNO(pthread_mutex_init(&m_lock, NULL)); } history_t &get_creating(const wcstring &name);
~history_collection_t() {
for (std::map<wcstring, history_t *>::const_iterator i = m_histories.begin();
i != m_histories.end(); ++i) {
delete i->second;
}
pthread_mutex_destroy(&m_lock);
}
history_t &alloc(const wcstring &name);
void save(); void save();
}; };
@ -698,16 +691,21 @@ static size_t offset_of_next_item(const char *begin, size_t mmap_length,
return result; return result;
} }
history_t &history_collection_t::alloc(const wcstring &name) { history_t &history_collection_t::get_creating(const wcstring &name) {
// Return a history for the given name, creating it if necessary
// Note that histories are currently never deleted, so we can return a reference to them without // Note that histories are currently never deleted, so we can return a reference to them without
// using something like shared_ptr. // using something like shared_ptr
scoped_lock locker(m_lock); auto hs = histories.acquire();
history_t *&current = m_histories[name]; std::unique_ptr<history_t> &hist = hs.value[name];
if (current == NULL) current = new history_t(name); if (! hist) {
return *current; hist = make_unique<history_t>(name);
}
return *hist;
} }
history_t &history_t::history_with_name(const wcstring &name) { return histories.alloc(name); } history_t &history_t::history_with_name(const wcstring &name) {
return histories.get_creating(name);
}
history_t::history_t(const wcstring &pname) history_t::history_t(const wcstring &pname)
: name(pname), : name(pname),
@ -1647,11 +1645,10 @@ void history_t::incorporate_external_changes() {
void history_init() {} void history_init() {}
void history_collection_t::save() { void history_collection_t::save() {
// Save all histories. // Save all histories
for (std::map<wcstring, history_t *>::iterator iter = m_histories.begin(); auto h = histories.acquire();
iter != m_histories.end(); ++iter) { for (auto &p : h.value) {
history_t *hist = iter->second; p.second->save();
hist->save();
} }
} }