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