fix errors printing and some other fixes

This commit is contained in:
MeexReay 2025-04-14 00:57:55 +03:00
parent c2208c54ac
commit 0c2a5cb256
3 changed files with 32 additions and 18 deletions

View File

@ -47,18 +47,23 @@ impl ChatStorage {
self.messages.read().unwrap().clone()
}
pub fn update(&self, messages: Vec<String>, packet_size: usize) {
pub fn update(&self, max_length: usize, messages: Vec<String>, packet_size: usize) {
self.packet_size.store(packet_size, Ordering::SeqCst);
let mut messages = messages;
messages.drain(max_length..);
*self.messages.write().unwrap() = messages;
}
pub fn append_and_store(&self, messages: Vec<String>, packet_size: usize) {
pub fn append_and_store(&self, max_length: usize, messages: Vec<String>, packet_size: usize) {
self.packet_size.store(packet_size, Ordering::SeqCst);
self.messages.write().unwrap().append(&mut messages.clone());
self.append(max_length, messages);
}
pub fn append(&self, messages: Vec<String>) {
pub fn append(&self, max_length: usize, messages: Vec<String>) {
self.messages.write().unwrap().append(&mut messages.clone());
if self.messages.read().unwrap().len() > max_length {
self.messages.write().unwrap().drain(max_length..);
}
}
}

View File

@ -1,4 +1,6 @@
use std::sync::Arc;
use std::io::stdout;
use std::io::Write;
use colored::Colorize;
@ -29,38 +31,44 @@ pub fn run_main_loop(ctx: Arc<Context>) {
};
if ctx.enable_chunked {
ctx.messages.append_and_store(messages.clone(), size);
ctx.messages.append_and_store(ctx.max_messages, messages.clone(), size);
} else {
ctx.messages.update(messages.clone(), size);
ctx.messages.update(ctx.max_messages, messages.clone(), size);
}
}
Err(e) => {
let msg = format!("Read messages error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
}
_ => {}
}
},
Err(e) => {
let msg = format!("Connect error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
}
}
print!(
"{}\n{} ",
ctx.messages.messages()
let messages = ctx.messages.messages();
let mut out = stdout().lock();
write!(
out,
"{}\n{}\n{} ",
"\n".repeat(ctx.max_messages - messages.len()),
messages
.into_iter()
.map(|o| o.white().blink().to_string())
.collect::<Vec<String>>()
.join("\n"),
">".bright_yellow()
);
out.flush();
if let Some(message) = get_input("") {
if let Err(e) = on_send_message(ctx.clone(), &message) {
let msg = format!("Send message error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
}
}
}

View File

@ -169,7 +169,7 @@ fn poll_events(ctx: Arc<Context>) -> Result<(), Box<dyn Error>> {
if let Err(e) = on_send_message(ctx.clone(), &message) {
let msg = format!("Send message error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
print_console(ctx.clone(), ctx.messages.messages(), &ctx.input.read().unwrap())?;
}
} else {
@ -328,16 +328,16 @@ pub fn recv_tick(ctx: Arc<Context>) -> Result<(), Box<dyn Error>> {
};
if ctx.enable_chunked {
ctx.messages.append_and_store(messages.clone(), size);
ctx.messages.append_and_store(ctx.max_messages, messages.clone(), size);
print_console(ctx.clone(), ctx.messages.messages(), &ctx.input.read().unwrap())?;
} else {
ctx.messages.update(messages.clone(), size);
ctx.messages.update(ctx.max_messages, messages.clone(), size);
print_console(ctx.clone(), messages, &ctx.input.read().unwrap())?;
}
}
Err(e) => {
let msg = format!("Read messages error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
print_console(ctx.clone(), ctx.messages.messages(), &ctx.input.read().unwrap())?;
}
_ => {}
@ -362,8 +362,9 @@ pub fn run_main_loop(ctx: Arc<Context>) {
loop {
if let Err(e) = recv_tick(ctx.clone()) {
let msg = format!("Print messages error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
let _ = print_console(ctx.clone(), ctx.messages.messages(), &ctx.input.read().unwrap());
thread::sleep(Duration::from_secs(1));
}
}
}
@ -371,7 +372,7 @@ pub fn run_main_loop(ctx: Arc<Context>) {
if let Err(e) = poll_events(ctx.clone()) {
let msg = format!("Poll events error: {}", e.to_string()).bright_red().to_string();
ctx.messages.append(vec![msg]);
ctx.messages.append(ctx.max_messages, vec![msg]);
let _ = print_console(ctx.clone(), ctx.messages.messages(), &ctx.input.read().unwrap());
}
}