winegstreamer: Read into an existing buffer if requested.
oggdemux needs this. Signed-off-by: Zebediah Figura <zfigura@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
c9f0d862b5
commit
d61504f16b
|
@ -896,9 +896,8 @@ static GstFlowReturn request_buffer_src(GstPad *pad, GstObject *parent, guint64
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
GstMapInfo info;
|
GstMapInfo info;
|
||||||
|
|
||||||
TRACE("%p %s %i %p\n", pad, wine_dbgstr_longlong(ofs), len, buf);
|
TRACE("pad %p, offset %s, length %u, buffer %p.\n", pad, wine_dbgstr_longlong(ofs), len, *buf);
|
||||||
|
|
||||||
*buf = NULL;
|
|
||||||
if (ofs == GST_BUFFER_OFFSET_NONE)
|
if (ofs == GST_BUFFER_OFFSET_NONE)
|
||||||
ofs = This->nextpullofs;
|
ofs = This->nextpullofs;
|
||||||
if (ofs >= This->filesize) {
|
if (ofs >= This->filesize) {
|
||||||
|
@ -909,7 +908,8 @@ static GstFlowReturn request_buffer_src(GstPad *pad, GstObject *parent, guint64
|
||||||
len = This->filesize - ofs;
|
len = This->filesize - ofs;
|
||||||
This->nextpullofs = ofs + len;
|
This->nextpullofs = ofs + len;
|
||||||
|
|
||||||
*buf = gst_buffer_new_and_alloc(len);
|
if (!*buf)
|
||||||
|
*buf = gst_buffer_new_and_alloc(len);
|
||||||
gst_buffer_map(*buf, &info, GST_MAP_WRITE);
|
gst_buffer_map(*buf, &info, GST_MAP_WRITE);
|
||||||
hr = IAsyncReader_SyncRead(This->reader, ofs, len, info.data);
|
hr = IAsyncReader_SyncRead(This->reader, ofs, len, info.data);
|
||||||
gst_buffer_unmap(*buf, &info);
|
gst_buffer_unmap(*buf, &info);
|
||||||
|
|
Loading…
Reference in New Issue