// 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_