Могу ли я связать простой файл с моим исполняемым файлом? [Дубликат]

44

Некоторые фреймворки (Qt, Windows, Gtk...) предлагают функциональность для добавления ресурсов в ваши двоичные файлы. Интересно, можно ли достичь этого без рамки, поскольку все, что действительно необходимо, это

  • символ, содержащий адрес ресурса в двоичном (сегменте данных)
  • символ для представления длины ресурса
  • сам ресурс

Как это можно достичь с помощью gcc toolchain?

  • 7
    Ну, вы можете реализовать все эти вещи, и тогда у вас будет структура ресурсов.
  • 0
    @LightnessRacesinOrbit: действительно, но без графического интерфейса, сериализации, XML, ... которые мне сейчас не нужны :)
Показать ещё 4 комментария
Теги:
linker
gcc
embedded-resource

2 ответа

48
Лучший ответ

Вы можете сделать это:

objcopy --input binary \
        --output elf32-i386 \
        --binary-architecture i386 my_file.xml myfile.o

Это создает объектный файл, который вы можете связать с вашим исполняемым файлом. Этот файл будет содержать эти символы, которые вы должны будете объявить в своем коде на C быть в состоянии использовать их

00000550 D _binary_my_file_xml_end
00000550 A _binary_my_file_xml_size 
00000000 D _binary_my_file_xml_start
  • 0
    именно то, что мне было нужно. Вы случайно не знаете, существует ли objcopy в Windows?
  • 2
    @xtofl Он доступен в Windows, если вы используете, по крайней мере, mingw или cygwin, но преобразование файла в массив C было бы наиболее переносимым способом для всех цепочек инструментов.
30

В самом базовом, эквивалент представляет собой массив char, полный байтов.

В Linux вы можете использовать xxd -i <file> для "компиляции" файлов в массивы char, а затем привязать массивы к вашему двоичному файлу и использовать, тем не менее, составные байты.

Вот пример из моего собственного кода makefile, который создает "файл ресурсов" под названием templates.h, содержащий кучу массивов char, представляющих HTML-шаблоны:

templates.h:
    @echo "#ifndef REDACTED_TEMPLATES_H" > templates.h
    @echo "#define REDACTED_TEMPLATES_H" >> templates.h
    @echo "// Auto-generated file! Do not modify!" >> templates.h
    @echo "// NB: arrays are not null-terminated" >> templates.h
    @echo "// (anonymous namespace used to force internal linkage)" >> templates.h
    @echo "namespace {" >> templates.h
    @echo "namespace templates {" >> templates.h
    @cd templates;\
    for i in * ;\
    do \
        echo "Compiling $$i...";\
        xxd -i $$i | sed -e 's/ =/ __attribute__((unused)) =/' >> ../templates.h;\
    done;\
    cd ..
    @echo "}" >> templates.h
    @echo "}" >> templates.h
    @echo "#endif" >> templates.h

(см. также: Насколько наилучшим образом я могу программно применить` __attribute__ ((не используется)) `к этим автоматически сгенерированным объектам?)

Результат выглядит примерно так:

#ifndef REDACTED_TEMPLATES_H
#define REDACTED_TEMPLATES_H
// Auto-generated file! Do not modify!
// NB: arrays are not null-terminated
// (anonymous namespace used to force internal linkage)
namespace {
namespace templates {
unsigned char alert_email_finished_events_html[] __attribute__((unused)) = {
  0x3c, 0x74, 0x61, 0x62, 0x6c, 0x65, 0x20, 0x63, 0x6c, 0x61, 0x73, 0x73,
  0x3d, 0x22, 0x6e, 0x6f, 0x64, 0x65, 0x2d, 0x69, 0x6e, 0x66, 0x6f, 0x2d,
[..]
  0x7d, 0x7d, 0x0d, 0x0a, 0x3c, 0x2f, 0x74, 0x61, 0x62, 0x6c, 0x65, 0x3e,
  0x0d, 0x0a
};
unsigned int alert_email_finished_events_html_len __attribute__((unused)) = 290;
unsigned char alert_email_finished_events_list_html[] __attribute__((unused)) = {
  0x3c, 0x74, 0x72, 0x20, 0x63, 0x6c, 0x61, 0x73, 0x73, 0x3d, 0x22, 0x73,
  0x65, 0x70, 0x61, 0x72, 0x61, 0x74, 0x65, 0x2d, 0x70, 0x72, 0x65, 0x76,
[..]
  0x73, 0x74, 0x7d, 0x7d, 0x0d, 0x0a
};
unsigned int alert_email_finished_events_list_html_len __attribute__((unused)) = 42;
}
}
#endif

Обратите внимание, что этот конкретный пример оптимален при использовании ресурса только в одном модуле перевода, но общий подход может быть адаптирован в соответствии с вашими потребностями.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню