Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/codylico/mmaptwo

Memory mapping files on POSIX and WIndows
https://github.com/codylico/mmaptwo

c89 cmake memory-mapped memory-mapped-file mmap posix unix unlicense win32api

Last synced: about 1 month ago
JSON representation

Memory mapping files on POSIX and WIndows

Awesome Lists containing this project

README

        

# mmaptwo
The `mmaptwo` library aims to provide an API for interacting with files
in memory.

## Goals
This project aims to provide easy-to-use access to the memory mapping on
Unix and Windows. The target API language is C 89. In addition:

- The API should provide a base interface for file accesses.

- The interface should be simple and orthogonal.

- The interface should allow for mapping a file multiple times
without needing to close the file between each mapping.

- The source should not use more language features or libraries
than necessary, and should not be larger (in lines of code)
than needed.

- The library should return error values where appropriate, without
causing an application to abruptly terminate.

## Build

This project uses CMake for building. Developers can obtain CMake from
the following URL:
[https://cmake.org/download/](https://cmake.org/download/)

To use CMake with this project, first make a directory to hold the build
results. Then run CMake in the directory with a path to the source code.
On UNIX, the commands would look like the following:
```
mkdir build
cd build
cmake ../mmaptwo
```

Running CMake should create a build project, which then can be processed
using other tools. Usually, the tool would be Makefile or a IDE project.
For Makefiles, use the following command to build the project:
```
make
```
For IDE projects, the IDE must be installed and ready to use. Open the
project within the IDE.

Since this project's source only holds two files, developers could also
use these files independently from CMake.

## License
This project uses the Unlicense, which makes the source effectively
public domain. Go to [http://unlicense.org/](http://unlicense.org/)
to learn more about the Unlicense.

Contributions to this project should likewise be provided under a
public domain dedication.