C++ 脚本/工具,用于转换由“C”编码的C源代码;xxd-i“;到C源代码?

C++ 脚本/工具,用于转换由“C”编码的C源代码;xxd-i“;到C源代码?,c++,c,linux,unix,xxd,C++,C,Linux,Unix,Xxd,是否有Linux/Unix工具可用于将C文件的十六进制转储数组(即xxd-i的输出)转换为相应的源代码?该工具是免费的,在Linux上工作,在SourceForge上可用。源文件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, 0x0

是否有Linux/Unix工具可用于将C文件的十六进制转储数组(即
xxd-i
的输出)转换为相应的源代码?

该工具是免费的,在Linux上工作,在SourceForge上可用。

源文件
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;
}

它使用“自动拆分”选项(
-a
)和“自动读取但不打印”选项(
-n
),然后处理输入中看起来像十六进制字符的任何字,例如0x0a(可选后跟逗号,因为
xxd-i
在最后一个字节值之后有点不必要地省略逗号)并将其转换为相应的字节。它是Perl,TMTOWTDI——有不止一种方法可以做到这一点。

你是说反汇编程序吗?或者是逆向工程?我想你需要一个反编译器。我想这个问题会让你觉得,如果你的意思是回到二进制,而不是src代码。就像乔纳森回答的那样。在这种情况下,xxd似乎缺少一种无法反转的格式。
#!/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);
}