aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTeddy Wing2022-03-19 00:37:32 +0100
committerTeddy Wing2022-03-19 00:37:32 +0100
commitd78addd46aa7633346c47dd310c972ef0e9029fa (patch)
tree794fc485f65b19a29e8162866c05de22f233d7fc
parent052e0e9639e15a4cce5cb5f0ec6399ed195ebb90 (diff)
downloadyaqlite-d78addd46aa7633346c47dd310c972ef0e9029fa.tar.bz2
select(): Build a `yaml_rust::yaml::Hash` for each row
Instead of my earlier `std::collections::HashMap`, build the type we want to return directly in the row closure. Required copying some data like the column names, but I don't see a way around that. I suppose we could make `yaml_rust::Yaml`s from the column headers in the row closure too instead of copying an existing column header that we otherwise never use. This nearly passes the test I have for this function, but it includes the `id` column in the `Yaml` hash. The primary key column will need to be removed.
-rw-r--r--src/select.rs13
-rw-r--r--src/yaml/sql.rs6
2 files changed, 16 insertions, 3 deletions
diff --git a/src/select.rs b/src/select.rs
index 6f82727..5b11fae 100644
--- a/src/select.rs
+++ b/src/select.rs
@@ -39,21 +39,28 @@ pub fn select(
// data.push(row.get(i)?);
// }
- let mut data: HashMap<&yaml_rust::Yaml, Yaml> = HashMap::new();
+ // let mut data: HashMap<&yaml_rust::Yaml, Yaml> = HashMap::new();
+ let mut data = yaml_rust::yaml::Hash::new();
for (i, column) in column_names.iter().enumerate() {
- data.insert(&column, row.get(i)?);
+ let column_value: Yaml = row.get(i)?;
+ data.insert(column.clone(), column_value.into_inner());
}
Ok(data)
},
).unwrap();
+ let mut row = None;
for row_result in rows {
- let row = row_result.unwrap();
+ row = Some(yaml_rust::Yaml::Hash(row_result.unwrap()));
dbg!(&row);
}
+ if let Some(r) = row {
+ return r;
+ }
+
// todo!();
yaml_rust::Yaml::Null
}
diff --git a/src/yaml/sql.rs b/src/yaml/sql.rs
index 49d83f7..ef72aae 100644
--- a/src/yaml/sql.rs
+++ b/src/yaml/sql.rs
@@ -16,6 +16,12 @@ pub(crate) struct Yaml<'a>(pub Cow<'a, yaml::Yaml>);
// impl From<
+impl<'a> Yaml<'a> {
+ pub fn into_inner(self) -> yaml::Yaml {
+ self.0.into_owned()
+ }
+}
+
impl<'a> rusqlite::ToSql for Yaml<'a> {
fn to_sql(&self) -> rusqlite::Result<rusqlite::types::ToSqlOutput<'_>> {
use rusqlite::types::ToSqlOutput;