Skip to main content

SqliteValue

Struct SqliteValue 

Source
pub struct SqliteValue(/* private fields */);
Expand description

An owned handle to a sqlite3_value.

§Note: Decoding is Stateful

The sqlite3_value interface reserves the right to be stateful:

Other interfaces might change the datatype for an sqlite3_value object. For example, if the datatype is initially SQLITE_INTEGER and sqlite3_value_text(V) is called to extract a text value for that integer, then subsequent calls to sqlite3_value_type(V) might return SQLITE_TEXT. Whether or not a persistent internal datatype conversion occurs is undefined and may change from one release of SQLite to the next.

Thus, this type is !Sync and SqliteValueRef is !Send and !Sync to prevent data races.

Additionally, this statefulness means that the return values of sqlite3_value_bytes() and sqlite3_value_blob() could be invalidated by later calls to other sqlite3_value* methods.

To prevent undefined behavior from accessing dangling pointers, this type (and any SqliteValueRef instances created from it) remembers when it was used to decode a borrowed &[u8] or &str and returns an error if it is used to decode any other type.

To bypass this error, you must prove that no outstanding borrows exist.

This may be done in one of a few ways:

This is only necessary if using the same SqliteValue or SqliteValueRef to decode multiple different types. The vast majority of use-cases employing once-through decoding should not have to worry about this.

Implementations§

Source§

impl SqliteValue

Source

pub fn reset_borrow(&mut self)

Prove that there are no outstanding borrows of this instance.

Call this after decoding a borrowed &[u8] or &str to reset the internal borrowed state and allow decoding of other types.

Source

pub fn try_clone(&self) -> Result<SqliteValue, SqliteError>

Call sqlite3_value_dup() to create a new instance of this type.

Returns an error if the call returns a null pointer, indicating that SQLite was unable to allocate the additional memory required.

Non-panicking version of Self::clone().

Trait Implementations§

Source§

impl Clone for SqliteValue

Source§

fn clone(&self) -> SqliteValue

Call sqlite3_value_dup() to create a new instance of this type.

§Panics

If sqlite3_value_dup() returns a null pointer, indicating an out-of-memory condition.

See Self::try_clone() for a non-panicking version.

1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Value for SqliteValue

Source§

type Database = Sqlite

Source§

fn as_ref(&self) -> SqliteValueRef<'_>

Get this value as a reference.
Source§

fn type_info(&self) -> Cow<'_, SqliteTypeInfo>

Get the type information for this value.
Source§

fn is_null(&self) -> bool

Returns true if the SQL value is NULL.
Source§

fn decode<'r, T>(&'r self) -> T
where T: Decode<'r, Self::Database> + Type<Self::Database>,

Decode this single value into the requested type. Read more
Source§

fn decode_unchecked<'r, T>(&'r self) -> T
where T: Decode<'r, Self::Database>,

Decode this single value into the requested type. Read more
Source§

fn try_decode<'r, T>(&'r self) -> Result<T, Error>
where T: Decode<'r, Self::Database> + Type<Self::Database>,

Decode this single value into the requested type. Read more
Source§

fn try_decode_unchecked<'r, T>(&'r self) -> Result<T, Error>
where T: Decode<'r, Self::Database>,

Decode this single value into the requested type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more