mirror of
https://github.com/quickwit-oss/tantivy.git
synced 2026-01-06 17:22:54 +00:00
Compare commits
4 Commits
validate_l
...
issue/repr
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
98d17c9c77 | ||
|
|
5583e5d0ad | ||
|
|
1fcf656ed7 | ||
|
|
68fa58d74b |
@@ -73,7 +73,7 @@ debug-assertions = true
|
|||||||
overflow-checks = true
|
overflow-checks = true
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
default = ["mmap"]
|
default = ["mmap", "brotli"]
|
||||||
mmap = ["fs2", "tempfile", "memmap"]
|
mmap = ["fs2", "tempfile", "memmap"]
|
||||||
brotli-compression = ["brotli"]
|
brotli-compression = ["brotli"]
|
||||||
lz4-compression = ["lz4"]
|
lz4-compression = ["lz4"]
|
||||||
|
|||||||
BIN
src/store/broken_seg/e6ece22e5bca4e0dbe7ce3e4dcbd5bbf.store
Normal file
BIN
src/store/broken_seg/e6ece22e5bca4e0dbe7ce3e4dcbd5bbf.store
Normal file
Binary file not shown.
@@ -36,6 +36,8 @@ and should rely on either
|
|||||||
mod index;
|
mod index;
|
||||||
mod reader;
|
mod reader;
|
||||||
mod writer;
|
mod writer;
|
||||||
|
mod tests_store;
|
||||||
|
|
||||||
pub use self::reader::StoreReader;
|
pub use self::reader::StoreReader;
|
||||||
pub use self::writer::StoreWriter;
|
pub use self::writer::StoreWriter;
|
||||||
|
|
||||||
|
|||||||
@@ -50,6 +50,22 @@ impl StoreReader {
|
|||||||
self.skip_index.checkpoints()
|
self.skip_index.checkpoints()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn documents(&self) -> Vec<Document> {
|
||||||
|
let mut documents = Vec::new();
|
||||||
|
for checkpoint in self.skip_index.checkpoints() {
|
||||||
|
println!("{:?}", checkpoint);
|
||||||
|
let block = self.read_block(&checkpoint).unwrap();
|
||||||
|
let mut cursor = &block[..];
|
||||||
|
while cursor.len() > 0 {
|
||||||
|
let doc_length = VInt::deserialize(&mut cursor).unwrap().val() as usize;
|
||||||
|
let doc = Document::deserialize(&mut &cursor[..doc_length]).unwrap();
|
||||||
|
documents.push(doc);
|
||||||
|
cursor = &cursor[doc_length..];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
documents
|
||||||
|
}
|
||||||
|
|
||||||
fn block_checkpoint(&self, doc_id: DocId) -> Option<Checkpoint> {
|
fn block_checkpoint(&self, doc_id: DocId) -> Option<Checkpoint> {
|
||||||
self.skip_index.seek(doc_id)
|
self.skip_index.seek(doc_id)
|
||||||
}
|
}
|
||||||
@@ -104,7 +120,6 @@ impl StoreReader {
|
|||||||
let doc_length = VInt::deserialize(&mut cursor)?.val() as usize;
|
let doc_length = VInt::deserialize(&mut cursor)?.val() as usize;
|
||||||
cursor = &cursor[doc_length..];
|
cursor = &cursor[doc_length..];
|
||||||
}
|
}
|
||||||
|
|
||||||
let doc_length = VInt::deserialize(&mut cursor)?.val() as usize;
|
let doc_length = VInt::deserialize(&mut cursor)?.val() as usize;
|
||||||
cursor = &cursor[..doc_length];
|
cursor = &cursor[..doc_length];
|
||||||
Ok(Document::deserialize(&mut cursor)?)
|
Ok(Document::deserialize(&mut cursor)?)
|
||||||
|
|||||||
50
src/store/tests_store.rs
Normal file
50
src/store/tests_store.rs
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
use std::path::Path;
|
||||||
|
|
||||||
|
use crate::HasLen;
|
||||||
|
use crate::directory::{Directory, ManagedDirectory, MmapDirectory, RAMDirectory};
|
||||||
|
use crate::fastfield::DeleteBitSet;
|
||||||
|
|
||||||
|
use super::{StoreReader, StoreWriter};
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_toto2() -> crate::Result<()> {
|
||||||
|
let directory = ManagedDirectory::wrap(MmapDirectory::open("src/store/broken_seg")?)?;
|
||||||
|
let path = Path::new("b6029ade1b954ea1acad15b432eaacb9.store");
|
||||||
|
assert!(directory.validate_checksum(path)?);
|
||||||
|
let store_file = directory.open_read(path)?;
|
||||||
|
let store = StoreReader::open(store_file)?;
|
||||||
|
let documents = store.documents();
|
||||||
|
// for doc in documents {
|
||||||
|
// println!("{:?}", doc);
|
||||||
|
// }
|
||||||
|
let doc= store.get(15_086)?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_toto() -> crate::Result<()> {
|
||||||
|
let directory = ManagedDirectory::wrap(MmapDirectory::open("src/store/broken_seg")?)?;
|
||||||
|
assert!(directory.validate_checksum(Path::new("e6ece22e5bca4e0dbe7ce3e4dcbd5bbf.store"))?);
|
||||||
|
let store_file = directory.open_read(Path::new("e6ece22e5bca4e0dbe7ce3e4dcbd5bbf.store.patched"))?;
|
||||||
|
let store = StoreReader::open(store_file)?;
|
||||||
|
let doc= store.get(53)?;
|
||||||
|
println!("{:?}", doc);
|
||||||
|
// let documents = store.documents();
|
||||||
|
// let ram_directory = RAMDirectory::create();
|
||||||
|
// let path = Path::new("store");
|
||||||
|
|
||||||
|
// let store_wrt = ram_directory.open_write(path)?;
|
||||||
|
// let mut store_writer = StoreWriter::new(store_wrt);
|
||||||
|
// for doc in &documents {
|
||||||
|
// store_writer.store(doc)?;
|
||||||
|
// }
|
||||||
|
// store_writer.close()?;
|
||||||
|
// let store_data = ram_directory.open_read(path)?;
|
||||||
|
// let new_store = StoreReader::open(store_data)?;
|
||||||
|
// for doc in 0..59 {
|
||||||
|
// println!("{}", doc);
|
||||||
|
// let doc = new_store.get(doc)?;
|
||||||
|
// println!("{:?}", doc);
|
||||||
|
// }
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user