diff options
Diffstat (limited to 'src/shared_string.cc')
| -rw-r--r-- | src/shared_string.cc | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/src/shared_string.cc b/src/shared_string.cc index d98affe9..01104e00 100644 --- a/src/shared_string.cc +++ b/src/shared_string.cc @@ -10,16 +10,16 @@ SharedString StringRegistry::intern(StringView str) if (it == m_strings.end()) { SharedString shared_str = str; - it = m_strings.emplace(StringView{shared_str}, shared_str.m_storage).first; + it = m_strings.emplace(shared_str, shared_str.m_storage).first; } - return {*it->second, it->second}; + return {it->second->strview(), it->second}; } void StringRegistry::purge_unused() { for (auto it = m_strings.begin(); it != m_strings.end(); ) { - if (it->second.unique()) + if (it->second->refcount == 1) it = m_strings.erase(it); else ++it; @@ -28,15 +28,14 @@ void StringRegistry::purge_unused() void StringRegistry::debug_stats() const { - write_debug("Shared Strings stats:"); size_t total_refcount = 0; size_t total_size = 0; size_t count = m_strings.size(); for (auto& st : m_strings) { - total_refcount += st.second.use_count() - 1; - total_size += (int)st.second->length(); + total_refcount += st.second->refcount - 1; + total_size += (int)st.second->content.size(); } write_debug(" data size: " + to_string(total_size) + ", mean: " + to_string((float)total_size/count)); write_debug(" refcounts: " + to_string(total_refcount) + ", mean: " + to_string((float)total_refcount/count)); |
