On 5/6/22 12:20, RĂ©mi Bernon (@rbernon) wrote:
Sure, then the question becomes, can we move the entire logic to the client side? That would require a separate call to retrieve the type of the current sample, given the below (or alternatively some extra queuing on the client side, but that seems more complex than necessary), but structurally it feels a lot less awkward.
It would only makes things more complicated, with an additional entry point which you would have to call on every sample to get their format, back to the client to compare them, and then only eventually read it.
I don't see how this is awkward at all, the client optionally provides the format it believes the stream has and that it expects to be for the output samples, the transform returns either with a read success and unmodified format, or a format change result and the update format.
It's overall a dozen lines of code. Having an additional entry point will be much larger change, with wrappers, etc.
I've already tried to explain why this feels awkward to me. I'd rather have two function calls that make sense structurally, than try to shove everything into one call, regardless of how many lines it takes.
(For that matter, we don't even need two function calls. With the current state of things, all we need to do is pass a maximum size of zero to the read_data function. It's not clear how that'll work with a zero-copy infrastructure, but we could easily just add a "peek" flag.)
If at any point we need all this to be thread safe, because right now it's definitely not and I hope we won't need it, the separate entry point would make everything much more difficult whereas with this design you could just lock the read_data and either return a format change or read success atomically.
I don't see how thread safety makes this any more complex?