#hex-dump #binary #input #format #variety #default #table

无 std bin+lib xd

以多种格式转储二进制输入的工具

5 个版本

0.0.4 2020年11月29日
0.0.3 2020年11月23日
0.0.2 2020年11月16日
0.0.1 2020年11月16日
0.0.0 2020年11月15日

#2517命令行实用工具

ISC 许可证

245KB
636

xd

crates.io page Bitbucket Pipelines status

xd(1) 是一个以多种格式转储二进制输入的工具。

> rustup default 1.46.0
> cargo install xd
> xd --example
00 01 02 03  04 05 06 07  08 09 0A 0B  0C 0D 0E 0F  ␀☺☻♥♦♣♠•◘○◙♂♀♪♫☼  0
10 11 12 13  14 15 16 17  18 19 1A 1B  1C 1D 1E 1F  ►◄↕‼¶§▬↨↑↓→←∟↔▲▼  10
20 21 22 23  24 25 26 27  28 29 2A 2B  2C 2D 2E 2F   !"#$%&'()*+,-./  20
30 31 32 33  34 35 36 37  38 39 3A 3B  3C 3D 3E 3F  0123456789:;<=>?  30
40 41 42 43  44 45 46 47  48 49 4A 4B  4C 4D 4E 4F  @ABCDEFGHIJKLMNO  40
50 51 52 53  54 55 56 57  58 59 5A 5B  5C 5D 5E 5F  PQRSTUVWXYZ[\]^_  50
60 61 62 63  64 65 66 67  68 69 6A 6B  6C 6D 6E 6F  `abcdefghijklmno  60
70 71 72 73  74 75 76 77  78 79 7A 7B  7C 7D 7E 7F  pqrstuvwxyz{|}~⌂  70
80 81 82 83  84 85 86 87  88 89 8A 8B  8C 8D 8E 8F  ÇüéâäàåçêëèïîìÄÅ  80
90 91 92 93  94 95 96 97  98 99 9A 9B  9C 9D 9E 9F  ÉæÆôöòûùÿÖÜ¢£¥₧ƒ  90
A0 A1 A2 A3  A4 A5 A6 A7  A8 A9 AA AB  AC AD AE AF  áíóúñѪº¿⌐¬½¼¡«»  A0
B0 B1 B2 B3  B4 B5 B6 B7  B8 B9 BA BB  BC BD BE BF  ░▒▓│┤╡╢╖╕╣║╗╝╜╛┐  B0
C0 C1 C2 C3  C4 C5 C6 C7  C8 C9 CA CB  CC CD CE CF  └┴┬├─┼╞╟╚╔╩╦╠═╬╧  C0
D0 D1 D2 D3  D4 D5 D6 D7  D8 D9 DA DB  DC DD DE DF  ╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀  D0
E0 E1 E2 E3  E4 E5 E6 E7  E8 E9 EA EB  EC ED EE EF  αßΓπΣσµτΦΘΩδ∞φε∩  E0
F0 F1 F2 F3  F4 F5 F6 F7  F8 F9 FA FB  FC FD FE FF  ≡±≥≤⌠⌡÷≈°∙·√ⁿ²■   F0

默认格式描述每行最多 16 个八进制数,同时以十六进制和文本形式显示,文本列使用以下字符集之一

  • --table default — 调整后的代码页 437,类似于旧 IBM PC。此编码为每个八进制数提供唯一的符号,使其可逆,并且几乎所有符号在视觉上都是独特的,这在可视化超出可打印 ASCII 的二进制数据中的模式时很有帮助。
  • --table classic — 可打印 ASCII 字节以确切的方式显示,其余部分以点显示,就像传统的十六进制转储工具一样。
  • --table reverse — 可打印 ASCII 字节加上 00h (␀) 至 1Fh (␟) 和 7Fh (␡) 的控制图像,然后是 80h 至 FFh 的反向视频相同符号。

screenshot for --table

功能

  • ☑ 可以作为库在 #[no_std] 中使用
  • ☑ 在 OpenBSD 上使用 pledge(2) + unveil(2)
  • ☑ 调整后的 437 + 经典 + 反向视频字符集
  • ☑ 固定格式 (16×{:02X} 16×{符号} {地址})
  • ☐ 自定义格式
  • ☐ 与 od(1) 兼容
  • ☐ 与 hexdump(1)/hd(1) 兼容
  • ☐ 与 xxd(1) 兼容

要求

  • Rust 1.46+(使用 1.46.0 进行测试)
  • 应适用于包括以下平台在内的任何平台
    • Linux
    • Windows 1511+
    • OpenBSD 6.4+

Windows 注意事项

xd(1) 当前需要 ENABLE_VIRTUAL_TERMINAL_PROCESSING,该功能于 Windows 构建号 10586 或附近推出。这包括 Windows 10(1511+)的大多数版本,或 Windows Server 2016(1607+)或更高版本的任何版本。

如果在输出达到控制台之前将其管道化或重定向,请尝试使用只包含ASCII的--table classic,或者将您的代码页设置为UTF-8。要在Windows 1809或更新的版本上启用UTF-8,请运行intl.cpl,点击管理,然后点击更改系统区域设置,接着勾选使用Unicode UTF-8以支持全球语言。如果您使用的是较旧版本的Windows,请尝试这些方法之一。请注意,启用UTF-8的所有方法都可能导致野外某些软件出现异常行为。

为了在conhost中获得最佳结果,不要使用位图字体。默认提供的其他字体效果相当不错,但控制图片(如␀)除外,因为conhost尚不支持字体回退。同样地,自定义字体可能会有所不同。

依赖项

~0.1–8.5MB
~64K SLoC