Commit e9800b1c authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

winegstreamer: Move GST_BUFFER_OFFSET_NONE handling to the Unix library.

parent 09d573ce
...@@ -145,6 +145,7 @@ struct wg_parser ...@@ -145,6 +145,7 @@ struct wg_parser
GstPad *my_src, *their_sink; GstPad *my_src, *their_sink;
guint64 file_size, start_offset, next_offset, stop_offset; guint64 file_size, start_offset, next_offset, stop_offset;
guint64 next_pull_offset;
pthread_t push_thread; pthread_t push_thread;
......
...@@ -66,8 +66,6 @@ struct parser ...@@ -66,8 +66,6 @@ struct parser
* separate lock. */ * separate lock. */
bool streaming, sink_connected; bool streaming, sink_connected;
uint64_t next_pull_offset;
HANDLE read_thread; HANDLE read_thread;
BOOL (*init_gst)(struct parser *filter); BOOL (*init_gst)(struct parser *filter);
...@@ -796,8 +794,6 @@ static GstFlowReturn read_buffer(struct parser *This, guint64 ofs, guint len, Gs ...@@ -796,8 +794,6 @@ static GstFlowReturn read_buffer(struct parser *This, guint64 ofs, guint len, Gs
TRACE("filter %p, offset %s, length %u, buffer %p.\n", This, wine_dbgstr_longlong(ofs), len, buffer); TRACE("filter %p, offset %s, length %u, buffer %p.\n", This, wine_dbgstr_longlong(ofs), len, buffer);
if (ofs == GST_BUFFER_OFFSET_NONE)
ofs = This->next_pull_offset;
if (ofs >= This->file_size) if (ofs >= This->file_size)
{ {
WARN("Reading past eof: %s, %u\n", wine_dbgstr_longlong(ofs), len); WARN("Reading past eof: %s, %u\n", wine_dbgstr_longlong(ofs), len);
...@@ -805,7 +801,6 @@ static GstFlowReturn read_buffer(struct parser *This, guint64 ofs, guint len, Gs ...@@ -805,7 +801,6 @@ static GstFlowReturn read_buffer(struct parser *This, guint64 ofs, guint len, Gs
} }
if (len + ofs > This->file_size) if (len + ofs > This->file_size)
len = This->file_size - ofs; len = This->file_size - ofs;
This->next_pull_offset = ofs + len;
gst_buffer_map(buffer, &info, GST_MAP_WRITE); gst_buffer_map(buffer, &info, GST_MAP_WRITE);
hr = IAsyncReader_SyncRead(This->reader, ofs, len, info.data); hr = IAsyncReader_SyncRead(This->reader, ofs, len, info.data);
...@@ -998,7 +993,6 @@ static HRESULT parser_sink_connect(struct strmbase_sink *iface, IPin *peer, cons ...@@ -998,7 +993,6 @@ static HRESULT parser_sink_connect(struct strmbase_sink *iface, IPin *peer, cons
filter->sink_connected = true; filter->sink_connected = true;
filter->read_thread = CreateThread(NULL, 0, read_thread, filter, 0, NULL); filter->read_thread = CreateThread(NULL, 0, read_thread, filter, 0, NULL);
filter->next_pull_offset = 0;
if (FAILED(hr = unix_funcs->wg_parser_connect(filter->wg_parser, filter->file_size))) if (FAILED(hr = unix_funcs->wg_parser_connect(filter->wg_parser, filter->file_size)))
goto err; goto err;
......
...@@ -989,6 +989,10 @@ static GstFlowReturn request_buffer_src(GstPad *pad, GstObject *parent, guint64 ...@@ -989,6 +989,10 @@ static GstFlowReturn request_buffer_src(GstPad *pad, GstObject *parent, guint64
GST_LOG("pad %p, offset %" G_GINT64_MODIFIER "u, length %u, buffer %p.", pad, offset, size, *buffer); GST_LOG("pad %p, offset %" G_GINT64_MODIFIER "u, length %u, buffer %p.", pad, offset, size, *buffer);
if (offset == GST_BUFFER_OFFSET_NONE)
offset = parser->next_pull_offset;
parser->next_pull_offset = offset + size;
if (!*buffer) if (!*buffer)
*buffer = new_buffer = gst_buffer_new_and_alloc(size); *buffer = new_buffer = gst_buffer_new_and_alloc(size);
...@@ -1325,6 +1329,7 @@ static HRESULT CDECL wg_parser_connect(struct wg_parser *parser, uint64_t file_s ...@@ -1325,6 +1329,7 @@ static HRESULT CDECL wg_parser_connect(struct wg_parser *parser, uint64_t file_s
gst_pad_set_element_private(parser->my_src, parser); gst_pad_set_element_private(parser->my_src, parser);
parser->start_offset = parser->next_offset = parser->stop_offset = 0; parser->start_offset = parser->next_offset = parser->stop_offset = 0;
parser->next_pull_offset = 0;
if (!parser->init_gst(parser)) if (!parser->init_gst(parser))
return E_FAIL; return E_FAIL;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment