2020-12-27 14:39:06 +00:00
|
|
|
#pragma once
|
|
|
|
|
2023-07-13 12:08:23 +00:00
|
|
|
#include <string>
|
|
|
|
|
2020-12-27 14:39:06 +00:00
|
|
|
#include <imgui.h>
|
2021-08-20 22:52:11 +00:00
|
|
|
#include <imgui_internal.h>
|
2020-12-27 14:39:06 +00:00
|
|
|
|
|
|
|
#include <hex.hpp>
|
2023-07-13 12:08:23 +00:00
|
|
|
#include <hex/api/plugin_manager.hpp>
|
|
|
|
|
|
|
|
#include <wolv/utils/string.hpp>
|
2020-12-27 14:39:06 +00:00
|
|
|
|
2023-04-18 08:06:47 +00:00
|
|
|
/**
|
|
|
|
* This macro is used to define all the required entry points for a plugin.
|
|
|
|
* Name, Author and Description will be displayed in the in the plugin list on the Welcome screen.
|
|
|
|
*/
|
2022-02-02 16:19:50 +00:00
|
|
|
#define IMHEX_PLUGIN_SETUP(name, author, description) IMHEX_PLUGIN_SETUP_IMPL(name, author, description)
|
2021-02-07 12:40:47 +00:00
|
|
|
|
2022-02-02 16:19:50 +00:00
|
|
|
#define IMHEX_PLUGIN_SETUP_IMPL(name, author, description) \
|
2022-01-24 19:53:17 +00:00
|
|
|
extern "C" [[gnu::visibility("default")]] const char *getPluginName() { return name; } \
|
|
|
|
extern "C" [[gnu::visibility("default")]] const char *getPluginAuthor() { return author; } \
|
|
|
|
extern "C" [[gnu::visibility("default")]] const char *getPluginDescription() { return description; } \
|
|
|
|
extern "C" [[gnu::visibility("default")]] const char *getCompatibleVersion() { return IMHEX_VERSION; } \
|
|
|
|
extern "C" [[gnu::visibility("default")]] void setImGuiContext(ImGuiContext *ctx) { \
|
|
|
|
ImGui::SetCurrentContext(ctx); \
|
|
|
|
GImGui = ctx; \
|
|
|
|
} \
|
2022-01-23 22:28:56 +00:00
|
|
|
extern "C" [[gnu::visibility("default")]] void initializePlugin()
|
2023-07-13 12:08:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This macro is used to define subcommands defined by the plugin
|
|
|
|
* A subcommand consists of a key, a description, and a callback
|
|
|
|
* The key is what the first argument to ImHex should be, prefixed by `--`
|
|
|
|
* For example, if the key if `help`, ImHex should be started with `--help` as its first argument to trigger the subcommand
|
|
|
|
* when the subcommand is triggerred, it's callback will be executed. The callback is executed BEFORE most of ImHex initialization
|
|
|
|
* so to do anything meaningful, you should subscribe to an event (like EventImHexStartupFinished) and run your code there.
|
|
|
|
*/
|
|
|
|
#define IMHEX_PLUGIN_SUBCOMMANDS() IMHEX_PLUGIN_SUBCOMMANDS_IMPL()
|
|
|
|
|
|
|
|
#define IMHEX_PLUGIN_SUBCOMMANDS_IMPL() \
|
|
|
|
extern std::vector<hex::SubCommand> g_subCommands; \
|
2023-07-21 12:12:08 +00:00
|
|
|
extern "C" [[gnu::visibility("default")]] void* getSubCommands() { \
|
|
|
|
return &g_subCommands; \
|
2023-07-13 12:08:23 +00:00
|
|
|
} \
|
|
|
|
std::vector<hex::SubCommand> g_subCommands
|