wip: refactoring all the structure and improve error messages
This commit is contained in:
		
					parent
					
						
							
								f98c778a0c
							
						
					
				
			
			
				commit
				
					
						de91c7a68f
					
				
			
		
					 10 changed files with 268 additions and 56 deletions
				
			
		
							
								
								
									
										31
									
								
								rpxy-lib/src/count.rs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								rpxy-lib/src/count.rs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,31 @@ | |||
| use std::sync::{ | ||||
|   atomic::{AtomicUsize, Ordering}, | ||||
|   Arc, | ||||
| }; | ||||
| 
 | ||||
| #[derive(Debug, Clone, Default)] | ||||
| /// Counter for serving requests
 | ||||
| pub struct RequestCount(Arc<AtomicUsize>); | ||||
| 
 | ||||
| impl RequestCount { | ||||
|   pub fn current(&self) -> usize { | ||||
|     self.0.load(Ordering::Relaxed) | ||||
|   } | ||||
| 
 | ||||
|   pub fn increment(&self) -> usize { | ||||
|     self.0.fetch_add(1, Ordering::Relaxed) | ||||
|   } | ||||
| 
 | ||||
|   pub fn decrement(&self) -> usize { | ||||
|     let mut count; | ||||
|     while { | ||||
|       count = self.0.load(Ordering::Relaxed); | ||||
|       count > 0 | ||||
|         && self | ||||
|           .0 | ||||
|           .compare_exchange(count, count - 1, Ordering::Relaxed, Ordering::Relaxed) | ||||
|           != Ok(count) | ||||
|     } {} | ||||
|     count | ||||
|   } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Jun Kurihara
				Jun Kurihara