#[repr(C)]pub struct OpenFlags(_);
Expand description
Flags for opening SQLite database connections. See sqlite3_open_v2 for details.
The default open flags are SQLITE_OPEN_READ_WRITE | SQLITE_OPEN_CREATE | SQLITE_OPEN_URI | SQLITE_OPEN_NO_MUTEX
. See Connection::open
for
some discussion about these flags.
Implementations§
source§impl OpenFlags
impl OpenFlags
sourcepub const SQLITE_OPEN_READ_ONLY: Self = _
pub const SQLITE_OPEN_READ_ONLY: Self = _
The database is opened in read-only mode. If the database does not already exist, an error is returned.
sourcepub const SQLITE_OPEN_READ_WRITE: Self = _
pub const SQLITE_OPEN_READ_WRITE: Self = _
The database is opened for reading and writing if possible, or reading only if the file is write protected by the operating system. In either case the database must already exist, otherwise an error is returned.
sourcepub const SQLITE_OPEN_CREATE: Self = _
pub const SQLITE_OPEN_CREATE: Self = _
The database is created if it does not already exist
sourcepub const SQLITE_OPEN_URI: Self = _
pub const SQLITE_OPEN_URI: Self = _
The filename can be interpreted as a URI if this flag is set.
sourcepub const SQLITE_OPEN_MEMORY: Self = _
pub const SQLITE_OPEN_MEMORY: Self = _
The database will be opened as an in-memory database.
sourcepub const SQLITE_OPEN_NO_MUTEX: Self = _
pub const SQLITE_OPEN_NO_MUTEX: Self = _
The new database connection will not use a per-connection mutex (the connection will use the “multi-thread” threading mode, in SQLite parlance).
This is used by default, as proper Send
/Sync
usage (in
particular, the fact that Connection
does not implement Sync
)
ensures thread-safety without the need to perform locking around all
calls.
sourcepub const SQLITE_OPEN_FULL_MUTEX: Self = _
pub const SQLITE_OPEN_FULL_MUTEX: Self = _
The new database connection will use a per-connection mutex – the “serialized” threading mode, in SQLite parlance.
Caveats
This flag should probably never be used with rusqlite
, as we
ensure thread-safety statically (we implement Send
and not
Sync
). That said
Critically, even if this flag is used, the Connection
is not
safe to use across multiple threads simultaneously. To access a
database from multiple threads, you should either create multiple
connections, one for each thread (if you have very many threads,
wrapping the rusqlite::Connection
in a mutex is also reasonable).
This is both because of the additional per-connection state stored
by rusqlite
(for example, the prepared statement cache), and
because not all of SQLites functions are fully thread safe, even in
serialized/SQLITE_OPEN_FULLMUTEX
mode.
All that said, it’s fairly harmless to enable this flag with
rusqlite
, it will just slow things down while providing no
benefit.
sourcepub const SQLITE_OPEN_SHARED_CACHE: Self = _
pub const SQLITE_OPEN_SHARED_CACHE: Self = _
The database is opened with shared cache enabled.
This is frequently useful for in-memory connections, but note that broadly speaking it’s discouraged by SQLite itself, which states “Any use of shared cache is discouraged” in the official documentation.
sourcepub const SQLITE_OPEN_PRIVATE_CACHE: Self = _
pub const SQLITE_OPEN_PRIVATE_CACHE: Self = _
The database is opened shared cache disabled.
sourcepub const SQLITE_OPEN_NOFOLLOW: Self = _
pub const SQLITE_OPEN_NOFOLLOW: Self = _
The database filename is not allowed to be a symbolic link. (3.31.0)
sourcepub const SQLITE_OPEN_EXRESCODE: Self = _
pub const SQLITE_OPEN_EXRESCODE: Self = _
Extended result codes. (3.37.0)
sourcepub const fn from_bits(bits: c_int) -> Option<Self>
pub const fn from_bits(bits: c_int) -> Option<Self>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
sourcepub const fn from_bits_truncate(bits: c_int) -> Self
pub const fn from_bits_truncate(bits: c_int) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const fn from_bits_retain(bits: c_int) -> Self
pub const fn from_bits_retain(bits: c_int) -> Self
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
sourcepub fn from_name(name: &str) -> Option<Self>
pub fn from_name(name: &str) -> Option<Self>
Get the value for a flag from its stringified name.
Names are case-sensitive, so must correspond exactly to the identifier given to the flag.
sourcepub const fn iter_names(&self) -> IterRaw
pub const fn iter_names(&self) -> IterRaw
Iterate over enabled flag values with their stringified names.
sourcepub const fn intersects(&self, other: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Returns true
if there are flags common to both self
and other
.
sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Returns true
if all of the flags in other
are contained within self
.
sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Inserts or removes the specified flags depending on the passed value.
sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
Returns the intersection between the flags in self
and
other
.
Specifically, the returned set contains only the flags which are
present in both self
and other
.
This is equivalent to using the &
operator (e.g.
ops::BitAnd
), as in flags & other
.
sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
Returns the union of between the flags in self
and other
.
Specifically, the returned set contains all flags which are
present in either self
or other
, including any which are
present in both (see Self::symmetric_difference
if that
is undesirable).
This is equivalent to using the |
operator (e.g.
ops::BitOr
), as in flags | other
.
sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
Returns the difference between the flags in self
and other
.
Specifically, the returned set contains all flags present in
self
, except for the ones present in other
.
It is also conceptually equivalent to the “bit-clear” operation:
flags & !other
(and this syntax is also supported).
This is equivalent to using the -
operator (e.g.
ops::Sub
), as in flags - other
.
sourcepub const fn symmetric_difference(self, other: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
Returns the symmetric difference between the flags
in self
and other
.
Specifically, the returned set contains the flags present which
are present in self
or other
, but that are not present in
both. Equivalently, it contains the flags present in exactly
one of the sets self
and other
.
This is equivalent to using the ^
operator (e.g.
ops::BitXor
), as in flags ^ other
.
sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
Returns the complement of this set of flags.
Specifically, the returned set contains all the flags which are
not set in self
, but which are allowed for this type.
Alternatively, it can be thought of as the set difference
between Self::all()
and self
(e.g. Self::all() - self
)
This is equivalent to using the !
operator (e.g.
ops::Not
), as in !flags
.
Trait Implementations§
source§impl BitAndAssign<OpenFlags> for OpenFlags
impl BitAndAssign<OpenFlags> for OpenFlags
source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
source§impl BitFlags for OpenFlags
impl BitFlags for OpenFlags
§type IterNames = IterRaw
type IterNames = IterRaw
source§fn from_bits(bits: c_int) -> Option<OpenFlags>
fn from_bits(bits: c_int) -> Option<OpenFlags>
source§fn from_bits_truncate(bits: c_int) -> OpenFlags
fn from_bits_truncate(bits: c_int) -> OpenFlags
source§fn from_bits_retain(bits: c_int) -> OpenFlags
fn from_bits_retain(bits: c_int) -> OpenFlags
source§fn iter_names(&self) -> Self::IterNames
fn iter_names(&self) -> Self::IterNames
source§fn intersects(&self, other: OpenFlags) -> bool
fn intersects(&self, other: OpenFlags) -> bool
true
if there are flags common to both self
and other
.source§impl BitOrAssign<OpenFlags> for OpenFlags
impl BitOrAssign<OpenFlags> for OpenFlags
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXorAssign<OpenFlags> for OpenFlags
impl BitXorAssign<OpenFlags> for OpenFlags
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
source§impl Extend<OpenFlags> for OpenFlags
impl Extend<OpenFlags> for OpenFlags
source§fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
)source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one
)source§impl FromIterator<OpenFlags> for OpenFlags
impl FromIterator<OpenFlags> for OpenFlags
source§fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
source§impl IntoIterator for OpenFlags
impl IntoIterator for OpenFlags
source§impl PartialEq<OpenFlags> for OpenFlags
impl PartialEq<OpenFlags> for OpenFlags
source§impl SubAssign<OpenFlags> for OpenFlags
impl SubAssign<OpenFlags> for OpenFlags
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.