是否有 Linux/Unix 工具可用于将 C 文件的十六进制转储数组(即 xxd -i
的输出)转换为相应的源代码?
最佳答案
源文件xyz.c
的xxd -i xyz.c
的输出如下所示:
unsigned char xyz_c[] = {
0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74,
0x64, 0x69, 0x6f, 0x2e, 0x68, 0x3e, 0x0a, 0x23, 0x69, 0x6e, 0x63, 0x6c,
0x75, 0x64, 0x65, 0x20, 0x3c, 0x73, 0x74, 0x64, 0x6c, 0x69, 0x62, 0x2e,
0x68, 0x3e, 0x0a, 0x23, 0x69, 0x6e, 0x63, 0x6c, 0x75, 0x64, 0x65, 0x20,
0x3c, 0x73, 0x74, 0x72, 0x69, 0x6e, 0x67, 0x2e, 0x68, 0x3e, 0x0a, 0x0a,
…
0x65, 0x5f, 0x6c, 0x69, 0x73, 0x74, 0x28, 0x73, 0x74, 0x61, 0x72, 0x74,
0x29, 0x3b, 0x0a, 0x20, 0x20, 0x20, 0x20, 0x7d, 0x0a, 0x0a, 0x20, 0x20,
0x20, 0x20, 0x72, 0x65, 0x74, 0x75, 0x72, 0x6e, 0x20, 0x30, 0x3b, 0x0a,
0x7d, 0x0a
};
unsigned int xyz_c_len = 4442;
假设它存储在文件 xyz.xxd
中。
在很多方面,重新生成原始代码的最简单方法是:
#include <stdio.h>
#include "xyz.xxd"
int main(void)
{
for (unsigned int i = 0; i < xyz_c_len; i++)
putchar(xyz_c[i]);
return 0;
}
通过更多的小心和一些宏,您可以将其制作为该工作的通用大纲程序 - 您需要提供文件名以及要使用的两个 C 变量名称。
如果您不能(或不想)使用 C 编译器来完成这项工作,那么使用 Python 或 Perl 编写工具是一个简单的练习。例如,一个不一定最小的 Perl 脚本是:
#!/usr/bin/env perl -na
use strict;
use warnings;
# xxd -i drops the final comma - aargh (why?)!
foreach my $word (@F)
{
next unless $word =~ m/^0[Xx][[:xdigit:]]{2},?$/;
$word =~ s/,//;
printf "%c", hex($word);
}
它使用“自动拆分”选项 (-a
) 和“自动读取但不打印”选项 (-n
),然后处理任何单词在看起来像十六进制字符的输入中,例如 0x0a(可选地后跟一个逗号,因为 xxd -i 在某种程度上不必要地省略了最终字节值后面的逗号)并将其转换为相应的字节。它是 Perl,TMTOWTDI — 有不止一种方法可以做到这一点。
关于c++ - 将 "xxd -i"编码的C源代码转换为C源代码的脚本/工具?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35974932/