diff --git a/changelog.md b/changelog.md index cdfcf327a..e3b653dc6 100644 --- a/changelog.md +++ b/changelog.md @@ -135,6 +135,7 @@ For a closer look at breaking changes and how to migrate from SFML 2, check out - Fixed `sf::SoundStream::play` bug (#2037) - Fixed poor `sf::SoundStream::setPlayingOffset` precision (#3101) +- Fixed a bug when reading Ogg files on big endian systems (#3340) ### Network diff --git a/src/SFML/Audio/CMakeLists.txt b/src/SFML/Audio/CMakeLists.txt index d911b8475..e42ba77f6 100644 --- a/src/SFML/Audio/CMakeLists.txt +++ b/src/SFML/Audio/CMakeLists.txt @@ -169,6 +169,9 @@ target_compile_definitions(sfml-audio PRIVATE MA_NO_MP3 MA_NO_FLAC MA_NO_ENCODIN # use standard fixed-width integer types target_compile_definitions(sfml-audio PRIVATE MA_USE_STDINT) +# detect the endianness as required by Ogg +target_compile_definitions(sfml-audio PRIVATE SFML_IS_BIG_ENDIAN=$) + # setup dependencies target_link_libraries(sfml-audio PUBLIC SFML::System diff --git a/src/SFML/Audio/SoundFileReaderOgg.cpp b/src/SFML/Audio/SoundFileReaderOgg.cpp index 9ea735657..9bfa9e319 100644 --- a/src/SFML/Audio/SoundFileReaderOgg.cpp +++ b/src/SFML/Audio/SoundFileReaderOgg.cpp @@ -196,8 +196,8 @@ std::uint64_t SoundFileReaderOgg::read(std::int16_t* samples, std::uint64_t maxC std::uint64_t count = 0; while (count < maxCount) { - const int bytesToRead = static_cast(maxCount - count) * static_cast(sizeof(std::int16_t)); - const long bytesRead = ov_read(&m_vorbis, reinterpret_cast(samples), bytesToRead, 0, 2, 1, nullptr); + const int bytesToRead = static_cast(maxCount - count) * static_cast(sizeof(std::int16_t)); + const long bytesRead = ov_read(&m_vorbis, reinterpret_cast(samples), bytesToRead, SFML_IS_BIG_ENDIAN, 2, 1, nullptr); if (bytesRead > 0) { const long samplesRead = bytesRead / static_cast(sizeof(std::int16_t));