WebAssembly/Files

From Free Pascal wiki
Jump to navigationJump to search

The WASI target supports filesystem access and this is implemented in the Free Pascal RTL. However, there are some caveats, due to the way WASI is designed.

File access using wasmtime

By default wasmtime disallows any file access, only standard input and output. This is because WebAssembly can be used for sandboxing and running untrusted code. To enable access to a directory, you need to run your program like that:

wasmtime run --dir <DIRECTORY> program.wasm

You can also specify the way the directory is visible inside the program, like this:

wasmtime run --mapdir <GUEST_DIR::HOST_DIR> program.wasm

For example, if you want /home/blabla/tralala on your host system to be visible as the root directory in your WebAssembly program, you can do:

 wasmtime run --mapdir /::/home/blabla/tralala program.wasm

Caveats

Current directory

There is no WASI API function to obtain or change the current directory. All the Free Pascal RTL functions for dealing with the current directory are actually emulated inside the RTL. However, there's no way to specify the initial directory, so, for example, if you run your program like that:

wasmtime run --dir / program.wasm

To grant it access to the root directory and therefore to the entire filesystem, you would expect that your program would also inherit the current directory, however that's not the case. Your program will assume the current directory is /.

Relative paths

If you give access to a directory, using a relative path to wasmtime, e.g.:

wasmtime run --dir . program.wasm

Then the full path will not be known to your program. It will simply see the current directory as ".". Some programs might not expect this, so it's better to use --mapdir in this case, e.g.:

wasmtime run --mapdir /::. program.wasm

This will make the current directory to be visible as / in your program.