diff --git a/common/mptString.h b/common/mptString.h index 16fc64c49bb..99b5f7e6c6b 100644 --- a/common/mptString.h +++ b/common/mptString.h @@ -429,7 +429,11 @@ inline mpt::ustring ToUnicode(uint16 codepage, Tencoding &&fallback, Tsrc &&str) std::optional charset = mpt::optional_encoding_from_codepage(codepage); if(charset.has_value()) { +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + result = mpt::transcode(*charset, std::forward(str)); +#else result = mpt::transcode(charset.value(), std::forward(str)); +#endif } else if(mpt::has_codepage(static_cast(codepage))) { result = mpt::transcode(static_cast(codepage), std::forward(str)); @@ -440,7 +444,11 @@ inline mpt::ustring ToUnicode(uint16 codepage, Tencoding &&fallback, Tsrc &&str) return result; #else // !MPT_OS_WINDOWS std::optional charset = mpt::optional_encoding_from_codepage(codepage); +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) return charset.has_value() ? mpt::transcode(charset.value(), std::forward(str)) : mpt::transcode(std::forward(fallback), std::forward(str)); +#else + return charset.has_value() ? mpt::transcode(*charset, std::forward(str)) : mpt::transcode(std::forward(fallback), std::forward(str)); +#endif #endif // MPT_OS_WINDOWS } diff --git a/soundlib/Dlsbank.cpp b/soundlib/Dlsbank.cpp index b0b08cf1293..f865cfdda29 100644 --- a/soundlib/Dlsbank.cpp +++ b/soundlib/Dlsbank.cpp @@ -1415,7 +1415,13 @@ bool CDLSBank::Open(FileReader file) uint32 nInsDef; if(file.GetOptionalFileName()) + { +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + m_szFileName = *(file.GetOptionalFileName()); +#else m_szFileName = file.GetOptionalFileName().value(); +#endif + } file.Rewind(); if(!file.CanRead(256)) diff --git a/soundlib/Load_mod.cpp b/soundlib/Load_mod.cpp index a53aa79d49e..e5c562f7b09 100644 --- a/soundlib/Load_mod.cpp +++ b/soundlib/Load_mod.cpp @@ -1286,7 +1286,11 @@ bool CSoundFile::ReadMOD(FileReader &file, ModLoadingFlags loadFlags) FileReader amData; if(file.GetOptionalFileName()) { +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + mpt::PathString filename = *(file.GetOptionalFileName()); +#else mpt::PathString filename = file.GetOptionalFileName().value(); +#endif // Find instrument definition file const mpt::PathString exts[] = {P_(".nt"), P_(".NT"), P_(".as"), P_(".AS")}; for(const auto &ext : exts) diff --git a/src/mpt/base/detect_quirks.hpp b/src/mpt/base/detect_quirks.hpp index 24fd41398b6..8c3191de4f4 100644 --- a/src/mpt/base/detect_quirks.hpp +++ b/src/mpt/base/detect_quirks.hpp @@ -322,4 +322,20 @@ +#if MPT_OS_MACOSX_OR_IOS +#if defined(TARGET_OS_OSX) +#if TARGET_OS_OSX +#if !defined(MAC_OS_X_VERSION_10_14) +#define MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE +#else +#if (MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_14) +#define MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE +#endif +#endif +#endif +#endif +#endif + + + #endif // MPT_BASE_DETECT_QUIRKS_HPP diff --git a/src/mpt/io_file_adapter/fileadapter.hpp b/src/mpt/io_file_adapter/fileadapter.hpp index 4ec1c4a9302..7ecfac16aed 100644 --- a/src/mpt/io_file_adapter/fileadapter.hpp +++ b/src/mpt/io_file_adapter/fileadapter.hpp @@ -135,7 +135,11 @@ class FileAdapter { m_Filename = tempName; m_IsTempFile = true; } else { +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + m_Filename = *(file.GetOptionalFileName()); +#else m_Filename = file.GetOptionalFileName().value(); +#endif } } catch (const std::runtime_error &) { m_Filename = mpt::os_path{}; diff --git a/src/mpt/library/library.hpp b/src/mpt/library/library.hpp index 11a94093df5..fcc9c0f8329 100644 --- a/src/mpt/library/library.hpp +++ b/src/mpt/library/library.hpp @@ -187,7 +187,11 @@ class library { if (!optionalfilename) { return std::nullopt; } +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + mpt::native_path & filename = *optionalfilename; +#else mpt::native_path & filename = optionalfilename.value(); +#endif if (filename.empty()) { return std::nullopt; } @@ -351,7 +355,11 @@ class library { if (!optionalfilename) { return std::nullopt; } +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + mpt::native_path & filename = *optionalfilename; +#else mpt::native_path & filename = optionalfilename.value(); +#endif if (filename.empty()) { return std::nullopt; } @@ -405,7 +413,11 @@ class library { if (!optionalfilename) { return std::nullopt; } +#if defined(MPT_LIBCXX_QUIRK_NO_OPTIONAL_VALUE) + mpt::native_path & filename = *optionalfilename; +#else mpt::native_path & filename = optionalfilename.value(); +#endif if (filename.empty()) { return std::nullopt; }