aboutsummaryrefslogtreecommitdiffstats
path: root/src/sqlite.rs
diff options
context:
space:
mode:
authorTeddy Wing2022-03-10 00:02:40 +0100
committerTeddy Wing2022-03-10 00:03:08 +0100
commitf8fec23264acd576860509d6cf68d49b23330fc3 (patch)
treebc6da56469464eb89baf0be1b8ebf4401db5aaaa /src/sqlite.rs
parent06d872db01752763daf4a423806bb5e0cd4bd3f7 (diff)
downloadyaqlite-f8fec23264acd576860509d6cf68d49b23330fc3.tar.bz2
Start encoding SQLite affinity rules
Need to figure out what to do for NUMERIC affinity since Rusqlite doesn't expose a variant for that pseudo-type.
Diffstat (limited to 'src/sqlite.rs')
-rw-r--r--src/sqlite.rs25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/sqlite.rs b/src/sqlite.rs
index 10dbb61..8094398 100644
--- a/src/sqlite.rs
+++ b/src/sqlite.rs
@@ -6,4 +6,29 @@ use rusqlite;
/// Use the SQLite rules for type affinity described in:
/// https://sqlite.org/datatype3.html#determination_of_column_affinity
pub fn affinity(type_name: &str) -> rusqlite::types::Type {
+ use rusqlite::types::Type;
+
+ let type_name = type_name.to_uppercase();
+
+ if type_name.contains("INT") {
+ return Type::Integer;
+ } else if type_name.contains("CHAR")
+ || type_name.contains("CLOB")
+ || type_name.contains("TEXT")
+ {
+ return Type::Text;
+ } else if type_name.contains("BLOB")
+ || type_name.is_empty()
+ {
+ return Type::Blob;
+ } else if type_name.contains("REAL")
+ || type_name.contains("FLOA")
+ || type_name.contains("DOUB")
+ {
+ return Type::Real;
+ }
+
+ // TODO: Numeric affinity
+
+ Type::Text
}