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. 28 class 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