Add a SQLite database backend #265
@ -3,5 +3,5 @@ pub mod json;
|
|||||||
#[cfg(feature = "database-sqlite")]
|
#[cfg(feature = "database-sqlite")]
|
||||||
pub mod sql;
|
pub mod sql;
|
||||||
|
|
||||||
#[cfg(feature = "database-json")]
|
#[cfg(any(feature = "database-json", feature = "database-sqlite"))]
|
||||||
mod serde;
|
mod serde;
|
||||||
|
@ -5,6 +5,8 @@ use crate::core::collection::{
|
|||||||
musicbrainz::MbRefOption,
|
musicbrainz::MbRefOption,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
pub const V20250103: &str = "V20250103";
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, Serialize)]
|
#[derive(Debug, Deserialize, Serialize)]
|
||||||
#[serde(remote = "AlbumLibId")]
|
#[serde(remote = "AlbumLibId")]
|
||||||
pub enum AlbumLibIdDef {
|
pub enum AlbumLibIdDef {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
//! Module for storing MusicHoard data in a JSON file database.
|
//! Module for storing MusicHoard data in a SQLite database.
|
||||||
|
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
|
||||||
@ -10,7 +10,7 @@ use crate::{
|
|||||||
collection::album::AlbumDate,
|
collection::album::AlbumDate,
|
||||||
external::database::{
|
external::database::{
|
||||||
serde::{
|
serde::{
|
||||||
common::SerdeAlbumDate,
|
common::{SerdeAlbumDate, V20250103},
|
||||||
deserialize::{DeserializeAlbum, DeserializeArtist, DeserializeDatabase},
|
deserialize::{DeserializeAlbum, DeserializeArtist, DeserializeDatabase},
|
||||||
serialize::{SerializeAlbum, SerializeArtist, SerializeDatabase},
|
serialize::{SerializeAlbum, SerializeArtist, SerializeDatabase},
|
||||||
},
|
},
|
||||||
@ -157,7 +157,7 @@ impl ISqlTransactionBackend for SqlTransactionSqliteBackend<'_> {
|
|||||||
VALUES (?1, ?2)",
|
VALUES (?1, ?2)",
|
||||||
)?;
|
)?;
|
||||||
let version = match version {
|
let version = match version {
|
||||||
SerializeDatabase::V20250103(_) => "V20250103",
|
SerializeDatabase::V20250103(_) => V20250103,
|
||||||
};
|
};
|
||||||
Self::execute(&mut stmt, ("version", version))
|
Self::execute(&mut stmt, ("version", version))
|
||||||
}
|
}
|
||||||
@ -168,16 +168,11 @@ impl ISqlTransactionBackend for SqlTransactionSqliteBackend<'_> {
|
|||||||
let mut rows = Self::query(&mut stmt, ())?;
|
let mut rows = Self::query(&mut stmt, ())?;
|
||||||
|
|
||||||
match Self::next_row(&mut rows)? {
|
match Self::next_row(&mut rows)? {
|
||||||
Some(row) => {
|
Some(row) => match Self::get_value::<String>(row, 0)?.as_str() {
|
||||||
let version: String = Self::get_value(row, 0)?;
|
V20250103 => Ok(DeserializeDatabase::V20250103(vec![])),
|
||||||
match version.as_str() {
|
s => Err(Error::SerDeError(format!("unknown database version: {s}"))),
|
||||||
"V20250103" => Ok(DeserializeDatabase::V20250103(vec![])),
|
},
|
||||||
s => Err(Error::SerDeError(format!("unknown database version: {s}"))),
|
None => Err(Error::SerDeError(String::from("missing database version"))),
|
||||||
}
|
|
||||||
}
|
|
||||||
None => Err(Error::SerDeError(String::from(
|
|
||||||
"database version is missing",
|
|
||||||
))),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -227,7 +227,7 @@ impl<'de> Deserialize<'de> for SerdeMbid {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct SerdeAlbumDate(pub AlbumDate);
|
pub struct SerdeAlbumDate(AlbumDate);
|
||||||
|
|
||||||
impl From<SerdeAlbumDate> for AlbumDate {
|
impl From<SerdeAlbumDate> for AlbumDate {
|
||||||
fn from(value: SerdeAlbumDate) -> Self {
|
fn from(value: SerdeAlbumDate) -> Self {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user