feat: optmize console output to render only what is visible

egui TextEdit::multiligne will render everything. Use show_rows insteead of show_viewport for AreaScroll to fix this.
This commit is contained in:
Louis-Marie Baer 2024-03-23 16:41:29 +01:00
parent bddc507a83
commit 9f91f88689
5 changed files with 102 additions and 87 deletions

View file

@ -45,13 +45,17 @@
- [x] output log to console in XvB tab - [x] output log to console in XvB tab
- [x] fix some overlapping from upstream - [x] fix some overlapping from upstream
- [ ] edit metadata of project - [ ] edit metadata of project
- [ ] adapt README for XvB - [ ] adapt README for XvB
- [ ] beta release
- [ ] stable release
- [ ] video tutorial to set up XvB Tab
- [ ] adapt doc for new code - [ ] adapt doc for new code
- [ ] cargo package metadata - [ ] cargo package metadata
- [ ] pgp signatures - [ ] pgp signatures
- [x] fix clippy - [x] fix clippy
- [ ] optimizations - [ ] optimizations
- [x] benchmarks table render only what is visible - [x] benchmarks table render only what is visible
- [x] console output render only what is visible
- [ ] migrate to hyper stable - [ ] migrate to hyper stable
- [ ] use tor socks proxy instead of creating one - [ ] use tor socks proxy instead of creating one
- [ ] better organize new code - [ ] better organize new code

View file

@ -1,6 +1,7 @@
use crate::disk::node::Node; use crate::disk::node::Node;
use crate::disk::state::{P2pool, State}; use crate::disk::state::{P2pool, State};
use crate::helper::p2pool::PubP2poolApi; use crate::helper::p2pool::PubP2poolApi;
use crate::regex::num_lines;
// Gupax - GUI Uniting P2Pool And XMRig // Gupax - GUI Uniting P2Pool And XMRig
// //
// Copyright (c) 2022-2023 hinto-janai // Copyright (c) 2022-2023 hinto-janai
@ -18,7 +19,11 @@ use crate::helper::p2pool::PubP2poolApi;
// You should have received a copy of the GNU General Public License // You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>. // along with this program. If not, see <https://www.gnu.org/licenses/>.
use crate::{components::node::*, constants::*, helper::*, macros::*, utils::regex::Regexes}; use crate::{components::node::*, constants::*, helper::*, macros::*, utils::regex::Regexes};
use egui::{vec2, Color32, Label, RichText, TextEdit, TextStyle::*, Vec2}; use egui::{
vec2, Color32, Label, RichText, TextEdit,
TextStyle::{self, *},
Vec2,
};
use log::*; use log::*;
use std::sync::{Arc, Mutex}; use std::sync::{Arc, Mutex};
@ -45,49 +50,45 @@ impl P2pool {
let width = size.x; let width = size.x;
let text_edit = size.y / 25.0; let text_edit = size.y / 25.0;
//---------------------------------------------------------------------------------------------------- [Simple] Console //---------------------------------------------------------------------------------------------------- [Simple] Console
debug!("P2Pool Tab | Rendering [Console]"); // debug!("P2Pool Tab | Rendering [Console]");
ui.group(|ui| { ui.group(|ui| {
if self.simple { let text = &lock!(api).output;
// height of console = height - address - simple(dropmenu, select_bar, buttons, warning) let nb_lines = num_lines(text);
let height = (size.y * 0.38) - SPACE; let (height, width) = if self.simple {
let width = size.x - SPACE; ((size.y * 0.38) - SPACE, size.x - SPACE)
egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| {
ui.style_mut().override_text_style = Some(Name("MonospaceSmall".into()));
egui::ScrollArea::vertical()
.stick_to_bottom(true)
.max_width(width)
.max_height(height)
.auto_shrink([false; 2])
.show_viewport(ui, |ui, _| {
ui.add_sized(
[width, height],
TextEdit::multiline(&mut lock!(api).output.as_str()),
);
});
});
//---------------------------------------------------------------------------------------------------- [Advanced] Console
} else { } else {
// fix for advanced submenu overlap on bottom when small window (
let height = if size.y < 600.0 { if size.y < 600.0 {
size.y * 0.22 - SPACE size.y * 0.22 - SPACE
} else { } else {
size.y * 0.36 - SPACE size.y * 0.36 - SPACE
}; },
let width = width - SPACE; width - SPACE,
egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| { )
ui.style_mut().override_text_style = Some(Name("MonospaceSmall".into())); };
egui::ScrollArea::vertical() egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| {
.stick_to_bottom(true) ui.style_mut().override_text_style = Some(Name("MonospaceSmall".into()));
.max_width(width) egui::ScrollArea::vertical()
.max_height(height) .stick_to_bottom(true)
.auto_shrink([false; 2]) .max_width(width)
.show_viewport(ui, |ui, _| { .max_height(height)
ui.add_sized( .auto_shrink([false; 2])
[width, height], // .show_viewport(ui, |ui, _| {
TextEdit::multiline(&mut lock!(api).output.as_str()), .show_rows(
); ui,
}); ui.text_style_height(&TextStyle::Name("MonospaceSmall".into())),
}); nb_lines,
|ui, row_range| {
for i in row_range {
if let Some(line) = text.lines().nth(i) {
ui.label(line);
}
}
},
);
});
if !self.simple {
//---------------------------------------------------------------------------------------------------- [Advanced] Console
ui.separator(); ui.separator();
let response = ui let response = ui
.add_sized( .add_sized(

View file

@ -19,12 +19,13 @@ use crate::disk::pool::Pool;
use crate::disk::state::Xmrig; use crate::disk::state::Xmrig;
use crate::helper::xmrig::PubXmrigApi; use crate::helper::xmrig::PubXmrigApi;
use crate::helper::Process; use crate::helper::Process;
use crate::regex::REGEXES; use crate::regex::{num_lines, REGEXES};
use crate::utils::regex::Regexes; use crate::utils::regex::Regexes;
use crate::{constants::*, macros::*}; use crate::{constants::*, macros::*};
use egui::{ use egui::{
vec2, Button, Checkbox, ComboBox, Label, RichText, SelectableLabel, Slider, TextEdit, vec2, Button, Checkbox, ComboBox, Label, RichText, SelectableLabel, Slider, TextEdit,
TextStyle::*, Vec2, TextStyle::{self, *},
Vec2,
}; };
use log::*; use log::*;
@ -47,43 +48,36 @@ impl Xmrig {
//---------------------------------------------------------------------------------------------------- [Simple] Console //---------------------------------------------------------------------------------------------------- [Simple] Console
debug!("XMRig Tab | Rendering [Console]"); debug!("XMRig Tab | Rendering [Console]");
ui.group(|ui| { ui.group(|ui| {
if self.simple { let text = &lock!(api).output;
let height = size.y / 1.5; let nb_lines = num_lines(text);
let width = size.x - SPACE; let (height, width) = if self.simple {
let size = vec2(width, height); (size.y / 1.5, size.x - SPACE)
egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| {
ui.style_mut().override_text_style = Some(Name("MonospaceSmall".into()));
egui::ScrollArea::vertical()
.stick_to_bottom(true)
.max_width(width)
.max_height(height)
.auto_shrink([false; 2])
.show_viewport(ui, |ui, _| {
ui.add_sized(
size,
TextEdit::multiline(&mut lock!(api).output.as_str()),
);
});
});
//---------------------------------------------------------------------------------------------------- [Advanced] Console
} else { } else {
let height = size.y / 2.8; (size.y / 2.8, size.x - SPACE)
let width = size.x - SPACE; };
let size = vec2(width, height); egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| {
egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| { ui.style_mut().override_text_style = Some(Name("MonospaceSmall".into()));
ui.style_mut().override_text_style = Some(Name("MonospaceSmall".into())); egui::ScrollArea::vertical()
egui::ScrollArea::vertical() .stick_to_bottom(true)
.stick_to_bottom(true) .max_width(width)
.max_width(width) .max_height(height)
.max_height(height) .auto_shrink([false; 2])
.auto_shrink([false; 2]) // .show_viewport(ui, |ui, _| {
.show_viewport(ui, |ui, _| { .show_rows(
ui.add_sized( ui,
size, ui.text_style_height(&TextStyle::Name("MonospaceSmall".into())),
TextEdit::multiline(&mut lock!(api).output.as_str()), nb_lines,
); |ui, row_range| {
}); for i in row_range {
}); if let Some(line) = text.lines().nth(i) {
ui.label(line);
}
}
},
);
});
//---------------------------------------------------------------------------------------------------- [Advanced] Console
if !self.simple {
ui.separator(); ui.separator();
let response = ui let response = ui
.add_sized( .add_sized(

View file

@ -6,6 +6,7 @@ use log::debug;
use readable::num::Float; use readable::num::Float;
use crate::helper::xvb::PubXvbApi; use crate::helper::xvb::PubXvbApi;
use crate::regex::num_lines;
use crate::utils::constants::{ use crate::utils::constants::{
GREEN, LIGHT_GRAY, ORANGE, RED, XVB_DONATED_1H_FIELD, XVB_DONATED_24H_FIELD, XVB_FAILURE_FIELD, GREEN, LIGHT_GRAY, ORANGE, RED, XVB_DONATED_1H_FIELD, XVB_DONATED_24H_FIELD, XVB_FAILURE_FIELD,
XVB_HELP, XVB_HERO_SELECT, XVB_ROUND_TYPE_FIELD, XVB_TOKEN_FIELD, XVB_TOKEN_LEN, XVB_URL_RULES, XVB_HELP, XVB_HERO_SELECT, XVB_ROUND_TYPE_FIELD, XVB_TOKEN_FIELD, XVB_TOKEN_LEN, XVB_URL_RULES,
@ -47,6 +48,8 @@ impl crate::disk::state::Xvb {
// console output for log // console output for log
debug!("XvB Tab | Rendering [Console]"); debug!("XvB Tab | Rendering [Console]");
ui.group(|ui| { ui.group(|ui| {
let text = &lock!(api).output;
let nb_lines = num_lines(text);
let height = size.y / 2.8; let height = size.y / 2.8;
let width = size.x - (space_h / 2.0); let width = size.x - (space_h / 2.0);
egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| { egui::Frame::none().fill(DARK_GRAY).show(ui, |ui| {
@ -56,12 +59,19 @@ impl crate::disk::state::Xvb {
.max_width(width) .max_width(width)
.max_height(height) .max_height(height)
.auto_shrink([false; 2]) .auto_shrink([false; 2])
.show_viewport(ui, |ui, _| { // .show_viewport(ui, |ui, _| {
ui.add_sized( .show_rows(
[width, height], ui,
TextEdit::multiline(&mut lock!(api).output.as_str()), ui.text_style_height(&TextStyle::Name("MonospaceSmall".into())),
); nb_lines,
}); |ui, row_range| {
for i in row_range {
if let Some(line) = text.lines().nth(i) {
ui.label(line);
}
}
},
);
}); });
}); });
// input token // input token

View file

@ -123,6 +123,12 @@ impl XmrigRegex {
} }
} }
} }
// count the lines without consuming.
pub fn num_lines(s: &str) -> usize {
static LINE_BREAKS: Lazy<Regex> = Lazy::new(|| Regex::new(r"\r?\n").unwrap());
LINE_BREAKS.captures_iter(s).count() + 1
}
//---------------------------------------------------------------------------------------------------- TEST //---------------------------------------------------------------------------------------------------- TEST
#[cfg(test)] #[cfg(test)]
mod test { mod test {