2024-12-12 20:44:53 +01:00
|
|
|
//go:build ((linux || darwin || windows || freebsd || openbsd || netbsd || dragonfly || illumos) && (386 || arm || amd64 || arm64 || riscv64 || ppc64le)) || sqlite3_flock || sqlite3_dotlk
|
2024-05-27 17:46:15 +02:00
|
|
|
|
|
|
|
package vfs
|
|
|
|
|
|
|
|
// SupportsSharedMemory is false on platforms that do not support shared memory.
|
|
|
|
// To use [WAL without shared-memory], you need to set [EXCLUSIVE locking mode].
|
|
|
|
//
|
|
|
|
// [WAL without shared-memory]: https://sqlite.org/wal.html#noshm
|
|
|
|
// [EXCLUSIVE locking mode]: https://sqlite.org/pragma.html#pragma_locking_mode
|
|
|
|
const SupportsSharedMemory = true
|
|
|
|
|
|
|
|
func (f *vfsFile) SharedMemory() SharedMemory { return f.shm }
|
|
|
|
|
|
|
|
// NewSharedMemory returns a shared-memory WAL-index
|
|
|
|
// backed by a file with the given path.
|
|
|
|
// It will return nil if shared-memory is not supported,
|
|
|
|
// or not appropriate for the given flags.
|
|
|
|
// Only [OPEN_MAIN_DB] databases may need a WAL-index.
|
|
|
|
// You must ensure all concurrent accesses to a database
|
|
|
|
// use shared-memory instances created with the same path.
|
|
|
|
func NewSharedMemory(path string, flags OpenFlag) SharedMemory {
|
|
|
|
if flags&OPEN_MAIN_DB == 0 || flags&(OPEN_DELETEONCLOSE|OPEN_MEMORY) != 0 {
|
|
|
|
return nil
|
|
|
|
}
|
2024-11-07 01:16:28 +01:00
|
|
|
return &vfsShm{path: path}
|
2024-09-14 16:36:25 +02:00
|
|
|
}
|