1
0
mirror of synced 2025-01-07 20:21:37 +01:00
ImHex/main/source/main.cpp

152 lines
4.5 KiB
C++
Raw Normal View History

#include <hex.hpp>
2021-08-29 22:15:18 +02:00
#include <hex/helpers/logger.hpp>
#include "window.hpp"
#include "crash_handlers.hpp"
#include "messaging.hpp"
#include "init/splash_window.hpp"
#include "init/tasks.hpp"
2023-05-14 21:50:58 +02:00
#include <hex/api/task.hpp>
#include <hex/api/project_file_manager.hpp>
#include <hex/api/plugin_manager.hpp>
2023-07-22 21:30:22 +02:00
#include <hex/helpers/fs.hpp>
#include "hex/subcommands/subcommands.hpp"
#include <wolv/io/fs.hpp>
#include <wolv/utils/guards.hpp>
using namespace hex;
2023-07-22 21:30:22 +02:00
namespace {
2023-07-22 21:30:22 +02:00
/**
* @brief Handles commands passed to ImHex via the command line
* @param argc Argument count
* @param argv Argument values
*/
void handleCommandLineInterface(int argc, char **argv) {
// Skip the first argument (the executable path) and convert the rest to a vector of strings
std::vector<std::string> args(argv + 1, argv + argc);
2023-07-22 21:30:22 +02:00
// Load all plugins but don't initialize them
for (const auto &dir : fs::getDefaultPaths(fs::ImHexPath::Plugins)) {
PluginManager::load(dir);
}
2023-07-22 21:30:22 +02:00
// Setup messaging system to allow sending commands to the main ImHex instance
hex::messaging::setupMessaging();
2023-07-22 21:30:22 +02:00
// Process the arguments
hex::subcommands::processArguments(args);
2023-07-22 21:30:22 +02:00
// Unload plugins again
PluginManager::unload();
}
2023-07-22 21:30:22 +02:00
/**
* @brief Checks if the portable version of ImHex is installed
* @note The portable version is detected by the presence of a file named "PORTABLE" in the same directory as the executable
* @return True if ImHex is running in portable mode, false otherwise
*/
bool isPortableVersion() {
if (const auto executablePath = wolv::io::fs::getExecutablePath(); executablePath.has_value()) {
const auto flagFile = executablePath->parent_path() / "PORTABLE";
if (wolv::io::fs::exists(flagFile) && wolv::io::fs::isRegularFile(flagFile))
2023-07-22 21:30:22 +02:00
return true;
}
2023-07-22 21:30:22 +02:00
return false;
}
2023-07-22 21:30:22 +02:00
/**
* @brief Displays ImHex's splash screen and runs all initialization tasks. The splash screen will be displayed until all tasks have finished.
*/
void initializeImHex() {
init::WindowSplash splashWindow;
2023-07-22 21:30:22 +02:00
log::info("Using '{}' GPU", ImHexApi::System::getGPUVendor());
// Add initialization tasks to run
TaskManager::init();
for (const auto &[name, task, async] : init::getInitTasks())
splashWindow.addStartupTask(name, task, async);
2023-07-22 21:30:22 +02:00
// Draw the splash window while tasks are running
if (!splashWindow.loop())
ImHexApi::System::getInitArguments().insert({ "tasks-failed", {} });
}
2023-07-22 21:30:22 +02:00
/**
* @brief Deinitializes ImHex by running all exit tasks and terminating all asynchronous tasks
*/
void deinitializeImHex() {
// Run exit tasks
for (const auto &[name, task, async] : init::getExitTasks())
task();
// Terminate all asynchronous tasks
TaskManager::exit();
}
/**
* @brief Handles a file open request by opening the file specified by OS-specific means
*/
void handleFileOpenRequest() {
if (auto path = hex::getInitialFilePath(); path.has_value()) {
EventManager::post<RequestOpenFile>(path.value());
}
2023-07-22 21:30:22 +02:00
}
2023-07-22 21:30:22 +02:00
}
2023-07-22 21:30:22 +02:00
/**
* @brief Main entry point of ImHex
* @param argc Argument count
* @param argv Argument values
* @return Exit code
*/
int main(int argc, char **argv) {
Window::initNative();
hex::crash::setupCrashHandlers();
2023-07-21 11:53:37 +02:00
2023-07-22 21:30:22 +02:00
if (argc > 1) {
handleCommandLineInterface(argc, argv);
}
2023-07-22 21:30:22 +02:00
log::info("Welcome to ImHex {}!", ImHexApi::System::getImHexVersion());
log::info("Compiled using commit {}@{}", ImHexApi::System::getCommitBranch(), ImHexApi::System::getCommitHash());
log::info("Running on {} {} ({})", ImHexApi::System::getOSName(), ImHexApi::System::getOSVersion(), ImHexApi::System::getArchitecture());
ImHexApi::System::impl::setPortableVersion(isPortableVersion());
2023-07-22 21:30:22 +02:00
bool shouldRestart = false;
do {
// Register an event handler that will make ImHex restart when requested
shouldRestart = false;
EventManager::subscribe<RequestRestartImHex>([&] {
shouldRestart = true;
});
2023-07-22 21:30:22 +02:00
initializeImHex();
handleFileOpenRequest();
2023-07-22 21:30:22 +02:00
// Clean up everything after the main window is closed
ON_SCOPE_EXIT {
deinitializeImHex();
};
// Main window
Window window;
window.loop();
} while (shouldRestart);
2021-01-12 16:50:15 +01:00
return EXIT_SUCCESS;
}