Make OSG plugin checker barely functional

* Work out what module filenames should be in CMake, and give those to C++
* Compare just the module filenames instead of the full strings
* Deal with OSG trying to support both UTF-8 and system-eight-bit-code-page file paths on Windows.
* Add a comment complaining about the constexpr situation.
* Use a stub implementation when using static OSG - apparently we don't actually support mixing and matching static and dynamic OSG plugins even though OSG itself does.
fix-osga-rotate-wildly
AnyOldName3 12 months ago
parent c2d1a4c861
commit ef65f0c70d

@ -41,6 +41,9 @@ endif (GIT_CHECKOUT)
list (APPEND COMPONENT_FILES "${OpenMW_BINARY_DIR}/${VERSION_CPP_FILE}")
# OSG plugin checker
list(TRANSFORM USED_OSG_PLUGINS PREPEND "${CMAKE_SHARED_MODULE_PREFIX}" OUTPUT_VARIABLE USED_OSG_PLUGIN_FILENAMES)
list(TRANSFORM USED_OSG_PLUGIN_FILENAMES APPEND "${CMAKE_SHARED_MODULE_SUFFIX}")
set(OSG_PLUGIN_CHECKER_CPP_FILE "components/misc/osgpluginchecker.cpp")
configure_file("${OpenMW_SOURCE_DIR}/${OSG_PLUGIN_CHECKER_CPP_FILE}.in" "${OpenMW_BINARY_DIR}/${OSG_PLUGIN_CHECKER_CPP_FILE}")
list(APPEND COMPONENT_FILES "${OpenMW_BINARY_DIR}/${OSG_PLUGIN_CHECKER_CPP_FILE}")

@ -1,27 +1,42 @@
#include "components/misc/osgpluginchecker.hpp"
#include <components/debug/debuglog.hpp>
#include <components/misc/strings/conversion.hpp>
#include <osg/Config>
#include <osgDB/PluginQuery>
#include <algorithm>
#include <filesystem>
#include <string_view>
namespace Misc
{
#ifdef OSG_LIBRARY_STATIC
bool checkRequiredOSGPluginsArePresent()
{
// assume they were linked in at build time and CMake would have failed if they were missing
return true;
}
#else
namespace
{
std::string_view USED_OSG_PLUGINS = "${USED_OSG_PLUGINS}";
std::string_view USED_OSG_PLUGIN_FILENAMES = "${USED_OSG_PLUGIN_FILENAMES}";
constexpr std::vector<std::string_view> getRequiredOSGPlugins()
constexpr auto getRequiredOSGPlugins()
{
// TODO: this is only constexpr due to an MSVC extension, so doesn't work on GCC and Clang
// I tried replacing it with std::views::split_range, but we support compilers without that bit of C++20, and it wasn't obvious how to use the result as a string_view without C++23
std::vector<std::string_view> requiredOSGPlugins;
auto currentStart = USED_OSG_PLUGINS.begin();
while (currentStart != USED_OSG_PLUGINS.end())
auto currentStart = USED_OSG_PLUGIN_FILENAMES.begin();
while (currentStart != USED_OSG_PLUGIN_FILENAMES.end())
{
auto currentEnd = std::find(currentStart, USED_OSG_PLUGINS.end(), ';');
auto currentEnd = std::find(currentStart, USED_OSG_PLUGIN_FILENAMES.end(), ';');
requiredOSGPlugins.emplace_back(currentStart, currentEnd);
if (currentEnd == USED_OSG_PLUGINS.end())
if (currentEnd == USED_OSG_PLUGIN_FILENAMES.end())
break;
currentStart = currentEnd + 1;
}
@ -36,7 +51,14 @@ namespace Misc
bool haveAllPlugins = true;
for (std::string_view plugin : requiredOSGPlugins)
{
if (std::find(availableOSGPlugins.begin(), availableOSGPlugins.end(), plugin) == availableOSGPlugins.end())
if (std::find_if(availableOSGPlugins.begin(), availableOSGPlugins.end(), [&](std::string availablePlugin) {
#ifdef OSG_USE_UTF8_FILENAME
std::filesystem::path pluginPath {stringToU8String(availablePlugin)};
#else
std::filesystem::path pluginPath {availablePlugin};
#endif
return pluginPath.filename() == plugin;
}) == availableOSGPlugins.end())
{
Log(Debug::Error) << "Missing OSG plugin: " << plugin;
haveAllPlugins = false;
@ -44,4 +66,6 @@ namespace Misc
}
return haveAllPlugins;
}
#endif
}

Loading…
Cancel
Save