NAME
Sys::Mmap::Simple - Memory mapping made simple and safe.
VERSION
Version 0.01
SYNOPSIS
use Sys::Mmap::Simple 'map_file';
map_file(my $mmap, $filename);
if ($mmap eq "foobar") {
$mmap =~ s/bar/quz/g;
}
DESCRIPTION
This module maps files to Perl variables. There are a few differences between this module and Sys::Mmap.
It offers a more simple interface. It always maps the whole file, and always does shared mapping. This seems to be what people want in 95% of all cases.
This module is safe yet fast. Sys::Mmap offers two interfaces, one is fast, but can segfault if not used correctly. The other is safe, but reportedly 10 times slower. Sys::Mmap::Simple is fast (as long as it is used properly) and safe.
It will automatically unmap the file when the scalar gets destroyed.
FUNCTIONS
The following functions are defined and availible for exportation.
map_handle $variable, *handle, $writable = 0
Use a filehandle to mmap into a variable. $variable must be an lvalue. *handle may be filehandle or a reference to a filehandle.
map_file $variable, $filename, $writable = 0
Open a file and mmap it into a variable. $variable must be an lvalue.
map_anonymous $variable, $length
Map an anonymous piece of memory.
sync $variable
Flush changes made to the memory map back to disk.
locked { block } $variable
Perform an action while keeping a thread lock on the map. The map is accessable as $_
. This is only useful when using threads.
unmap $scalar
Unmap a variable. Note that normally this is not necessary, but it is included for completeness.
DIAGNOSTICS
If you use warnings
, this module will give warnings if the variable is improperly used (anything that changes its size). This can be turned off lexically by using no warnings 'substr'
.
Trying to sync or unmap a variable that hasn't been mapped will result in an exception.
BUGS AND LIMITATIONS
This is an early release. Bugs are likely. Bug reports are welcome.
Please report any bugs or feature requests to bug-sys-mmap-simple at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Sys-Mmap-Simple. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
AUTHOR
Leon Timmermans, <leont at cpan.org>
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc Sys::Mmap::Simple
You can also look for information at:
RT: CPAN's request tracker
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
COPYRIGHT AND LICENSE
Copyright 2008 Leon Timmermans, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.