#sqlite #vfs #virtual-filesystem #traits #systems #own #memory

sqlite-vfs

Build SQLite virtual file systems (VFS) by implementing a simple Rust trait

2 unstable releases

0.2.0 Jul 8, 2022
0.1.0 Jan 25, 2022

#895 in Filesystem

Download history 1/week @ 2024-07-20 84/week @ 2024-07-27 44/week @ 2024-08-03 29/week @ 2024-08-10 3/week @ 2024-08-17 9/week @ 2024-08-24 14/week @ 2024-08-31 4/week @ 2024-09-07 20/week @ 2024-09-21 85/week @ 2024-09-28 36/week @ 2024-10-05 28/week @ 2024-10-12 82/week @ 2024-10-19 106/week @ 2024-10-26 23/week @ 2024-11-02

248 downloads per month

MIT/Apache

105KB
2.5K SLoC

sqlite-vfs

Build SQLite virtual file systems (VFS) by implementing a simple Rust trait.

Documentation | Example

This library is build for my own use-case. It doesn't expose everything a SQLite VFS provides (e.g. memory mapped files). Feel free to propose additions if the current state doesn't work for your use-case.

Status

This library is still in prototype state and not ready to be used (except for maybe prototypes). While progress will be slow, it is actively worked on.

  • ✅ It passes most of SQLite's TCL test harness.
    • ⚠️ CI only runs full.test and not all.test.
    • ⚠️ Some tests are skipped.
  • ✅ Successfully runs experiments like do-sqlite.
  • ⚠️ It uses unsafe Rust, which hasn't been peer-reviewed yet.
  • ⚠️ It is not used in any production-capacity yet.

Limitations

  • WAL is not supported (but in progress)
  • Memory mapping not supported (xFetch/xUnfetch)
  • Loading extensions not supported (xDl*)
  • Tests run only on UNIX right now (due to std::os::unix usage in tests)
  • Directory sync is not supported
  • Sector size is always 1024
  • Custom device characteristic are not supported (xDeviceCharacteristics)

Dependencies

~1MB
~15K SLoC