| 
									
										
										
										
											2022-12-23 22:32:30 -05:00
										 |  |  | #![allow(unused_variables)] // TODO(you): remove this lint after implementing this mod
 | 
					
						
							|  |  |  | #![allow(dead_code)] // TODO(you): remove this lint after implementing this mod
 | 
					
						
							| 
									
										
										
										
											2022-12-23 21:14:11 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-23 22:32:30 -05:00
										 |  |  | mod builder;
 | 
					
						
							|  |  |  | mod iterator;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use std::{path::Path, sync::Arc};
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pub use builder::SsTableBuilder;
 | 
					
						
							|  |  |  | use bytes::{Buf, Bytes};
 | 
					
						
							|  |  |  | pub use iterator::SsTableIterator;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use crate::block::Block;
 | 
					
						
							|  |  |  | use anyhow::Result;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[derive(Clone, Debug, PartialEq, Eq)]
 | 
					
						
							|  |  |  | pub struct BlockMeta {
 | 
					
						
							|  |  |  |     /// Offset of this data block.
 | 
					
						
							|  |  |  |     pub offset: usize,
 | 
					
						
							|  |  |  |     /// The first key of the data block.
 | 
					
						
							|  |  |  |     pub first_key: Bytes,
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | impl BlockMeta {
 | 
					
						
							|  |  |  |     /// Encode block meta to a buffer.
 | 
					
						
							|  |  |  |     pub fn encode_block_meta(
 | 
					
						
							|  |  |  |         block_meta: &[BlockMeta],
 | 
					
						
							| 
									
										
										
										
											2022-12-23 23:45:09 -05:00
										 |  |  |         #[allow(clippy::ptr_arg)] /* remove this allow after you finish */ buf: &mut Vec<u8>,
 | 
					
						
							| 
									
										
										
										
											2022-12-23 22:32:30 -05:00
										 |  |  |     ) {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Decode block meta from a buffer.
 | 
					
						
							|  |  |  |     pub fn decode_block_meta(buf: impl Buf) -> Vec<BlockMeta> {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// A file object.
 | 
					
						
							|  |  |  | pub struct FileObject(Bytes);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | impl FileObject {
 | 
					
						
							|  |  |  |     pub fn read(&self, offset: u64, len: u64) -> Result<Vec<u8>> {
 | 
					
						
							|  |  |  |         Ok(self.0[offset as usize..(offset + len) as usize].to_vec())
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn size(&self) -> u64 {
 | 
					
						
							|  |  |  |         self.0.len() as u64
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn create(path: &Path, data: Vec<u8>) -> Result<Self> {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn open(path: &Path) -> Result<Self> {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pub struct SsTable {}
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | impl SsTable {
 | 
					
						
							|  |  |  |     /// Open SSTable from a file.
 | 
					
						
							|  |  |  |     pub fn open(file: FileObject) -> Result<Self> {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Read a block from the disk.
 | 
					
						
							|  |  |  |     pub fn read_block(&self, block_idx: usize) -> Result<Arc<Block>> {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Find the block that may contain `key`.
 | 
					
						
							|  |  |  |     pub fn find_block_idx(&self, key: &[u8]) -> usize {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Get number of data blocks.
 | 
					
						
							|  |  |  |     pub fn num_of_blocks(&self) -> usize {
 | 
					
						
							|  |  |  |         unimplemented!()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[cfg(test)]
 | 
					
						
							|  |  |  | mod tests;
 |