// Copyright 2011 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. // This package is a lightly modified version of the mmap code // in github.com/google/codesearch/index. // The mmap package provides an abstraction for memory mapping files // on different platforms. package mmap import ( "os" ) // Data is mmap'ed read-only data from a file. // The backing file is never closed, so Data // remains valid for the lifetime of the process. type Data struct { f *os.File Data []byte } // Mmap maps the given file into memory. // The boolean result indicates whether the file was opened. // If it is true, the caller should avoid attempting // to write to the file on Windows, because Windows locks // the open file, and writes to it will fail. func Mmap(file string) (Data, bool, error) { f, err := os.Open(file) if err != nil { return Data{}, false, err } data, err := mmapFile(f) // Closing the file causes it not to count against this process's // limit on open files; however, the mapping still counts against // the system-wide limit, which is typically higher. Examples: // // macOS process (sysctl kern.maxfilesperproc): 61440 // macOS system (sysctl kern.maxfiles): 122880 // linux process (ulimit -n) 1048576 // linux system (/proc/sys/fs/file-max) 100000 if cerr := f.Close(); cerr != nil && err == nil { return data, true, cerr } // The file is still considered to be in use on Windows after // it's closed because of the mapping. return data, true, err }