# File::Map
πŸ“¦ std
Memory-mapped scalars: make a file look like an ordinary string. `File::Map` attaches a file β€” or a fresh anonymous region of memory β€” to a Perl scalar. Reads and writes to the scalar go straight to the kernel’s mapping: the file appears in your variable as a string, and changes propagate back without you ever calling `read` or `write`. A multi-gigabyte file costs almost nothing to open this way, because pages are faulted in lazily as you touch them. Once a scalar is mapped it behaves like a regular string for the operations that matter: `substr`, regex match and substitution, `index`, `length`, and slicing. Direct assignment (`$map = "..."`) is caught and fixed up so you never corrupt the mapping, though `substr` is the recommended way to write. The mapping is released automatically when the scalar goes out of scope; `unmap` is available for explicit control. ## Synopsis ```perl use File::Map qw(map_file map_anonymous unmap); map_file my $map, 'data.bin', '+<'; # read/write $map =~ s/foo/bar/g; # edits go to disk substr $map, 0, 4, "HEAD"; # in-place write map_anonymous my $buf, 4096, 'shared'; # scratch region unmap $map; # optional ``` ## Choosing a mapping function - `map_file` β€” give a filename and a mode, get a mapped scalar. The common case. - `map_handle` β€” same idea, but you already have an open filehandle. - `map_anonymous` β€” no file; a scratch region shared with forked children or private to the process. - `sys_map` β€” low-level wrapper around raw `mmap(2)` flags for when the convenience functions don’t fit. ## Managing a live mapping - `sync` β€” flush pending writes back to disk. - `advise` β€” hint the kernel about access patterns (`"sequential"`, `"random"`, `"willneed"`, …). - `protect` β€” change read/write protection at runtime. - `remap` β€” resize an existing mapping (Linux only). - `unmap` β€” drop the mapping explicitly. ## Functions ### Mapping #### [`map_file`](Map/map_file.md) Open a file by name and attach it to a scalar as a memory map. #### [`map_handle`](Map/map_handle.md) Attach an already-open filehandle to a scalar as a memory map. #### [`map_anonymous`](Map/map_anonymous.md) Allocate a fresh memory region backed by no file and attach it to a scalar. #### [`sys_map`](Map/sys_map.md) Low-level mapping with raw `mmap(2)` protection and flag constants. #### [`remap`](Map/remap.md) Resize an existing mapping in place. ### Unmapping #### [`unmap`](Map/unmap.md) Release a mapping explicitly before the scalar goes out of scope. ### Synchronisation #### [`sync`](Map/sync.md) Flush pending writes from a mapped scalar back to disk. ### Advice #### [`advise`](Map/advise.md) Tell the kernel how the mapped region will be accessed. #### [`protect`](Map/protect.md) Change the read/write/execute protection of a mapped region.