// Copyright (c) 2012 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.
#ifndef NET_DISK_CACHE_STATS_H_
#define NET_DISK_CACHE_STATS_H_
#include <string>
#include <vector>
#include "base/basictypes.h"
#include "net/disk_cache/addr.h"
#include "net/disk_cache/stats_histogram.h"
namespace base {
class HistogramSamples;
} // namespace base
namespace disk_cache {
typedef std::vector<std::pair<std::string, std::string> > StatsItems;
// This class stores cache-specific usage information, for tunning purposes.
class Stats {
public:
static const int kDataSizesLength = 28;
enum Counters {
MIN_COUNTER = 0,
OPEN_MISS = MIN_COUNTER,
OPEN_HIT,
CREATE_MISS,
CREATE_HIT,
RESURRECT_HIT,
CREATE_ERROR,
TRIM_ENTRY,
DOOM_ENTRY,
DOOM_CACHE,
INVALID_ENTRY,
OPEN_ENTRIES, // Average number of open entries.
MAX_ENTRIES, // Maximum number of open entries.
TIMER,
READ_DATA,
WRITE_DATA,
OPEN_RANKINGS, // An entry has to be read just to modify rankings.
GET_RANKINGS, // We got the ranking info without reading the whole entry.
FATAL_ERROR,
LAST_REPORT, // Time of the last time we sent a report.
LAST_REPORT_TIMER, // Timer count of the last time we sent a report.
DOOM_RECENT, // The cache was partially cleared.
UNUSED, // Was: ga.js was evicted from the cache.
MAX_COUNTER
};
Stats();
~Stats();
// Initializes this object with |data| from disk.
bool Init(void* data, int num_bytes, Addr address);
// Generates a size distribution histogram.
void InitSizeHistogram();
// Returns the number of bytes needed to store the stats on disk.
int StorageSize();
// Tracks changes to the stoage space used by an entry.
void ModifyStorageStats(int32 old_size, int32 new_size);
// Tracks general events.
void OnEvent(Counters an_event);
void SetCounter(Counters counter, int64 value);
int64 GetCounter(Counters counter) const;
void GetItems(StatsItems* items);
int GetHitRatio() const;
int GetResurrectRatio() const;
void ResetRatios();
// Returns the lower bound of the space used by entries bigger than 512 KB.
int GetLargeEntriesSize();
// Writes the stats into |data|, to be stored at the given cache address.
// Returns the number of bytes copied.
int SerializeStats(void* data, int num_bytes, Addr* address);
// Support for StatsHistograms. Together, these methods allow StatsHistograms
// to take a snapshot of the data_sizes_ as the histogram data.
int GetBucketRange(size_t i) const;
void Snapshot(base::HistogramSamples* samples) const;
private:
int GetStatsBucket(int32 size);
int GetRatio(Counters hit, Counters miss) const;
Addr storage_addr_;
int data_sizes_[kDataSizesLength];
int64 counters_[MAX_COUNTER];
StatsHistogram* size_histogram_;
DISALLOW_COPY_AND_ASSIGN(Stats);
};
} // namespace disk_cache
#endif // NET_DISK_CACHE_STATS_H_