[openal] Ideas on an explicit context API
hypatia.sva at posteo.eu
hypatia.sva at posteo.eu
Mon Apr 24 07:56:08 EDT 2023
Hello,
is this kind of what you wanted?
https://github.com/hypatia-of-sva/alad/blob/main/openal-explicit-polyfill.h
It's currently no better in terms of performance, as its temporarily
swapping contexts, but I would be interested if that is kind of the
semantics you are interested in or if it's different.
I also added the possibility of having multiple listeners per context. I
don't know if thats truely necessary for anything, but since it's
trivial to add I thought it might as well be there to differentiate
which function
changes which state information.
Hypatia of Sva.
Am 24.04.2023 09:37 schrieb Chris Robinson:
> On 4/23/23 21:47, Ryan C. Gordon wrote:
>>
>>> that for every
>>>
>>> alFoo(...) / alFooEXT(...)
>>>
>>> function, there would be a matching
>>>
>>> alFooExplicit(ALCcontext*, ...) / alFooExplicitEXT(ALCcontext*, ...)
>>
>> I like this idea a lot. All the existing entry points just become
>> simple wrappers:
>>
>> void alFoo(ALint bar) {
>> alFooExplicit(alcGetCurrentContext(), bar);
>> }
>>
>> ...and the existing implementation moves to the Explicit version, and
>> then it's just a matter of cleaning out references to the current
>> context from them.
>
> More or less, yeah. Though depending on whether these new functions
> check the validity of the current context or not, and whether they're
> considered thread-safe with regard to destruction (i.e. if one thread
> destroys a context at the same time another thread tries to call
> something with it), that specific example could result in redundant
> validation checking. It may end up more like
>
> void _alFooImpl(ContextRef context, ALint bar);
>
> void alFoo(ALint bar) {
> _alFooImpl(GetCurrentContextRef(), bar);
> }
> void alFooExplicit(ALcontext *context, ALint bar) {
> _alFooImpl(ValidateContext(context), bar);
> }
>
> where GetCurrentContextRef and ValidateContext are internal functions
> that safely return a reference-counted context handle, ensuring it
> won't be deleted while in scope.
>
>> I don't love the word "Explicit" for this, but that's a minor gripe.
>> If I come up with a different word, I'll suggest it here for
>> discussion.
>
> I'm certainly open to alternative names, especially if they're
> shorter. I remember OpenGL having the GL_ARB_direct_state_access
> extension to avoid having to set an object as current, or "bind" it,
> to modify in a similar way. E.g.
>
> glBindBuffer(type, bufferid);
> glBufferData(type, ...); // modifies bufferid
>
> became
>
> glNamedBufferData(bufferid, ...);
>
> OpenAL already does this as standard for sources/buffers/etc, but
> maybe this could be "direct context access", using the Direct suffix
> as in alFooDirect(context, ...)?
>
>> The nasty part of this is going to be how to deal with extensions. Do
>> we say there's a finite list of known extensions right now, and we'll
>> list them all out as having Explicit equivalents if the AL supports
>> both Explicit contexts and that extension, but the app is on its own
>> if an extension isn't included and doesn't mention its interaction
>> with Explicit context support?
>
> Ideally it would include all current and future extensions that have
> non-Explicit AL functions. An implementation that supports Explicit
> contexts shouldn't have an issue providing Explicit context functions
> for other extensions it supports without needing them to be...
> explicitly mentioned, since it's a generalized concept.
>
> Admittedly I don't know how to word it in a way that would be clear in
> that regard, but the usefulness would be limited if only some
> extensions are guaranteed to work. Maybe it won't be a problem to
> mention new functions only for existing extensions when supported
> alongside Explicit contexts like you suggest, then ensure future
> extensions specifically mention Explicit context functions as needed.
> _______________________________________________
> openal mailing list
> openal at openal.org
> http://openal.org/mailman/listinfo/openal
More information about the openal
mailing list