summaryrefslogtreecommitdiffstats
path: root/pdf/chunk_stream.h
blob: fac1ec644de367c60a8a57c18eb7a15395292e96 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright (c) 2010 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 PDF_CHUNK_STREAM_H_
#define PDF_CHUNK_STREAM_H_

#include <stddef.h>

#include <map>
#include <vector>

namespace chrome_pdf {

// This class collects a chunks of data into one data stream. Client can check
// if data in certain range is available, and get missing chunks of data.
class ChunkStream {
 public:
  ChunkStream();
  ~ChunkStream();

  void Clear();

  void Preallocate(size_t stream_size);
  size_t GetSize();

  bool WriteData(size_t offset, void* buffer, size_t size);
  bool ReadData(size_t offset, size_t size, void* buffer) const;

  // Returns vector of pairs where first is an offset, second is a size.
  bool GetMissedRanges(size_t offset, size_t size,
      std::vector<std::pair<size_t, size_t> >* ranges) const;
  bool IsRangeAvailable(size_t offset, size_t size) const;
  size_t GetFirstMissingByte() const;

  size_t GetLastByteBefore(size_t offset) const;
  size_t GetFirstByteAfter(size_t offset) const;

 private:
  std::vector<unsigned char> data_;

  // Pair, first - begining of the chunk, second - size of the chunk.
  std::map<size_t, size_t> chunks_;
};

};  // namespace chrome_pdf

#endif