-
Notifications
You must be signed in to change notification settings - Fork 247
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Progress bar not clear when changing style #669
Comments
Hey, sorry for the regression. Unfortunately I probably won't have time to look into this soon -- though it might help if you can do some more debugging on what code changes changed behavior for your use case for the worse. I don't think there were all that many changes between 0.17.8 and 0.17.9... |
Hi ! Could you try the branch from #671 to see if it fixes your issue ? |
Of course. I let you know once I have tested it. Thanks for the quick feedback! |
@spoutn1k, I tried branch fix-double-prints from https://github.com/spoutn1k/indicatif.git and it did not fix the issue.
|
Ok good news is, it keeps the project count broken by me down. Bad news is, I was not reponsible so I have no idea what is up for you. I'm fixing my mess in #671 and then I will take a look. |
Okay, I suggest you try to use git bisect to identify the offending commit. |
@DBY047 Would it be possible to share a minimal version of the code presenting this issue so that I could implement a test for it ? |
@spoutn1k, I reproduced it with the multi.rs example. Without the set_move_cursor set to true With the the set_move_cursor set to true use std::thread;
use std::time::Duration;
use indicatif::{MultiProgress, ProgressBar, ProgressStyle};
fn main() {
let m = MultiProgress::new();
let default_style = ProgressStyle::with_template("{msg}").unwrap();
let sty = ProgressStyle::with_template(
"[{elapsed_precise}] {bar:40.cyan/blue} {pos:>7}/{len:7} {msg}",
)
.unwrap()
.progress_chars("##-");
let n = 200;
let pb = m.add(ProgressBar::new(n));
pb.set_style(sty.clone());
pb.set_message("todo");
let pb2 = m.add(ProgressBar::new(n));
pb2.set_style(sty.clone());
pb2.set_message("finished");
let pb3 = m.insert_after(&pb2, ProgressBar::new(1024));
pb3.set_style(sty);
m.set_move_cursor(true);
let mut threads = vec![];
let default_style_clone = default_style.clone();
let h3 = thread::spawn(move || {
for i in 0..1024 {
thread::sleep(Duration::from_millis(2));
pb3.set_message(format!("item #{}", i + 1));
pb3.inc(1);
}
pb3.set_style(default_style_clone);
pb3.finish_with_message("done");
});
for i in 0..n {
thread::sleep(Duration::from_millis(15));
if i == n / 3 {
thread::sleep(Duration::from_secs(2));
}
pb.inc(1);
let pb2 = pb2.clone();
threads.push(thread::spawn(move || {
pb2.inc(1);
}));
}
pb.set_style(default_style.clone());
pb.finish_with_message("all jobs started");
for thread in threads {
let _ = thread.join();
}
let _ = h3.join();
pb2.set_style(default_style.clone());
pb2.finish_with_message("all jobs done");
} |
Amazing, thank you for the quick check ! |
@djc here the git bisect result
|
(@chris-laplante if you're really bored, maybe have a look at this one?) |
I should™ be able to this weekend or over holiday break maybe. |
I built a program to download artifacts from devOps. It uses MultiProgress with tokio to download artifacts in parallels. The program changes the prgress bar style dynamically while the the artifacts are process like progress you would see when you pulled docker images.
I use a default style (
ProgressStyle::with_template("{prefix}: {msg}")
) when download is not started yet or completedand another when download is in progress (
ProgressStyle::with_template("{prefix}: Downloading [{wide_bar:.white/red}] {percent}% [{bytes}/{total_bytes}]")
).With version 0.17.8, when swaping the progress style, the line in the terminal are all cleaned from previous inforrmations. The bar progress and the percent/bytes downloaded is not visiable anymore. See the result while download is completed and the default progress is used:
With version 0.17.9, when swaping the progress from the download style to the default style, the bar, the percent and the bytes information or still shown in the console on all progress bar except the last one 🤔. See the result while download is completed and the default progress is use:
I found out that using
set_move_cursor(true)
with the MultiProgress causes this issue with version 0.17.9. Without this setting, progress bar flicker way more specially on Windows. But I guess it is better than seeing data from the bars previous style.The new version with
set_move_cursor(true)
seams to fix the flicker issue. I don't see any flickering at all. That whould be nice to have no flicker and the lines clreared like in the previous version. For the moment I will sitck with the previous version.Thanks!
The text was updated successfully, but these errors were encountered: