| // Copyright 2014 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include "net/disk_cache/blockfile/webfonts_histogram.h" |
| |
| #include "base/strings/string_piece.h" |
| #include "base/strings/stringprintf.h" |
| #include "net/disk_cache/blockfile/entry_impl.h" |
| #include "net/disk_cache/blockfile/histogram_macros.h" |
| |
| namespace { |
| |
| enum WebFontDiskCacheEventType { |
| CACHE_EVENT_MISS, |
| CACHE_EVENT_HIT, |
| CACHE_EVENT_EVICTED_ENTRY, |
| CACHE_EVENT_MAX |
| }; |
| |
| // Tests if the substring of str that begins at pos starts with substr. If so, |
| // returns true and advances pos by the length of substr. |
| bool Consume(const std::string& str, const base::StringPiece& substr, |
| std::string::size_type* pos) { |
| if (!str.compare(*pos, substr.length(), substr.data())) { |
| *pos += substr.length(); |
| return true; |
| } |
| return false; |
| } |
| |
| const char kRoboto[] = "roboto"; |
| const char kOpenSans[] = "opensans"; |
| const char kOthers[] = "others"; |
| |
| // Check if the given string is a URL for a font resource of Google Fonts. |
| // If so, returns a label for UMA histogram ("roboto", "opensans" or "others"). |
| const char* HistogramLabel(const std::string& str) { |
| std::string::size_type pos = 0; |
| if (Consume(str, "http://", &pos) || Consume(str, "https://", &pos)) { |
| if (Consume(str, "themes.googleusercontent.com/static/fonts/", &pos) || |
| Consume(str, "ssl.gstatic.com/fonts/", &pos) || |
| Consume(str, "fonts.gstatic.com/s/", &pos)) { |
| if (Consume(str, kRoboto, &pos)) |
| return kRoboto; |
| if (Consume(str, kOpenSans, &pos)) |
| return kOpenSans; |
| return kOthers; |
| } |
| } |
| return NULL; |
| } |
| |
| std::string HistogramName(const char* prefix, const char* label) { |
| return base::StringPrintf("WebFont.%s_%s", prefix, label); |
| } |
| |
| void RecordCacheEvent(WebFontDiskCacheEventType type, const char* label) { |
| CACHE_HISTOGRAM_ENUMERATION(HistogramName("DiskCacheHit", label), |
| type, CACHE_EVENT_MAX); |
| } |
| |
| } // namespace |
| |
| namespace disk_cache { |
| namespace web_fonts_histogram { |
| |
| void RecordCacheMiss(const std::string& key) { |
| const char* label = HistogramLabel(key); |
| if (label) |
| RecordCacheEvent(CACHE_EVENT_MISS, label); |
| } |
| |
| void RecordEvictedEntry(const std::string& key) { |
| const char* label = HistogramLabel(key); |
| if (label) |
| RecordCacheEvent(CACHE_EVENT_EVICTED_ENTRY, label); |
| } |
| |
| void RecordCacheHit(EntryImpl* entry) { |
| const char* label = HistogramLabel(entry->GetKey()); |
| if (!label) |
| return; |
| EntryStore* info = entry->entry()->Data(); |
| CACHE_HISTOGRAM_COUNTS_10000(HistogramName("DiskCache.ReuseCount.Hit", label), |
| info->reuse_count); |
| CACHE_HISTOGRAM_AGE(HistogramName("DiskCache.EntryAge.Hit", label), |
| base::Time::FromInternalValue(info->creation_time)); |
| RecordCacheEvent(CACHE_EVENT_HIT, label); |
| } |
| |
| void RecordEviction(EntryImpl* entry) { |
| const char* label = HistogramLabel(entry->GetKey()); |
| if (!label) |
| return; |
| EntryStore* info = entry->entry()->Data(); |
| CACHE_HISTOGRAM_COUNTS_10000( |
| HistogramName("DiskCache.ReuseCount.Evict", label), |
| info->reuse_count); |
| CACHE_HISTOGRAM_AGE(HistogramName("DiskCache.EntryAge.Evict", label), |
| base::Time::FromInternalValue(info->creation_time)); |
| } |
| |
| } // namespace web_fonts_histogram |
| } // namespace disk_cache |