Chromium Code Reviews| Index: core/fxge/ge/cfx_fontcache.cpp |
| diff --git a/core/fxge/ge/cfx_fontcache.cpp b/core/fxge/ge/cfx_fontcache.cpp |
| index 3ecd83c33f8f8b66ffdb987eea6324f5f00e69d1..acae018c83cf1f251c3e672f8e7384102bedf077 100644 |
| --- a/core/fxge/ge/cfx_fontcache.cpp |
| +++ b/core/fxge/ge/cfx_fontcache.cpp |
| @@ -10,38 +10,43 @@ |
| #include "core/fxge/include/fx_font.h" |
| #include "core/fxge/include/fx_freetype.h" |
| +CFX_FontCache::CountedFaceCache::CountedFaceCache() {} |
| + |
| +CFX_FontCache::CountedFaceCache::~CountedFaceCache() {} |
| + |
| CFX_FontCache::CFX_FontCache() {} |
| CFX_FontCache::~CFX_FontCache() { |
| - FreeCache(TRUE); |
| + ASSERT(m_ExtFaceMap.empty()); |
| + ASSERT(m_FTFaceMap.empty()); |
| } |
| -CFX_FaceCache* CFX_FontCache::GetCachedFace(CFX_Font* pFont) { |
| +CFX_FaceCache* CFX_FontCache::GetCachedFace(const CFX_Font* pFont) { |
| FXFT_Face face = pFont->GetFace(); |
| const bool bExternal = !face; |
| CFX_FTCacheMap& map = bExternal ? m_ExtFaceMap : m_FTFaceMap; |
| auto it = map.find(face); |
| if (it != map.end()) { |
| - CFX_CountedFaceCache* counted_face_cache = it->second; |
| + CountedFaceCache* counted_face_cache = it->second.get(); |
| counted_face_cache->m_nCount++; |
| - return counted_face_cache->m_Obj; |
| + return counted_face_cache->m_Obj.get(); |
| } |
| - CFX_FaceCache* face_cache = new CFX_FaceCache(bExternal ? nullptr : face); |
| - CFX_CountedFaceCache* counted_face_cache = new CFX_CountedFaceCache; |
| + std::unique_ptr<CountedFaceCache> counted_face_cache(new CountedFaceCache); |
| counted_face_cache->m_nCount = 2; |
| - counted_face_cache->m_Obj = face_cache; |
| - map[face] = counted_face_cache; |
| + CFX_FaceCache* face_cache = new CFX_FaceCache(bExternal ? nullptr : face); |
| + counted_face_cache->m_Obj.reset(face_cache); |
| + map[face] = std::move(counted_face_cache); |
| return face_cache; |
| } |
| #ifdef _SKIA_SUPPORT_ |
| -CFX_TypeFace* CFX_FontCache::GetDeviceCache(CFX_Font* pFont) { |
| +CFX_TypeFace* CFX_FontCache::GetDeviceCache(const CFX_Font* pFont) { |
| return GetCachedFace(pFont)->GetDeviceCache(pFont); |
| } |
| #endif |
| -void CFX_FontCache::ReleaseCachedFace(CFX_Font* pFont) { |
| +void CFX_FontCache::ReleaseCachedFace(const CFX_Font* pFont) { |
| FXFT_Face face = pFont->GetFace(); |
| const bool bExternal = !face; |
| CFX_FTCacheMap& map = bExternal ? m_ExtFaceMap : m_FTFaceMap; |
| @@ -50,30 +55,10 @@ void CFX_FontCache::ReleaseCachedFace(CFX_Font* pFont) { |
| if (it == map.end()) |
| return; |
| - CFX_CountedFaceCache* counted_face_cache = it->second; |
| - if (counted_face_cache->m_nCount > 1) { |
| + CountedFaceCache* counted_face_cache = it->second.get(); |
| + if (counted_face_cache->m_nCount > 2) { |
| counted_face_cache->m_nCount--; |
| - } |
| -} |
| - |
| -void CFX_FontCache::FreeCache(FX_BOOL bRelease) { |
| - for (auto it = m_FTFaceMap.begin(); it != m_FTFaceMap.end();) { |
| - auto curr_it = it++; |
| - CFX_CountedFaceCache* cache = curr_it->second; |
| - if (bRelease || cache->m_nCount < 2) { |
| - delete cache->m_Obj; |
| - delete cache; |
| - m_FTFaceMap.erase(curr_it); |
| - } |
| - } |
| - |
| - for (auto it = m_ExtFaceMap.begin(); it != m_ExtFaceMap.end();) { |
| - auto curr_it = it++; |
| - CFX_CountedFaceCache* cache = curr_it->second; |
| - if (bRelease || cache->m_nCount < 2) { |
| - delete cache->m_Obj; |
| - delete cache; |
| - m_ExtFaceMap.erase(curr_it); |
| - } |
| + } else { |
|
npm
2016/09/14 23:07:59
Shouldn't you delete the CountedFaceCache as well?
snake
2016/09/15 10:39:25
It is unique_ptr.
|
| + map.erase(it); |
| } |
| } |