WiiUPluginLoaderBackend/source/plugin/PluginDataFactory.cpp

74 lines
2.6 KiB
C++
Raw Normal View History

/****************************************************************************
* Copyright (C) 2018 Maschell
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
****************************************************************************/
2024-11-27 20:44:36 +01:00
#include "PluginDataFactory.h"
2023-08-16 10:08:44 +02:00
#include "NotificationsUtils.h"
2024-12-29 17:43:28 +01:00
#include "PluginData.h"
#include "PluginLoadWrapper.h"
#include "fs/FSUtils.h"
#include "utils/StringTools.h"
#include "utils/logger.h"
2024-11-27 20:44:36 +01:00
2022-02-04 16:25:44 +01:00
#include <memory>
2024-11-27 20:44:36 +01:00
#include <set>
2024-12-29 17:43:28 +01:00
2024-11-27 20:44:36 +01:00
#include <sys/dirent.h>
std::vector<PluginLoadWrapper> PluginDataFactory::loadDir(const std::string_view path, const std::set<std::string> &inactivePluginsFilenames) {
std::vector<PluginLoadWrapper> result;
for (const auto &full_file_path : getPluginFilePaths(path)) {
std::string fileName = StringTools::FullpathToFilename(full_file_path.c_str());
DEBUG_FUNCTION_LINE("Loading plugin: %s", full_file_path.c_str());
2024-11-27 20:44:36 +01:00
if (auto pluginData = load(full_file_path)) {
bool shouldBeLoadedAndLinked = true;
if (inactivePluginsFilenames.contains(fileName)) {
shouldBeLoadedAndLinked = false;
}
result.emplace_back(std::move(pluginData), shouldBeLoadedAndLinked);
} else {
2023-08-16 10:08:44 +02:00
auto errMsg = string_format("Failed to load plugin: %s", full_file_path.c_str());
DEBUG_FUNCTION_LINE_ERR("%s", errMsg.c_str());
DisplayErrorNotificationMessage(errMsg, 15.0f);
}
}
return result;
}
2024-11-27 20:44:36 +01:00
std::unique_ptr<PluginData> PluginDataFactory::load(const std::string_view path) {
std::vector<uint8_t> buffer;
2024-11-27 20:44:36 +01:00
if (FSUtils::LoadFileToMem(path, buffer) < 0) {
DEBUG_FUNCTION_LINE_ERR("Failed to load %s into memory", path.data());
return nullptr;
}
2021-02-19 19:41:04 +01:00
DEBUG_FUNCTION_LINE_VERBOSE("Loaded file!");
2024-11-27 20:44:36 +01:00
return load(std::move(buffer), path);
}
std::unique_ptr<PluginData> PluginDataFactory::load(std::vector<uint8_t> &&buffer, std::string_view source) {
2020-05-03 12:30:15 +02:00
if (buffer.empty()) {
return nullptr;
}
return make_unique_nothrow<PluginData>(std::move(buffer), source);
}