Mercurial > libavformat.hg
diff rtp_asf.c @ 4754:c78617194786 libavformat
Assign the x-pf-asf payload string to be decoded by rtp_asf.c, and add a
SDP line handler that parses the streamID in the SDP so that ASF stream
data can be matched to their respective streams in the RTSP demuxer. See
"[PATCH] RTSP-MS 12/15: ASF payload support" thread on mailinglist.
author | rbultje |
---|---|
date | Fri, 20 Mar 2009 01:11:08 +0000 |
parents | 575b867fe279 |
children | aa0edc246bca |
line wrap: on
line diff
--- a/rtp_asf.c Thu Mar 19 21:57:14 2009 +0000 +++ b/rtp_asf.c Fri Mar 20 01:11:08 2009 +0000 @@ -27,6 +27,7 @@ #include <libavutil/base64.h> #include <libavutil/avstring.h> +#include "rtp.h" #include "rtp_asf.h" #include "rtsp.h" #include "asf.h" @@ -50,3 +51,41 @@ rt->asf_ctx->pb = NULL; } } + +static int +asfrtp_parse_sdp_line (AVFormatContext *s, int stream_index, + PayloadContext *asf, const char *line) +{ + if (av_strstart(line, "stream:", &line)) { + RTSPState *rt = s->priv_data; + + s->streams[stream_index]->id = strtol(line, NULL, 10); + + if (rt->asf_ctx) { + int i; + + for (i = 0; i < rt->asf_ctx->nb_streams; i++) { + if (s->streams[stream_index]->id == rt->asf_ctx->streams[i]->id) { + *s->streams[stream_index]->codec = + *rt->asf_ctx->streams[i]->codec; + rt->asf_ctx->streams[i]->codec->extradata_size = 0; + rt->asf_ctx->streams[i]->codec->extradata = NULL; + av_set_pts_info(s->streams[stream_index], 32, 1, 1000); + } + } + } + } + + return 0; +} + +#define RTP_ASF_HANDLER(n, s, t) \ +RTPDynamicProtocolHandler ff_ms_rtp_ ## n ## _handler = { \ + s, \ + t, \ + CODEC_ID_NONE, \ + asfrtp_parse_sdp_line, \ +}; + +RTP_ASF_HANDLER(asf_pfv, "x-asf-pf", CODEC_TYPE_VIDEO); +RTP_ASF_HANDLER(asf_pfa, "x-asf-pf", CODEC_TYPE_AUDIO);