[openal] Preparing for OpenAL Soft 1.23.1
Chris Robinson
chris.kcat at gmail.com
Tue Apr 4 22:16:53 EDT 2023
Hi,
OpenAL Soft 1.23.1 is soon to be released. Presuming no significant
issue pops up, I'd expect it to be early next week. This release fixes a
few compilation issues, and has a few new extensions like:
AL_SOFT_UHJ_ex
<https://openal-soft.org/openal-extensions/SOFT_UHJ_ex.txt>, adding a
few more sample types to UHJ formats (muLaw, aLaw, IMA4/MS ADPCM).
AL_SOFT_buffer_length_query
<https://openal-soft.org/openal-extensions/SOFT_buffer_length_query.txt>,
simplifying and closing some gaps in buffer attribute queries.
AL_SOFT_source_start_delay
<https://openal-soft.org/openal-extensions/SOFT_source_start_delay.txt>,
adding methods to play a source at a particular time point or with a
delay, instead of "immediately".
AL_EXT_STATIC_BUFFER
<https://github.com/Raulshc/OpenAL-EXT-Repository/blob/master/AL%20Extensions/AL_EXT_STATIC_BUFFER.txt>,
which isn't really new, but allows apps to specify custom storage for
buffer samples.
There are also improvements to EAX compatibility, improved quality of
the reverb modulator, and support for native ADPCM buffers (without
decompression on load).
If there are any problems you're aware of, please report it. If any
features sound of interest, give them a try.
I do have one question to pose to get feedback on. This issue
<https://github.com/kcat/openal-soft/issues/831> was fixed by adding a
game_compat config option to restore an old extension (at the cost of
disabling a newer one). I am curious if it might be a good idea to
detect that game and enable the compatibility option by default when
detected. This would be the first instance of OpenAL Soft doing some
game-specific behavior, though since it requires the user to manually
replace the game's existing shared library with an alternate one, maybe
it's not a problem to have the user manually set the game_compat option
too. Thoughts?
One further note that I forgot to mention with 1.23.0, that the 1.23
series will likely be the last requiring C++14. With 1.24, the plan is
to move on to C++17, which probably means GCC 8 or newer (as opposed to
GCC 5 currently), and whatever version of Clang and MSVC that has proper
C++17 support.
If there's any questions, comments, or concerns, don't hesitate to bring
them up.
More information about the openal
mailing list