-
Notifications
You must be signed in to change notification settings - Fork 842
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
Systematic cleanup and colorization of stack output #2650
Comments
Assigning myself, but if someone is interested in learning this pretty print stuff and doing the work, feel free to take it over / pitch in! Are you interested @luigy ? I know you were interested in improving some aspects of stack's CLI display. |
I think I'd be interested enough to take on at least some of this. Is there a branch or any context I should look at, or just start in |
@kadoban Awesome! I think the best place to start would be uses of May also be worth considering switching over to https://www.stackage.org/package/prettyprinter-ansi-terminal / https://www.stackage.org/package/prettyprinter . Though, from a cursory glance at the code, it isn't quite as efficient in its use of control codes (mine avoids doing a state reset for every color change). Thinking that might be a better choice for simplicity / more reliable if output gets interspersed. I suppose it'd be better to switch to the prettyprinter package before adding a lot more use of prettyprinting, though the API should be quite similar since they are both in the wadler-leijen family. |
Cool, thanks for the info. I'll get looking in to things and start a WIP PR or a branch or something tonight. I'll probably try a place or two and then look at which prettyprinter to use once I have a basic idea of what I'm doing and how the interface seems like it's working and etc. |
What would be your preference for small, obvious changes to switch to pretty* functions? Should I do small PRs, one big PR, or just push to master? Anything interesting I'll make a PR for, and the terminal detection of course, but I suspect it'll just be tedious doing PRs for every little change (or one big, never-ending PR could also be kind of bad for merge-conflict reasons). But I'm find doing whatever really. |
I think my preference is medium sized PRs, but it's pretty much up to you, one big PR is alright as well. One way to do it might be to do a big PR, but push to it as you go. Thanks for working on this, good stuff! |
Sure, that works. Maybe I'll do something like module-by-module for a while and see how that goes. I have a decent start at
Anytime, thanks for reviewing and advice! |
|
Now that #4205 is done, we can close this too. |
This issue is tracking doing a systematic sweep of the stack code and converting it to use the pretty-printer where appropriate.
I added some pretty print machinery to stack. In particular, we now have the following TH functions:
$prettyDebug
is just like$logDebug
, except it expects anAnsiDoc
value.$prettyInfo
is just like$logInfo
, except it expects anAnsiDoc
value.$prettyWarn
is similar to$logWarn
, but it prepends a newline and "Warning: " colored yellow.$prettyError
is similar to$logError
, but it prepends a newline and "Error: " colored red.One thing to note is that I would prefer colorization to be consistent across all of the stack messages. So, for the most part, colors should not be directly used in the stack source. Instead, add type and context specific utilities to `Stack.PrettyPrint. For example, I have these ones for plan construction:
Related issues that this work would ideally cover:
stack sdist
andstack upload
Improve error/warning reporting instack sdist
andstack upload
#2507The text was updated successfully, but these errors were encountered: