use idgenerator::*;
use std::time::Instant;
fn main() -> Result<(), OptionError> {
let mut new_id: i64 = 0;
let mut new_id_snd: i64 = 0;
let mut times = 500000;
let options = vec![
IdGeneratorOptions::new().worker_id(1).worker_id_bit_len(6),
IdGeneratorOptions::new().worker_id(2).worker_id_bit_len(6),
];
let _ = IdVecInstance::init(options)?;
let options = IdVecInstance::get_options(0).unwrap();
println!("First setting of index 0: {:?}", options);
let options = IdVecInstance::get_options(1).unwrap();
println!("First setting of index 1: {:?}", options);
let options = IdGeneratorOptions::new().seq_bit_len(12);
let _ = IdVecInstance::set_options(0, options.clone())?;
let _ = IdVecInstance::set_options(1, options)?;
let options = IdVecInstance::get_options(0).unwrap();
println!("Second setting of index 0: {:?}", options);
let options = IdVecInstance::get_options(1).unwrap();
println!("Second setting of index 1: {:?}", options);
println!("Start to generate new unique id");
let start = Instant::now();
while times > 0 {
new_id = IdVecInstance::next_id(0);
new_id_snd = IdVecInstance::next_id(1);
times -= 1;
}
let duration = start.elapsed();
println!(
"Program finished after {} seconds! Last id {}, {}",
duration.as_secs(),
new_id,
new_id_snd,
);
Ok(())
}