mirror of
https://github.com/aljazceru/turso.git
synced 2026-02-04 15:54:23 +01:00
Unify sync I/O
This commit is contained in:
53
cli/main.rs
53
cli/main.rs
@@ -1,12 +1,7 @@
|
||||
use anyhow::Result;
|
||||
use clap::{Parser, ValueEnum};
|
||||
use cli_table::{Cell, Table};
|
||||
use lig_core::{Database, DatabaseRef, Value};
|
||||
use lig_core::{Database, Value, SyncIO};
|
||||
use rustyline::{error::ReadlineError, DefaultEditor};
|
||||
use std::cell::RefCell;
|
||||
use std::collections::HashMap;
|
||||
use std::fs::File;
|
||||
use std::io::{Read, Seek};
|
||||
use std::path::PathBuf;
|
||||
use std::sync::Arc;
|
||||
|
||||
@@ -35,7 +30,7 @@ struct Opts {
|
||||
|
||||
fn main() -> anyhow::Result<()> {
|
||||
let opts = Opts::parse();
|
||||
let io = IO::new();
|
||||
let io = SyncIO::new();
|
||||
let db = Database::open(Arc::new(io), opts.database.to_str().unwrap())?;
|
||||
let conn = db.connect();
|
||||
let mut rl = DefaultEditor::new()?;
|
||||
@@ -108,47 +103,3 @@ fn main() -> anyhow::Result<()> {
|
||||
Ok(())
|
||||
}
|
||||
|
||||
struct IO {
|
||||
inner: RefCell<IOInner>,
|
||||
}
|
||||
|
||||
struct IOInner {
|
||||
db_refs: usize,
|
||||
db_files: HashMap<DatabaseRef, File>,
|
||||
}
|
||||
|
||||
impl lig_core::IO for IO {
|
||||
fn open(&self, path: &str) -> Result<DatabaseRef> {
|
||||
let file = std::fs::File::open(path)?;
|
||||
let mut inner = self.inner.borrow_mut();
|
||||
let db_ref = inner.db_refs;
|
||||
inner.db_refs += 1;
|
||||
inner.db_files.insert(db_ref, file);
|
||||
Ok(db_ref)
|
||||
}
|
||||
|
||||
fn get(&self, database_ref: DatabaseRef, page_idx: usize, buf: &mut [u8]) -> Result<()> {
|
||||
let page_size = buf.len();
|
||||
assert!(page_idx > 0);
|
||||
assert!(page_size >= 512);
|
||||
assert!(page_size <= 65536);
|
||||
assert!((page_size & (page_size - 1)) == 0);
|
||||
let mut inner = self.inner.borrow_mut();
|
||||
let file = inner.db_files.get_mut(&database_ref).unwrap();
|
||||
let pos = (page_idx - 1) * page_size;
|
||||
file.seek(std::io::SeekFrom::Start(pos as u64))?;
|
||||
file.read_exact(buf)?;
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
impl IO {
|
||||
fn new() -> Self {
|
||||
Self {
|
||||
inner: RefCell::new(IOInner {
|
||||
db_refs: 0,
|
||||
db_files: HashMap::new(),
|
||||
}),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,61 +1,11 @@
|
||||
use anyhow::Result;
|
||||
use criterion::{criterion_group, criterion_main, Criterion, Throughput};
|
||||
use lig_core::{Database, DatabaseRef};
|
||||
use lig_core::{Database, SyncIO};
|
||||
use pprof::criterion::{Output, PProfProfiler};
|
||||
use std::cell::RefCell;
|
||||
use std::collections::HashMap;
|
||||
use std::fs::File;
|
||||
use std::io::{Read, Seek};
|
||||
use std::sync::Arc;
|
||||
|
||||
struct IO {
|
||||
inner: RefCell<IOInner>,
|
||||
}
|
||||
|
||||
struct IOInner {
|
||||
db_refs: usize,
|
||||
db_files: HashMap<DatabaseRef, File>,
|
||||
}
|
||||
|
||||
impl lig_core::IO for IO {
|
||||
fn open(&self, path: &str) -> Result<DatabaseRef> {
|
||||
println!("Opening database file {}", path);
|
||||
let file = std::fs::File::open(path)?;
|
||||
let mut inner = self.inner.borrow_mut();
|
||||
let db_ref = inner.db_refs;
|
||||
inner.db_refs += 1;
|
||||
inner.db_files.insert(db_ref, file);
|
||||
Ok(db_ref)
|
||||
}
|
||||
|
||||
fn get(&self, database_ref: DatabaseRef, page_idx: usize, buf: &mut [u8]) -> Result<()> {
|
||||
let page_size = buf.len();
|
||||
assert!(page_idx > 0);
|
||||
assert!(page_size >= 512);
|
||||
assert!(page_size <= 65536);
|
||||
assert!((page_size & (page_size - 1)) == 0);
|
||||
let mut inner = self.inner.borrow_mut();
|
||||
let file = inner.db_files.get_mut(&database_ref).unwrap();
|
||||
let pos = (page_idx - 1) * page_size;
|
||||
file.seek(std::io::SeekFrom::Start(pos as u64))?;
|
||||
file.read_exact(buf)?;
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
impl IO {
|
||||
fn new() -> Self {
|
||||
Self {
|
||||
inner: RefCell::new(IOInner {
|
||||
db_refs: 0,
|
||||
db_files: HashMap::new(),
|
||||
}),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn bench_db() -> Database {
|
||||
let io = IO::new();
|
||||
let io = SyncIO::new();
|
||||
Database::open(Arc::new(io), "../testing/hello.db").unwrap()
|
||||
}
|
||||
|
||||
|
||||
1
core/io/mod.rs
Normal file
1
core/io/mod.rs
Normal file
@@ -0,0 +1 @@
|
||||
pub(crate) mod sync_io;
|
||||
53
core/io/sync_io.rs
Normal file
53
core/io/sync_io.rs
Normal file
@@ -0,0 +1,53 @@
|
||||
use crate::{DatabaseRef, IO};
|
||||
|
||||
use std::io::{Read, Seek};
|
||||
use std::cell::RefCell;
|
||||
use std::collections::HashMap;
|
||||
use std::fs::File;
|
||||
use anyhow::Result;
|
||||
|
||||
/// Synchronous I/O using traditional read() and write() system calls.
|
||||
pub struct SyncIO {
|
||||
inner: RefCell<SyncIOInner>,
|
||||
}
|
||||
|
||||
struct SyncIOInner {
|
||||
db_refs: usize,
|
||||
db_files: HashMap<DatabaseRef, File>,
|
||||
}
|
||||
|
||||
impl IO for SyncIO {
|
||||
fn open(&self, path: &str) -> Result<DatabaseRef> {
|
||||
let file = std::fs::File::open(path)?;
|
||||
let mut inner = self.inner.borrow_mut();
|
||||
let db_ref = inner.db_refs;
|
||||
inner.db_refs += 1;
|
||||
inner.db_files.insert(db_ref, file);
|
||||
Ok(db_ref)
|
||||
}
|
||||
|
||||
fn get(&self, database_ref: DatabaseRef, page_idx: usize, buf: &mut [u8]) -> Result<()> {
|
||||
let page_size = buf.len();
|
||||
assert!(page_idx > 0);
|
||||
assert!(page_size >= 512);
|
||||
assert!(page_size <= 65536);
|
||||
assert!((page_size & (page_size - 1)) == 0);
|
||||
let mut inner = self.inner.borrow_mut();
|
||||
let file = inner.db_files.get_mut(&database_ref).unwrap();
|
||||
let pos = (page_idx - 1) * page_size;
|
||||
file.seek(std::io::SeekFrom::Start(pos as u64))?;
|
||||
file.read_exact(buf)?;
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
impl SyncIO {
|
||||
pub fn new() -> Self {
|
||||
Self {
|
||||
inner: RefCell::new(SyncIOInner {
|
||||
db_refs: 0,
|
||||
db_files: HashMap::new(),
|
||||
}),
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -5,6 +5,7 @@ mod schema;
|
||||
mod sqlite3_ondisk;
|
||||
mod types;
|
||||
mod vdbe;
|
||||
mod io;
|
||||
|
||||
use mimalloc::MiMalloc;
|
||||
|
||||
@@ -18,6 +19,7 @@ use schema::Schema;
|
||||
use sqlite3_parser::{ast::Cmd, lexer::sql::Parser};
|
||||
use std::{borrow::BorrowMut, sync::Arc};
|
||||
|
||||
pub use io::sync_io::SyncIO;
|
||||
pub use types::Value;
|
||||
|
||||
pub struct Database {
|
||||
|
||||
Reference in New Issue
Block a user