2022-11-23 09:53:58 +00:00
|
|
|
use std::path::PathBuf;
|
2022-11-17 00:35:56 +00:00
|
|
|
|
2022-11-29 01:42:18 +00:00
|
|
|
use crate::Editor;
|
|
|
|
use db::sqlez_macros::sql;
|
2022-11-24 08:02:07 +00:00
|
|
|
use db::{connection, query};
|
2022-11-17 00:35:56 +00:00
|
|
|
use sqlez::domain::Domain;
|
2022-11-19 04:59:59 +00:00
|
|
|
use workspace::{ItemId, Workspace, WorkspaceId};
|
2022-11-17 00:35:56 +00:00
|
|
|
|
|
|
|
connection!(DB: EditorDb<(Workspace, Editor)>);
|
|
|
|
|
|
|
|
impl Domain for Editor {
|
|
|
|
fn name() -> &'static str {
|
|
|
|
"editor"
|
|
|
|
}
|
|
|
|
|
|
|
|
fn migrations() -> &'static [&'static str] {
|
2022-11-29 01:42:18 +00:00
|
|
|
&[sql! (
|
2022-11-19 04:59:59 +00:00
|
|
|
CREATE TABLE editors(
|
|
|
|
item_id INTEGER NOT NULL,
|
2022-11-21 07:44:30 +00:00
|
|
|
workspace_id INTEGER NOT NULL,
|
2022-11-19 04:59:59 +00:00
|
|
|
path BLOB NOT NULL,
|
2022-11-19 23:14:13 +00:00
|
|
|
PRIMARY KEY(item_id, workspace_id),
|
|
|
|
FOREIGN KEY(workspace_id) REFERENCES workspaces(workspace_id)
|
|
|
|
ON DELETE CASCADE
|
|
|
|
ON UPDATE CASCADE
|
2022-11-19 04:59:59 +00:00
|
|
|
) STRICT;
|
2022-11-29 01:42:18 +00:00
|
|
|
)]
|
2022-11-17 00:35:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl EditorDb {
|
2022-11-24 08:02:07 +00:00
|
|
|
query! {
|
2022-12-01 00:19:46 +00:00
|
|
|
pub fn get_path(item_id: ItemId, workspace_id: WorkspaceId) -> Result<Option<PathBuf>> {
|
2022-11-29 01:42:18 +00:00
|
|
|
SELECT path FROM editors
|
|
|
|
WHERE item_id = ? AND workspace_id = ?
|
2022-11-24 08:02:07 +00:00
|
|
|
}
|
2022-11-19 04:59:59 +00:00
|
|
|
}
|
|
|
|
|
2022-11-24 08:02:07 +00:00
|
|
|
query! {
|
|
|
|
pub async fn save_path(item_id: ItemId, workspace_id: WorkspaceId, path: PathBuf) -> Result<()> {
|
2022-11-29 01:42:18 +00:00
|
|
|
INSERT OR REPLACE INTO editors(item_id, workspace_id, path)
|
|
|
|
VALUES (?, ?, ?)
|
2022-11-24 08:02:07 +00:00
|
|
|
}
|
2022-11-21 18:38:16 +00:00
|
|
|
}
|
2022-11-17 00:35:56 +00:00
|
|
|
}
|