46
									
								
								mini-lsm-starter/src/compact/simple_leveled.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								mini-lsm-starter/src/compact/simple_leveled.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| use serde::{Deserialize, Serialize}; | ||||
|  | ||||
| use crate::lsm_storage::LsmStorageState; | ||||
|  | ||||
| #[derive(Debug, Clone)] | ||||
| pub struct SimpleLeveledCompactionOptions { | ||||
|     pub size_ratio_percent: usize, | ||||
|     pub level0_file_num_compaction_trigger: usize, | ||||
|     pub max_levels: usize, | ||||
| } | ||||
|  | ||||
| #[derive(Debug, Serialize, Deserialize)] | ||||
| pub struct SimpleLeveledCompactionTask { | ||||
|     // if upper_level is `None`, then it is L0 compaction | ||||
|     pub upper_level: Option<usize>, | ||||
|     pub upper_level_sst_ids: Vec<usize>, | ||||
|     pub lower_level: usize, | ||||
|     pub lower_level_sst_ids: Vec<usize>, | ||||
|     pub is_lower_level_bottom_level: bool, | ||||
| } | ||||
|  | ||||
| pub struct SimpleLeveledCompactionController { | ||||
|     options: SimpleLeveledCompactionOptions, | ||||
| } | ||||
|  | ||||
| impl SimpleLeveledCompactionController { | ||||
|     pub fn new(options: SimpleLeveledCompactionOptions) -> Self { | ||||
|         Self { options } | ||||
|     } | ||||
|  | ||||
|     pub fn generate_compaction_task( | ||||
|         &self, | ||||
|         snapshot: &LsmStorageState, | ||||
|     ) -> Option<SimpleLeveledCompactionTask> { | ||||
|         unimplemented!() | ||||
|     } | ||||
|  | ||||
|     pub fn apply_compaction_result( | ||||
|         &self, | ||||
|         snapshot: &LsmStorageState, | ||||
|         task: &SimpleLeveledCompactionTask, | ||||
|         output: &[usize], | ||||
|     ) -> (LsmStorageState, Vec<usize>) { | ||||
|         unimplemented!() | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Alex Chi
					Alex Chi