example_advanced_plugins.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. #include "app_api.h"
  2. #include "plugin_interface.h"
  3. #include "app_api_interface.h"
  4. #include <flipper_application/flipper_application.h>
  5. #include <flipper_application/plugins/plugin_manager.h>
  6. #include <flipper_application/plugins/composite_resolver.h>
  7. #include <loader/firmware_api/firmware_api.h>
  8. #define TAG "example_advanced_plugins"
  9. int32_t example_advanced_plugins_app(void* p) {
  10. UNUSED(p);
  11. FURI_LOG_I(TAG, "Starting");
  12. CompositeApiResolver* resolver = composite_api_resolver_alloc();
  13. composite_api_resolver_add(resolver, firmware_api_interface);
  14. composite_api_resolver_add(resolver, application_api_interface);
  15. PluginManager* manager = plugin_manager_alloc(
  16. PLUGIN_APP_ID, PLUGIN_API_VERSION, composite_api_resolver_get(resolver));
  17. do {
  18. if(plugin_manager_load_all(manager, APP_DATA_PATH("plugins")) != PluginManagerErrorNone) {
  19. FURI_LOG_E(TAG, "Failed to load all libs");
  20. break;
  21. }
  22. uint32_t plugin_count = plugin_manager_get_count(manager);
  23. FURI_LOG_I(TAG, "Loaded libs: %lu", plugin_count);
  24. for(uint32_t i = 0; i < plugin_count; i++) {
  25. const AdvancedPlugin* plugin = plugin_manager_get_ep(manager, i);
  26. FURI_LOG_I(TAG, "plugin name: %s. Calling methods", plugin->name);
  27. plugin->method1(228);
  28. plugin->method2();
  29. FURI_LOG_I(TAG, "Accumulator: %lu", app_api_accumulator_get());
  30. }
  31. } while(0);
  32. plugin_manager_free(manager);
  33. composite_api_resolver_free(resolver);
  34. FURI_LOG_I(TAG, "Goodbye!");
  35. return 0;
  36. }