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

Add a flag to aggressively interpret hex -> binary #39

Open
GrayHatter opened this issue Jun 23, 2024 · 1 comment
Open

Add a flag to aggressively interpret hex -> binary #39

GrayHatter opened this issue Jun 23, 2024 · 1 comment
Labels
feature New feature or request under consideration This is still under consideration or discussion
Milestone

Comments

@GrayHatter
Copy link

Quite often I find myself reading a binary file into vim, editing it through xxd and trying to return that new hex text file back to binary. When I append into the middle of some data, it often breaks the counting, which breaks xxd. e.g.

starting with

00000000: 5468 6973 2069 7320 6120 6269 6e61 7279  This is a binary
00000010: 2066 696c 6520 7768 6572 6520 2d3e 3c2d   file where -><-
00000020: 2073 686f 756c 6420 636f 6e74 6169 6e20   should contain
00000030: 7468 6520 776f 7264 2068 6576 6920 0a    the word hevi .

editing to

00000000: 5468 6973 2069 7320 6120 6269 6e61 7279  This is a binary
00000010: 2066 696c 6520 7768 6572 6520 2d3e 68 6576 69 3c2d   file where -><-
00000020: 2073 686f 756c 6420 636f 6e74 6169 6e20   should contain
00000030: 7468 6520 776f 7264 2068 6576 6920 0a    the word hevi .

causes xdd to error instead of parsing the hex. I'd like to have a flag that would allow hevi to parse it, and generate the binary.

Bonus points if it could detect mistakes and output the formatting back to vim with the error inline where detected. Or it could return an error, and the result suggestion and require the user to approve/fix it.

@Arnau478
Copy link
Owner

Editing/creating binaries was never the goal of hevi. That said, I think this use case doesn't interfere with the dump functionality. Thus, I am willing to consider implementing this. How would it work exactly? Would it have to parse the output format? What about flags like --offset/--no-offset? Those would make parsing difficult, although I guess we could use the | characters. So, a line would either be [offset] | <data> | [ascii] or <data> (for raw mode).

Also, from the example, I assume it should handle non-normalized lines (>16 bytes), am I right?

@Arnau478 Arnau478 added feature New feature or request under consideration This is still under consideration or discussion labels Jun 23, 2024
@Arnau478 Arnau478 added this to the 1.0.0 milestone Jun 23, 2024
@Arnau478 Arnau478 modified the milestones: 1.0.0, 2.0.0, 1.1.0 Jul 2, 2024
@Arnau478 Arnau478 modified the milestones: 1.1.0, 2.0.0 Oct 16, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature New feature or request under consideration This is still under consideration or discussion
Projects
None yet
Development

No branches or pull requests

2 participants