-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Previously, there were two mostly-identical value printers -- one in `libexpr/eval.cc` (which didn't force values) and one in `libcmd/repl.cc` (which did force values and also printed ANSI color codes). This PR unifies both of these printers into `print.cc` and provides a `PrintOptions` struct for controlling the output, which allows for toggling whether values are forced, whether repeated values are tracked, and whether ANSI color codes are displayed. Additionally, `PrintOptions` allows tuning the maximum number of attributes, list items, and bytes in a string that will be displayed; this makes it ideal for contexts where printing too much output (e.g. all of Nixpkgs) is distracting. (As requested by @roberth in NixOS#9554 (comment)) Please read the tests for example output. Future work: - It would be nice to provide this function as a builtin, perhaps `builtins.toStringDebug` -- a printing function that never fails would be useful when debugging Nix code. - It would be nice to support customizing `PrintOptions` members on the command line, e.g. `--option to-string-max-attrs 1000`.
- Loading branch information
Showing
12 changed files
with
839 additions
and
308 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
#pragma once | ||
/** | ||
* @file | ||
* @brief Options for printing Nix values. | ||
*/ | ||
|
||
namespace nix { | ||
|
||
/** | ||
* Options for printing Nix values. | ||
*/ | ||
struct PrintOptions | ||
{ | ||
/** | ||
* If true, output ANSI color sequences. | ||
*/ | ||
bool ansiColors = false; | ||
/** | ||
* If true, force values. | ||
*/ | ||
bool force = false; | ||
/** | ||
* If true, track which values have been printed and skip them on | ||
* subsequent encounters. Useful for self-referential values. | ||
*/ | ||
bool trackRepeated = true; | ||
/** | ||
* Maximum depth to evaluate to. | ||
*/ | ||
unsigned int maxDepth = std::numeric_limits<unsigned int>::max(); | ||
/** | ||
* Maximum number of attributes in an attribute set to print. | ||
*/ | ||
unsigned int maxAttrs = std::numeric_limits<unsigned int>::max(); | ||
/** | ||
* Maximum number of list items to print. | ||
*/ | ||
unsigned int maxListItems = std::numeric_limits<unsigned int>::max(); | ||
/** | ||
* Maximum string length to print. | ||
*/ | ||
unsigned int maxStringLength = std::numeric_limits<unsigned int>::max(); | ||
}; | ||
|
||
} |
Oops, something went wrong.