Skip to content
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

Refactored how firecore tools handles printing #69

Merged
merged 3 commits into from
Jan 6, 2025

Conversation

maoueh
Copy link
Contributor

@maoueh maoueh commented Dec 9, 2024

There is now a common flag for all tools subcommand output that can be one of: text, json, jsonl, protojson or protojsonl.

Commands that had flags defined have been removed, this should be backward compatible.

The text printer is now more clever and is able to print details about most blocks.

There is now a common flag for all `tools` subcommand `output` that can be one of: text, json, jsonl, protojson or protojsonl.

Commands that had flags defined have been removed, this should be backward compatible.

The text printer is now more clever and is able to print details about most blocks.
if err != nil {
fmt.Printf("❌ Unable to print block %s: %s\n", block.AsRef(), err)
continue
}
}

if printDetails == PrintFull {
printer, err := print2.GetOutputPrinter(globalToolsCheckCmd, chain.BlockFileDescriptor())
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I plan to remove all printing support from check.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

agreed.

Copy link
Contributor

@sduchesneau sduchesneau left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good job !
2 suggested small changes, but not required to go forward.

One of: text, json, jsonl, protojson, protojsonl
`))

flags.String("bytes-encoding", "hex", "Encoding for bytes fields when printing in 'text', 'json' or 'jsonl' --output, either 'hex', 'base58' or 'base64'")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

idea for this:
maybe LONG byte arrays should always be printed in hex, and this bytes-encoding flag should always be for byte arrays below 64 bytes or something...

One of the issue is that base58 is excruciatingly slow when dealing with long byte arrays

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems rather hard to understand if encoding switches based on length IMO. And since it's for printing, not sure it's a big thing with the performance, we are not in Solana ;)


if printer == "text" {
// Supports the `transactions` flag defined on `firecore tools print` sub-command,
// we should move it to a proper `text` sub-option like `output-text-details` or something
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

maybe just a different output mode:
short
full

or summary vs fulltext

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah let's discuss that part, I created a generic block printer using Golang protoreflect, we could maybe extend it!

// Encode encodes the given bytes using the specified encoding.
func Encode(bytesEncoding string, bytes []byte) string {
switch {
case strings.EqualFold(bytesEncoding, "base58"):
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

here we could switch based on the length, as mentionned earlier.. just an idea but I think it would make sense

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The byte encoding should have been an enum from the start, would make everything better. Let's refactor it later.

@@ -73,9 +73,7 @@ func NewToolsCompareBlocksCmd[B firecore.Block](chain *firecore.Chain[B]) *cobra

flags := cmd.PersistentFlags()
flags.Bool("diff", false, "When activated, difference is displayed for each block with a difference")
flags.String("bytes-encoding", "hex", "Encoding for bytes fields, either 'hex' or 'base58'")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here you replaced with the global bytes-encoding that supports more values (like base64), but the implementation in tools_compare_blocks.go does NOT support anything else than hex or base58, watch out there needs to be a few changes later in this file, in func Compare(...)

@maoueh maoueh merged commit bf0df17 into develop Jan 6, 2025
2 checks passed
@maoueh maoueh deleted the feature/tools-output-refactor branch January 6, 2025 16:21
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants