zed/crates/editor/src/persistence.rs

48 lines
1.3 KiB
Rust
Raw Normal View History

use std::path::{Path, PathBuf};
2022-11-21 18:38:16 +00:00
use db::{connection, sql_method};
use indoc::indoc;
use sqlez::domain::Domain;
use workspace::{ItemId, Workspace, WorkspaceId};
use crate::Editor;
connection!(DB: EditorDb<(Workspace, Editor)>);
impl Domain for Editor {
fn name() -> &'static str {
"editor"
}
fn migrations() -> &'static [&'static str] {
&[indoc! {"
CREATE TABLE editors(
item_id INTEGER NOT NULL,
workspace_id INTEGER NOT NULL,
path BLOB NOT NULL,
PRIMARY KEY(item_id, workspace_id),
FOREIGN KEY(workspace_id) REFERENCES workspaces(workspace_id)
ON DELETE CASCADE
ON UPDATE CASCADE
) STRICT;
"}]
}
}
impl EditorDb {
2022-11-21 18:52:19 +00:00
sql_method! {
get_path(item_id: ItemId, workspace_id: WorkspaceId) -> Result<PathBuf>:
2022-11-21 18:52:19 +00:00
indoc! {"
SELECT path FROM editors
WHERE item_id = ? AND workspace_id = ?"}
}
2022-11-21 18:38:16 +00:00
sql_method! {
save_path(item_id: ItemId, workspace_id: WorkspaceId, path: &Path) -> Result<()>:
2022-11-21 18:52:19 +00:00
indoc! {"
INSERT OR REPLACE INTO editors(item_id, workspace_id, path)
VALUES (?, ?, ?)"}
2022-11-21 18:38:16 +00:00
}
}