mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
lavf/tcp: add tcp_accept
Signed-off-by: Stephan Holljes <klaxa1337@googlemail.com>
This commit is contained in:
parent
63c07a956b
commit
21198155a7
@ -19,6 +19,7 @@
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
#include "avformat.h"
|
||||
#include "libavutil/avassert.h"
|
||||
#include "libavutil/parseutils.h"
|
||||
#include "libavutil/opt.h"
|
||||
#include "libavutil/time.h"
|
||||
@ -163,6 +164,22 @@ static int tcp_open(URLContext *h, const char *uri, int flags)
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tcp_accept(URLContext *s, URLContext **c)
|
||||
{
|
||||
TCPContext *sc = s->priv_data;
|
||||
TCPContext *cc;
|
||||
int ret;
|
||||
av_assert0(sc->listen);
|
||||
if ((ret = ffurl_alloc(c, s->filename, s->flags, &s->interrupt_callback)) < 0)
|
||||
return ret;
|
||||
cc = (*c)->priv_data;
|
||||
ret = ff_accept(sc->fd, sc->listen_timeout, s);
|
||||
if (ret < 0)
|
||||
return ff_neterrno();
|
||||
cc->fd = ret;
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int tcp_read(URLContext *h, uint8_t *buf, int size)
|
||||
{
|
||||
TCPContext *s = h->priv_data;
|
||||
@ -223,6 +240,7 @@ static int tcp_get_file_handle(URLContext *h)
|
||||
URLProtocol ff_tcp_protocol = {
|
||||
.name = "tcp",
|
||||
.url_open = tcp_open,
|
||||
.url_accept = tcp_accept,
|
||||
.url_read = tcp_read,
|
||||
.url_write = tcp_write,
|
||||
.url_close = tcp_close,
|
||||
|
Loading…
Reference in New Issue
Block a user