1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
use crate::row::{ColumnIndex, Row};
use crate::sqlite::statement::Statement;
use crate::sqlite::value::SqliteValue;
use crate::sqlite::{Sqlite, SqliteConnection};
use serde::de::DeserializeOwned;
#[derive(Debug)]
pub struct SqliteRow<'c> {
pub(super) column_keys: Vec<String>,
pub(super) statement: Option<usize>,
pub(super) connection: &'c SqliteConnection,
}
impl crate::row::private_row::Sealed for SqliteRow<'_> {}
unsafe impl Send for SqliteRow<'_> {}
unsafe impl Sync for SqliteRow<'_> {}
impl<'c> SqliteRow<'c> {
#[inline]
fn statement(&self) -> &'c Statement {
self.connection.statement(self.statement)
}
}
impl <'c>SqliteRow<'c>{
pub fn json_decode_impl<T, I>(&self, index: I) -> crate::Result<T>
where
I: ColumnIndex<'c, Self>,
T: DeserializeOwned
{
self.json_decode(index)
}
}
impl<'c> Row<'c> for SqliteRow<'c> {
type Database = Sqlite;
#[inline]
fn len(&self) -> usize {
self.column_keys.len()
}
#[doc(hidden)]
fn try_get_raw<I>(&self, index: I) -> crate::Result<SqliteValue<'c>>
where
I: ColumnIndex<'c, Self>,
{
Ok(SqliteValue {
statement: self.statement(),
index: index.index(self)? as i32,
})
}
}
impl<'c> ColumnIndex<'c, SqliteRow<'c>> for usize {
fn index(&self, row: &SqliteRow<'c>) -> crate::Result<usize> {
let len = Row::len(row);
if *self >= len {
return Err(crate::Error::ColumnIndexOutOfBounds { len, index: *self });
}
Ok(*self)
}
}
impl<'c> ColumnIndex<'c, SqliteRow<'c>> for str {
fn index(&self, row: &SqliteRow<'c>) -> crate::Result<usize> {
row.statement()
.columns
.get(self)
.ok_or_else(|| crate::Error::ColumnNotFound((*self).into()))
.map(|&index| index as usize)
}
}