1/*
2 * Copyright 2012, The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 *     http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17// Defines utility allowing in-memory buffers for bitcode input wrapping.
18
19#ifndef IN_MEMORY_WRAPPER_INPUT_H__
20#define IN_MEMORY_WRAPPER_INPUT_H__
21
22#include <stdio.h>
23
24#include "bcinfo/Wrap/support_macros.h"
25#include "bcinfo/Wrap/wrapper_input.h"
26
27// Define a class to wrap named files.
28class InMemoryWrapperInput : public WrapperInput {
29 public:
30  InMemoryWrapperInput(const char* buffer, size_t size);
31  ~InMemoryWrapperInput();
32  // Tries to read the requested number of bytes into the buffer. Returns the
33  // actual number of bytes read.
34  virtual size_t Read(uint8_t* buffer, size_t wanted);
35  // Returns true if at end of buffer. Note: May return false
36  // until Read is called, and returns 0.
37  virtual bool AtEof();
38  // Returns the size of the buffer (in bytes).
39  virtual off_t Size();
40  // Moves to the given offset within the buffer. Returns
41  // false if unable to move to that position.
42  virtual bool Seek(uint32_t pos);
43 private:
44  // The actual in-memory buffer
45  const char* _buffer;
46  // The position in the buffer
47  size_t _pos;
48  // True once eof has been encountered.
49  bool _at_eof;
50  // The size of the buffer.
51  size_t _size;
52 private:
53  DISALLOW_CLASS_COPY_AND_ASSIGN(InMemoryWrapperInput);
54};
55
56#endif // IN_MEMORY_WRAPPER_INPUT_H__
57