Импорт функций
Узнайте, как импортировать функции из других плагинов, написанных на разных языках, и использовать их в своем собственном.
Чтобы использовать функции из другого плагина в вашем плагине на C++, вам необходимо сгенерировать специфичные для языка заголовочные файлы. Эти заголовочные файлы предоставляют необходимые обертки для вызова функций, экспортируемых другими плагинами. Это руководство объясняет, как генерировать эти заголовочные файлы и как использовать их в вашем плагине на C++.
Генерация заголовочных файлов
Plugify предоставляет скрипт Python (generator.py
) для автоматической генерации заголовочных файлов для импорта функций из других плагинов. Эти заголовочные файлы включают функции-обертки, которые обрабатывают вызовы функций и передачу параметров.
Шаги по генерации заголовочных файлов
Найдите скрипт-генератор:
- Скрипт
generator.py
находится в папкеgenerator
языкового модуля C++.
Запустите скрипт-генератор:
- Откройте терминал или командную строку и перейдите в папку, содержащую
generator.py
. - Запустите скрипт со следующей командой:
path_to_plugin.pplugin
: Путь к файлу манифеста плагина (.pplugin
), из которого вы хотите импортировать функции.output_folder
: Каталог, в который будет сохранен сгенерированный заголовочный файл.
Пример:
Включите сгенерированный заголовочный файл:
- Скрипт сгенерирует заголовочный файл (например,
plugin_from_another_language.hpp
) в указанной папке вывода. - Включите этот заголовочный файл в исходные файлы вашего плагина на C++, чтобы использовать экспортированные функции.
Использование сгенерированных функций-оберток
Сгенерированный заголовочный файл содержит функции-обертки, которые позволяют вам вызывать функции из другого плагина. Эти обертки обрабатывают поиск адреса функции и передачу параметров.
Пример сгенерированного заголовочного файла
Вот пример сгенерированного заголовочного файла для плагина с именем plugin_from_another_language
:
Как это работает
- Функция-обертка (
ParamCallback
) получает адрес экспортированной функции с помощьюplg::GetMethodPtr
илиplg::GetMethodPtr2
. - Адрес функции сохраняется в статической переменной (
__func
), чтобы избежать повторных поисков. - Функция-обертка напрямую передает параметры в экспортированную функцию, используя соглашение о вызовах C++.
Пример: Использование сгенерированного заголовочного файла
Вот как вы можете использовать сгенерированный заголовочный файл в вашем плагине на C++:
Когда необходима генерация заголовочных файлов?
Генерация заголовочных файлов необходима при импорте функций из плагинов, написанных на статически типизированных языках, таких как C++ или C#. Без этих заголовочных файлов компилятор не сможет ссылаться на экспортированные функции. Для динамически типизированных языков, таких как Python, генерация заголовочных файлов не требуется, поскольку привязка методов происходит во время выполнения.
Рекомендации
- Используйте скрипт-генератор: Всегда используйте скрипт
generator.py
для генерации заголовочных файлов для импортируемых функций. - Включайте сгенерированные заголовочные файлы: Включайте сгенерированные заголовочные файлы в исходные файлы вашего плагина для доступа к экспортированным функциям.
- Тщательно тестируйте: Тестируйте импортированные функции, чтобы убедиться, что они работают как ожидалось.
- Документируйте зависимости: Четко документируйте плагины и функции, от которых зависит ваш плагин.
Заключение
Импорт функций из другого плагина в C++ прост, если вы используете скрипт generator.py
для генерации необходимых заголовочных файлов. Эти заголовочные файлы предоставляют функции-обертки, которые обрабатывают поиск адреса функции и передачу параметров, что упрощает интеграцию функциональности из других плагинов. Следуя шагам и лучшим практикам, изложенным в этом руководстве, вы можете создавать надежные и совместимые плагины в экосистеме Plugify.