4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
7 ** May you do good and not evil.
8 ** May you find forgiveness for yourself and forgive others.
9 ** May you share freely, never taking more than you give.
11 *************************************************************************
13 ** This file contains a VFS "shim" - a layer that sits in between the
14 ** pager and the real VFS.
16 ** This particular shim enforces a multiplex system on DB files.
17 ** This shim shards/partitions a single DB file into smaller
18 ** "chunks" such that the total DB file size may exceed the maximum
19 ** file size of the underlying file system.
23 #ifndef _TEST_MULTIPLEX_H
24 #define _TEST_MULTIPLEX_H
27 ** CAPI: File-control Operations Supported by Multiplex VFS
29 ** Values interpreted by the xFileControl method of a Multiplex VFS db file-handle.
31 ** MULTIPLEX_CTRL_ENABLE:
32 ** This file control is used to enable or disable the multiplex
35 ** MULTIPLEX_CTRL_SET_CHUNK_SIZE:
36 ** This file control is used to set the maximum allowed chunk
37 ** size for a multiplex file set. The chunk size should be
38 ** a multiple of SQLITE_MAX_PAGE_SIZE, and will be rounded up
41 ** MULTIPLEX_CTRL_SET_MAX_CHUNKS:
42 ** This file control is used to set the maximum number of chunks
43 ** allowed to be used for a mutliplex file set.
45 #define MULTIPLEX_CTRL_ENABLE 214014
46 #define MULTIPLEX_CTRL_SET_CHUNK_SIZE 214015
47 #define MULTIPLEX_CTRL_SET_MAX_CHUNKS 214016
50 ** CAPI: Initialize the multiplex VFS shim - sqlite3_multiplex_initialize()
52 ** Use the VFS named zOrigVfsName as the VFS that does the actual work.
53 ** Use the default if zOrigVfsName==NULL.
55 ** The multiplex VFS shim is named "multiplex". It will become the default
56 ** VFS if makeDefault is non-zero.
58 ** An auto-extension is registered which will make the function
59 ** multiplex_control() available to database connections. This
60 ** function gives access to the xFileControl interface of the
61 ** multiplex VFS shim.
63 ** SELECT multiplex_control(<op>,<val>);
65 ** <op>=1 MULTIPLEX_CTRL_ENABLE
69 ** <op>=2 MULTIPLEX_CTRL_SET_CHUNK_SIZE
70 ** <val> int, chunk size
72 ** <op>=3 MULTIPLEX_CTRL_SET_MAX_CHUNKS
73 ** <val> int, max chunks
75 ** THIS ROUTINE IS NOT THREADSAFE. Call this routine exactly once
78 extern int sqlite3_multiplex_initialize(const char *zOrigVfsName
, int makeDefault
);
81 ** CAPI: Shutdown the multiplex system - sqlite3_multiplex_shutdown()
83 ** All SQLite database connections must be closed before calling this
86 ** THIS ROUTINE IS NOT THREADSAFE. Call this routine exactly once while
87 ** shutting down in order to free all remaining multiplex groups.
89 extern int sqlite3_multiplex_shutdown(void);