diff options
| author | metamuffin <metamuffin@disroot.org> | 2026-02-05 20:31:55 +0100 |
|---|---|---|
| committer | metamuffin <metamuffin@disroot.org> | 2026-02-05 20:31:55 +0100 |
| commit | 65ca3f3450d0067668111f6e13cc3089768c9efe (patch) | |
| tree | 89dceed4f711d25ff2763e18a4be7e1a59e79507 /database/src/kv/sort/value.rs | |
| parent | 1af0468788c0a592a76398206e6c7479384853ec (diff) | |
| download | jellything-65ca3f3450d0067668111f6e13cc3089768c9efe.tar jellything-65ca3f3450d0067668111f6e13cc3089768c9efe.tar.bz2 jellything-65ca3f3450d0067668111f6e13cc3089768c9efe.tar.zst | |
remove read/write distinction for kv transactions; traitify database
Diffstat (limited to 'database/src/kv/sort/value.rs')
| -rw-r--r-- | database/src/kv/sort/value.rs | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/database/src/kv/sort/value.rs b/database/src/kv/sort/value.rs new file mode 100644 index 0000000..0d4ceb7 --- /dev/null +++ b/database/src/kv/sort/value.rs @@ -0,0 +1,86 @@ +/* + This file is part of jellything (https://codeberg.org/metamuffin/jellything) + which is licensed under the GNU Affero General Public License (version 3); see /COPYING. + Copyright (C) 2026 metamuffin <metamuffin.org> +*/ + +use jellyobject::Object; + +use crate::{ + MultiBehaviour, RowNum, ValueSort, + kv::{TableNum, binning::Binning}, +}; + +pub struct ValueIndex { + id: TableNum, + binning: Binning, + sort: ValueSort, +} + +impl ValueIndex { + pub fn new(id: TableNum, binning: Binning, sort: ValueSort) -> Self { + Self { id, binning, sort } + } + fn keys(&self, id: RowNum, ob: Object) -> Vec<Vec<u8>> { + let mut keys = vec![self.id.to_be_bytes().to_vec()]; + self.binning.apply(ob, &mut keys); + self.sort.apply(ob, &mut keys); + for k in &mut keys { + k.extend(id.to_ne_bytes()); + } + keys + } +} +// impl Index for ValueIndex { +// fn add(&self, db: &mut dyn WriteTransaction, id: RowNum, ob: Object) -> Result<()> { +// for key in self.keys(id, ob) { +// db.set(&key, &[])?; +// } +// Ok(()) +// } +// fn remove(&self, db: &mut dyn WriteTransaction, id: RowNum, ob: Object) -> Result<()> { +// for key in self.keys(id, ob) { +// db.del(&key)?; +// } +// Ok(()) +// } +// fn compare(&self, before: Object, after: Object) -> bool { +// self.keys(0, before) == self.keys(0, after) +// } +// fn query(&self, txn: &mut dyn ReadTransaction, sort: &Sort) -> Result<RowIter> { +// todo!() +// } +// } +impl ValueSort { + fn apply(&self, ob: Object, keys: &mut Vec<Vec<u8>>) { + match self.multi { + MultiBehaviour::First => { + if let Some(val) = self.path.get_matching_value(ob) { + for k in keys.iter_mut() { + k.extend(val); + } + } else { + keys.clear(); + } + } + MultiBehaviour::ForEach => { + let mut keys_out = Vec::new(); + for val in self.path.get_matching_values(ob) { + for mut k in keys.clone() { + k.extend(val); + keys_out.push(k); + } + } + *keys = keys_out + } + MultiBehaviour::Max => todo!(), + MultiBehaviour::Min => todo!(), + MultiBehaviour::Count => { + let count = self.path.get_matching_values(ob).len() as u32; + for k in keys.iter_mut() { + k.extend(count.to_be_bytes()); + } + } + } + } +} |