<html><head></head><body>Hi,<br>
<br>
block_t is *originally* the *merger* of the data/PES packet type (what you call frame) and the generic raw binary data buffer type. Contrary to allegations, this was not done by me. It even predates my involvement with VLC at all. Thus the same type is used for multiple different things.<br>
<br>
At the time the only extras from the second to the first were two times (DTS, PTS) and two flags, so I *guess* it was not considered a concern.<br>
<br>
But adding a whole new associative array is *way* beyond the scope of a data buffer, especially when it is only for some corner cases. See also The Blob / The God object.<br>
<br>
Not only that but block_t is not designed to cope with non-immediate writable metadata fields. That causes leaks abd possibly heap corruption.<br>
<br>
And even when all the boilerplate is added to fix those leaks (it's not so easy anymore). Then there is still the problem that you cannot "generically" pass side data through the block_t users. Things like block chain, timeshift, packetizers will need to handle it explicitly (it's even harder than fixing the leaks).<br>
<br>
I find it rather ironic that, after complaining so much about non-immediate field mishandling in es_format_t, the same class of hurdles is proposed for block_t. And it's much worse here, seen as there are many more block-based helpers than format-based.<br><br><div class="gmail_quote">Le 27 juin 2018 00:32:57 GMT+03:00, Denis Charmet <typx@dinauz.org> a écrit :<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
<pre class="k9mail">Hi,<br><br>On 2018-06-25 12:14, Jean-Baptiste Kempf wrote:<br><blockquote class="gmail_quote" style="margin: 0pt 0pt 1ex 0.8ex; border-left: 1px solid #729fcf; padding-left: 1ex;"> On Tue, 19 Jun 2018, at 19:22, Rémi Denis-Courmont wrote:<br><blockquote class="gmail_quote" style="margin: 0pt 0pt 1ex 0.8ex; border-left: 1px solid #ad7fa8; padding-left: 1ex;"> This is out of place. Block_t is a generic data structure, not some <br> demux/<br> codec internal.<br></blockquote> [...]<br> If we want to have a block as a generic input data structure, we can<br> have a different structure, but that is not what we have currently.<br></blockquote><br>I feel like the debate is slowly drifting from its point... May I ask <br>what is so fondamentaly wrong to add something that look to me like <br>generic side data to a block?<br><br> From my own perspective, and yes I have a demux bias, the block_t has <br>always been misnamed block and should be considered a frame more than a <br>generic block. If I take lavfc example AVFrames have side data. I mean <br>it's still the easiest way for everyone to handle it.<br><br>Sure we could have an ANCILLARY_ES or whatever and synchronize it with <br>the other ES using pts but we'd need to know how to properly route it in <br>the core to its rightful owner. It can be easily ignored by "simple" <br>modules.<br><br>We could rename block_t to frame_t (and I would love it) but then <br>should we keep block_t? If so what happens to all the block code? Do we <br>duplicate it?<br><br>Right now François' solution doesn't seem too bad for me. I might be <br>missing some part of the picture but if you could list all the problems <br>of which you can think then I'm sure we can all come up with a good <br>solution that would be satisfying for everybody.<br><br>Regards,</pre></blockquote></div><br>
-- <br>
Envoyé de mon appareil Android avec Courriel K-9 Mail. Veuillez excuser ma brièveté.</body></html>