mapped-file.h revision 5b6dc79427b8f7eeb6a7ff68034ab8548ce670ea
1 2// Licensed under the Apache License, Version 2.0 (the "License"); 3// you may not use this file except in compliance with the License. 4// You may obtain a copy of the License at 5// 6// http://www.apache.org/licenses/LICENSE-2.0 7// 8// Unless required by applicable law or agreed to in writing, software 9// distributed under the License is distributed on an "AS IS" BASIS, 10// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 11// See the License for the specific language governing permissions and 12// limitations under the License. 13// 14// Copyright 2005-2010 Google, Inc. 15// Author: sorenj@google.com (Jeffrey Sorensen) 16 17#ifndef FST_LIB_MAPPED_FILE_H_ 18#define FST_LIB_MAPPED_FILE_H_ 19 20#include <unistd.h> 21#include <sys/mman.h> 22 23#include <fst/fst.h> 24#include <iostream> 25#include <fstream> 26#include <sstream> 27 28DECLARE_int32(fst_arch_alignment); // defined in mapped-file.h 29 30namespace fst { 31 32// A memory region is a simple abstraction for allocated memory or data from 33// mmap'ed files. If mmap equals NULL, then data represents an owned region of 34// size bytes. Otherwise, mmap and size refer to the mapping and data is a 35// casted pointer to a region contained within [mmap, mmap + size). 36// If size is 0, then mmap refers and data refer to a block of memory managed 37// externally by some other allocator. 38struct MemoryRegion { 39 void *data; 40 void *mmap; 41 size_t size; 42}; 43 44class MappedFile { 45 public: 46 virtual ~MappedFile(); 47 48 void* mutable_data() const { 49 return reinterpret_cast<void*>(region_.data); 50 } 51 52 const void* data() const { 53 return reinterpret_cast<void*>(region_.data); 54 } 55 56 // Returns a MappedFile object that contains the contents of the input 57 // stream s starting from the current file position with size bytes. 58 // The file name must also be provided in the FstReadOptions as opts.source 59 // or else mapping will fail. If mapping is not possible, then a MappedFile 60 // object with a new[]'ed block of memory will be created. 61 static MappedFile* Map(istream* s, const FstReadOptions& opts, size_t size); 62 63 // Creates a MappedFile object with a new[]'ed block of memory of size. 64 // RECOMMENDED FOR INTERNAL USE ONLY, may change in future releases. 65 static MappedFile* Allocate(size_t size); 66 67 // Creates a MappedFile object pointing to a borrowed reference to data. 68 // This block of memory is not owned by the MappedFile object and will not 69 // be freed. 70 // RECOMMENDED FOR INTERNAL USE ONLY, may change in future releases. 71 static MappedFile* Borrow(void *data); 72 73 static const int kArchAlignment; 74 75 private: 76 explicit MappedFile(const MemoryRegion ®ion); 77 78 MemoryRegion region_; 79 DISALLOW_COPY_AND_ASSIGN(MappedFile); 80}; 81} // namespace fst 82 83#endif // FST_LIB_MAPPED_FILE_H_ 84