// 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. // See net/disk_cache/disk_cache.h for the public interface. #ifndef NET_DISK_CACHE_V3_BLOCK_BITMAPS_H_ #define NET_DISK_CACHE_V3_BLOCK_BITMAPS_H_ #include "base/files/file_path.h" #include "net/base/net_export.h" #include "net/disk_cache/addr.h" #include "net/disk_cache/block_files.h" namespace disk_cache { class BackendImplV3; // This class is the interface in the v3 disk cache to the set of files holding // cached data that is small enough to not be efficiently stored in a dedicated // file (i.e. < kMaxBlockSize). It is primarily used to allocate and free // regions in those files used to store data. class NET_EXPORT_PRIVATE BlockBitmaps { public: BlockBitmaps(); ~BlockBitmaps(); void Init(const BlockFilesBitmaps& bitmaps); // Creates a new entry on a block file. block_type indicates the size of block // to be used (as defined on cache_addr.h), block_count is the number of // blocks to allocate, and block_address is the address of the new entry. bool CreateBlock(FileType block_type, int block_count, Addr* block_address); // Removes an entry from the block files. void DeleteBlock(Addr address); // Releases the internal bitmaps. The cache is being purged. void Clear(); // Sends UMA stats. void ReportStats(); // Returns true if the blocks pointed by a given address are currently used. // This method is only intended for debugging. bool IsValid(Addr address); private: // Returns the header number that stores a given address. int GetHeaderNumber(Addr address); // Returns the appropriate header to use for a new block. int HeaderNumberForNewBlock(FileType block_type, int block_count); // Retrieves stats for the given file index. void GetFileStats(int index, int* used_count, int* load); BlockFilesBitmaps bitmaps_; DISALLOW_COPY_AND_ASSIGN(BlockBitmaps); }; } // namespace disk_cache #endif // NET_DISK_CACHE_V3_BLOCK_BITMAPS_H_