### Problem description This PR addresses issue #2013 that described a cluttered Event Manager. This is a DX issue and should not impact the users whatsoever. ### Implementation description The changes revolve around three main points: 1. the Event Manager (`event_manager.hpp`) was split into four categories: GUI, Interaction, Lifecycle, and Provider, and two types: Events, and Requests. This results in the following files: - `events_gui.hpp` - `events_interaction.hpp` - `events_lifecycle.hpp` - `events_provider.hpp` - `requests_gui.hpp` - `requests_interaction.hpp` - `requests_lifecycle.hpp` - `requests_provider.hpp` 2. Every event and request now has its own piece of documentation, with a `@brief`, accompanied by a longer comment if needed, and gets its `@param`s described. 3. The old `event_manager.hpp` import was removed and replaced by the correct imports wherever needed, as to reduce spread of those files only to where they are truly useful. ### Additional things The commits have been split into (chrono-)logical steps: - `feat`: split the Event Manager, and replace the imports - `refactor`, `chore`: make various small changes to match the required structure - `docs`: add documentation for events and requests Hopefully, this will help to review the PR. *Note: Beware of very long rebuild times in between the commits, use them sparingly! The Actions will ensure this PR builds anyways* Closes #2013 --------- Signed-off-by: BioTheWolff <47079795+BioTheWolff@users.noreply.github.com> Co-authored-by: Nik <werwolv98@gmail.com>
109 lines
3.8 KiB
C++
109 lines
3.8 KiB
C++
#include <content/providers/memory_file_provider.hpp>
|
|
#include <hex/api/shortcut_manager.hpp>
|
|
#include <hex/api/tutorial_manager.hpp>
|
|
#include <hex/ui/view.hpp>
|
|
#include <hex/api/events/requests_interaction.hpp>
|
|
#include <hex/api/events/events_gui.hpp>
|
|
|
|
namespace hex::plugin::builtin {
|
|
|
|
void registerIntroductionTutorial() {
|
|
using enum TutorialManager::Position;
|
|
auto &tutorial = TutorialManager::createTutorial("hex.builtin.tutorial.introduction", "hex.builtin.tutorial.introduction.description");
|
|
|
|
{
|
|
tutorial.addStep()
|
|
.setMessage(
|
|
"hex.builtin.tutorial.introduction.step1.title",
|
|
"hex.builtin.tutorial.introduction.step1.description",
|
|
Bottom | Right
|
|
)
|
|
.allowSkip();
|
|
}
|
|
|
|
{
|
|
auto &step = tutorial.addStep();
|
|
static EventManager::EventList::iterator eventHandle;
|
|
|
|
step.setMessage(
|
|
"hex.builtin.tutorial.introduction.step2.title",
|
|
"hex.builtin.tutorial.introduction.step2.description",
|
|
Bottom | Right
|
|
)
|
|
.addHighlight("hex.builtin.tutorial.introduction.step2.highlight",
|
|
{
|
|
"Welcome Screen/Start##SubWindow_69AA6996",
|
|
Lang("hex.builtin.welcome.start.create_file")
|
|
})
|
|
.onAppear([&step] {
|
|
eventHandle = EventProviderOpened::subscribe([&step](prv::Provider *provider) {
|
|
if (dynamic_cast<MemoryFileProvider*>(provider))
|
|
step.complete();
|
|
});
|
|
})
|
|
.onComplete([] {
|
|
EventProviderOpened::unsubscribe(eventHandle);
|
|
});
|
|
}
|
|
|
|
{
|
|
tutorial.addStep()
|
|
.addHighlight("hex.builtin.tutorial.introduction.step3.highlight", {
|
|
View::toWindowName("hex.builtin.view.hex_editor.name")
|
|
})
|
|
.allowSkip();
|
|
}
|
|
|
|
{
|
|
tutorial.addStep()
|
|
.addHighlight("hex.builtin.tutorial.introduction.step4.highlight", {
|
|
View::toWindowName("hex.builtin.view.data_inspector.name")
|
|
})
|
|
.onAppear([]{
|
|
ImHexApi::HexEditor::setSelection(Region { 0, 1 });
|
|
})
|
|
.allowSkip();
|
|
}
|
|
|
|
{
|
|
tutorial.addStep()
|
|
.addHighlight("hex.builtin.tutorial.introduction.step5.highlight.pattern_editor", {
|
|
View::toWindowName("hex.builtin.view.pattern_editor.name")
|
|
})
|
|
.addHighlight("hex.builtin.tutorial.introduction.step5.highlight.pattern_data", {
|
|
View::toWindowName("hex.builtin.view.pattern_data.name")
|
|
})
|
|
.onAppear([] {
|
|
RequestSetPatternLanguageCode::post("\n\n\n\n\n\nstruct Test {\n u8 value;\n};\n\nTest test @ 0x00;");
|
|
RequestRunPatternCode::post();
|
|
})
|
|
.allowSkip();
|
|
}
|
|
|
|
{
|
|
auto &step = tutorial.addStep();
|
|
|
|
step.addHighlight("hex.builtin.tutorial.introduction.step6.highlight", {
|
|
"##MainMenuBar",
|
|
"##menubar",
|
|
Lang("hex.builtin.menu.help")
|
|
})
|
|
.addHighlight({
|
|
"##Menu_00",
|
|
Lang("hex.builtin.view.tutorials.name")
|
|
})
|
|
.onAppear([&step] {
|
|
EventViewOpened::subscribe([&step](const View *view){
|
|
if (view->getUnlocalizedName() == UnlocalizedString("hex.builtin.view.tutorials.name"))
|
|
step.complete();
|
|
});
|
|
})
|
|
.onComplete([&step]{
|
|
EventViewOpened::unsubscribe(&step);
|
|
})
|
|
.allowSkip();
|
|
}
|
|
}
|
|
|
|
}
|