Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/leont/file-map

Memory mapping for Perl
https://github.com/leont/file-map

Last synced: 3 months ago
JSON representation

Memory mapping for Perl

Awesome Lists containing this project

README

        

File::Map

File::Map is a module that maps files or anonymous memory into perl variables.

Advantages of memory mapping
* Unlike normal perl variables, mapped memory is shared between
threads or forked processes.

* It is an efficient way to slurp an entire file. Unlike for example
File::Slurp, this module returns almost immediately, loading the
pages lazily on access. This means you only 'pay' for the parts of
the file you actually use.

* Perl normally never returns memory to the system while running,
mapped memory can be returned.

Advantages of this module over other similar modules
Safety and Speed
This module is safe yet fast. Alternatives are either fast but can cause
segfaults or loose the mapping when not used correctly, or are safe but
rather slow. File::Map is as fast as a normal string yet safe.

Simplicity
It offers a more simple interface targeted at common usage patterns

* Files are mapped into a variable that can be read just like any
other variable, and it can be written to using standard Perl
techniques such as regexps and "substr".

* Files can be mapped using a set of simple functions. No weird
constants or 6 argument functions.

* It will automatically unmap the file when the scalar gets destroyed.
This works correctly even in multithreaded programs.

Portability
File::Map supports both Unix and Windows.

Thread synchronization
It has built-in support for thread synchronization.

INSTALLATION

To install this module, run the following commands:

perl Build.PL
./Build
./Build test
./Build install

SUPPORT AND DOCUMENTATION

After installing, you can find documentation for this module with the
perldoc command.

perldoc File::Map

You can also look for information at:

RT, CPAN's request tracker
http://rt.cpan.org/NoAuth/Bugs.html?Dist=File-Map

AnnoCPAN, Annotated CPAN documentation
http://annocpan.org/dist/File-Map

CPAN Ratings
http://cpanratings.perl.org/d/File-Map

Search CPAN
http://search.cpan.org/dist/File-Map

COPYRIGHT AND LICENCE

Copyright (C) 2008 Leon Timmermans

This program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.