-
-
Notifications
You must be signed in to change notification settings - Fork 28
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
Spinner breaks on multiline message #43
Comments
Hi Michał 👋 Thanks for the issue report, and of course, big thank you for the sponsorship! ❤️ Supporting multiline content sounds good but there is a bit 'trickiness' involved in how the multi spinner works. I should have some time to investigate next week unless you have time to submit PR in the meantime? I wonder if your use case wouldn't be better served by adding new api for logging as suggested in this issue. Any thoughts? |
I tried looking into this and implementing this myself but I didn't manage to get far which is why I ultimately reported this as an issue. I'm not sure if I'll find time soon to look into this again but if I do I'll definitely send a PR :) And yeah, I totally think the API for logging would solve my issue as well. |
There is a new require "tty-spinner"
require "tty-command"
spinner = TTY::Spinner.new("[:spinner] Running :cmd command", format: :bouncing_ball)
cmd = TTY::Command.new(printer: :null)
spinner.auto_spin
spinner.update(cmd: "yarn")
cmd.run("yarn") do |out, err|
buffer = []
buffer << out if out
buffer << err if err
spinner.log(buffer.join)
sleep(0.5)
end
spinner.stop("Done") |
@piotrmurach for starters - apologies for such a long delay in responding, I had so many other things that I had to implement into our CLI tool that I didn't get around to testing this. Anyway - this sort of works, as in, it does output things properly for simple commands but it really hates cursor movement shell codes. If I just output the Here's a simple repro repository: https://github.com/d4rky-pl/tty-spinner-log-test My use-case here is a tool that wraps docker and docker-compose and sets up our local development environment and I wanted to output whatever the tools setting up things are doing. Unfortunately my knowledge of shell magic is painfully lacking so I'm afraid I have no idea if this an be resolved anyhow or if I should just strip the codes and deduplicate lines manually (or just drop the idea altogether and make --verbose` flag disable the spinner). |
@d4rky-pl This is well overdue! In future please ping me if you don't hear from me. I looked into your Now, the spinner write("#{cleared_text}#{"\n" unless cleared_text.end_with?("\n")}", false) In particular, the bit that adds a new line when it's missing. So when I replaced the above with: write(cleared_text, false) and removed the buffering from your example, cmd.run("docker-compose up") do |out, err|
spinner.log(out) if out
spinner.log(err) if err
end the output from the Why the So given the above how should the
|
Probably most of users will appreciate having a new line added automatically. I think best option is an option that would disable new line: cmd.run("docker-compose up") do |out, err|
spinner.log(out, trailing_newline: false) if out
spinner.log(err, trailing_newline: false) if err
end |
Describe the problem
Right now tty-spinner does not support multiline messages so this code will result in the spinner continuously outputting to the terminal:
It would be great if the spinner was smart enough to check the number of the lines of the message and moved the cursor accordingly when cleaning.
An example use case for this would be to keep the output of the command from tty-command on the screen without making it into an output salad:
The text was updated successfully, but these errors were encountered: