Практикантроп
4780 / 2680 / 517
Регистрация: 23.09.2011
Сообщений: 5,734
|
|
1 | |
Можно ли исключить названия экспортируемых функций?15.10.2013, 17:52. Показов 1461. Ответов 14
Метки нет Все метки)
(
Возник вопрос, ответа на который я до сих пор не могу найти... . Когда создается портабельное приложение, в его таблице экспорта (при просмотре соотв. программами) содержится список из нескольких функций: как правило это _Form1, finalize, initialize и еще парочка других. Использованные компоненты из базовых наборов никак не представлены. Но стоит только применить сторонний компонент, и все его функции тут же высвечиваются, хотя применялась аналогичная базовым библиотека bpl. Видимо, этим занимается компоновщик, но как его отучить...?... . Этот перечень кроме того, что занимает объем, иногда бывает нежелателен. Можно, конечно, применять хакерские примочки, но может кто знает, каким образом избежать появления этого списка в "экспорте"?
0
|
|
15.10.2013, 17:52 | |
Ответы с готовыми решениями:
14
Имена функций, экспортируемых из dll Получить адрес экспортируемых функций Скрыть имена экспортируемых функций из DLL Подключение сторонней .dll и вызов экспортируемых функций |
1405 / 568 / 127
Регистрация: 31.10.2011
Сообщений: 1,956
|
|
18.10.2013, 20:36 | 2 |
интересная тема, я подписался, но смотрю, никто ответа не дает...
я тоже не знаю. Кстати, может быть связано с этой темой: если поставить кнопку от альфаскин TsButton, то сразу в .cpp появляется #pragma link "sButton", а стандартный TButton подобных действий не вызывает. Сразу вопрос назревает - как сделать, чтоб не нужно было #pragma link ?
0
|
Практикантроп
4780 / 2680 / 517
Регистрация: 23.09.2011
Сообщений: 5,734
|
|
18.10.2013, 21:24 [ТС] | 3 |
- ну, тут по крайней мере варианты просматриваются: подключать hpp и соотв. lib. А вот какие опции добавить в устанавливаемые компоненты, чтоб их функции не экспортировались... - не понятно.
0
|
Практикантроп
4780 / 2680 / 517
Регистрация: 23.09.2011
Сообщений: 5,734
|
|
27.03.2015, 12:01 [ТС] | 4 |
В продолжение темы...
0
|
случайный прохожий
2383 / 1600 / 550
Регистрация: 20.07.2013
Сообщений: 4,490
|
|
27.03.2015, 12:13 | 5 |
Видимо, в pas-файл. А потом компилировать.
Опции в фигурных скобках вроде как (по крайней мере) "дельфийско-паскалевская" примочка. Насчет С(++) данными не владею.
1
|
Практикантроп
4780 / 2680 / 517
Регистрация: 23.09.2011
Сообщений: 5,734
|
|
27.03.2015, 12:54 [ТС] | 6 |
Да, я тоже так думаю. Сейчас попробую перекомпилировать пакет с исправленным компонентом; посмотрю, что даст... .
Добавлено через 35 минут Действительно! В паскалевый исходник компонента вставляю {$ObjExportAll Off} (для определенности: после строчки implementation) - и в экспорте чисто. Вопрос, считаю, снят.
0
|
0 / 0 / 0
Регистрация: 26.03.2016
Сообщений: 1
|
|
26.03.2016, 21:28 | 7 |
Хотелось бы продолжить эту тему с Вашего позволения
![]() А как быть если исходников компонента нет? Я использую сторонний компонент, лицензию на который я покупал без исходников (просьба не предлагать купить исходники - это довольно дорого ![]() Компонент достаточно объемный, и портянка в экспорте из пары-тройки сотен функций несколько раздражает ![]()
0
|
1405 / 568 / 127
Регистрация: 31.10.2011
Сообщений: 1,956
|
|
25.04.2016, 01:44 | 8 |
Продолжу тему ...
Вот попробовал убрать с *.cpp #pragma package(smart_init) и пропали finalize и initialize . Но остались _Form1 и еще кое-какая ерунда. У меня возникло 2 вопроса: - как повлияло на программу то, что удалено smart_init (визуально не заметно, все работает на ура) - как допилить все это, чтоб не приходилось использовать директивы делфи ![]()
0
|
1405 / 568 / 127
Регистрация: 31.10.2011
Сообщений: 1,956
|
|
11.09.2016, 03:44 | 9 |
nick42, что вообще в экспорте пусто?
Мне максимум, что получилось добиться, так это убрать finalize , initialize и формы.Осталось только ___CPPdebugHook , __GetExceptDLLinfo и TMethodImplementationIntercept .Просто я убрал все #pragma package(smart_init) и PACKAGE с форм.Добавлено через 13 минут Просто зачем в ехе экспорт? Поправьте меня, если что не так. На тесовом проекте все работает как и раньше, глюков не наблюдается. Как такие изменения могут повлиять на программу?
0
|
Avazart
|
11.09.2016, 12:17
#10
|
0
|
1405 / 568 / 127
Регистрация: 31.10.2011
Сообщений: 1,956
|
|
11.09.2016, 17:35 | 11 |
0
|
1405 / 568 / 127
Регистрация: 31.10.2011
Сообщений: 1,956
|
|
11.09.2016, 21:26 | 13 |
Зачем?
И кстати, в настройках проекта насчет debug все отключил, что в с++ компиляторе, что в делфи. Все сторонние компоненты, установлены мной, скомпилированые в релизе. Если делать проект в делфи, там такого нет, а тут танцы с бубном (((
0
|
1405 / 568 / 127
Регистрация: 31.10.2011
Сообщений: 1,956
|
|
13.09.2016, 02:26 | 14 |
на соседних форумах читал, что надо что-то в исходниках поправить
или скомпилировать как есть, но потом воспользоваться PE корректором. Подскажите, как правильно воспользоваться {$ObjExportAll Off} , чтоб экспорте чисто было.Просто *.pas файл я подключал, и ставил после импл эту директиву.
0
|
Практикантроп
4780 / 2680 / 517
Регистрация: 23.09.2011
Сообщений: 5,734
|
|
13.09.2016, 10:59 [ТС] | 15 |
Ну и достаточно, мне кажется. Я таким образом скорректировал свои "любимые" компоненты, - после их применения в проектах (в релиз-версиях разумеется) в таблице экспорта присутствуют лишь пресловутые debughook, getexcept... .
Меня еще интересует такой вопрос: нужны ли программе все эти Strings с номерами от 4096 до 4081 и далее вниз и куча битмапов BB. Я думаю - это рудименты прошлого и для современных операционок вещи бесполезные. Тем не менее компилятор (или линкер) всю эту кучу прилепляет к каждому проекту, и я не знаю, как его переубедить.
0
|
13.09.2016, 10:59 | |
Помогаю со студенческими работами здесь
15
Исключить дублирование функций Названия функций из пакета Объединение названия функций
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |