Commit 90825339 authored by rbultje's avatar rbultje

Use the "server" RTSP field to detect whether the server that we're talking

to is a Microsoft Windows Media Server (the field will be "WMServer/version").
See "[PATCH] RTSP-MS 3/15: Add Windows Media Server type" thread on
mailinglist.



git-svn-id: file:///var/local/repositories/ffmpeg/trunk@16472 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 146f7cda
...@@ -688,6 +688,9 @@ void rtsp_parse_line(RTSPHeader *reply, const char *buf) ...@@ -688,6 +688,9 @@ void rtsp_parse_line(RTSPHeader *reply, const char *buf)
} else if (av_stristart(p, "RealChallenge1:", &p)) { } else if (av_stristart(p, "RealChallenge1:", &p)) {
skip_spaces(&p); skip_spaces(&p);
av_strlcpy(reply->real_challenge, p, sizeof(reply->real_challenge)); av_strlcpy(reply->real_challenge, p, sizeof(reply->real_challenge));
} else if (av_stristart(p, "Server:", &p)) {
skip_spaces(&p);
av_strlcpy(reply->server, p, sizeof(reply->server));
} }
} }
...@@ -1123,6 +1126,8 @@ static int rtsp_read_header(AVFormatContext *s, ...@@ -1123,6 +1126,8 @@ static int rtsp_read_header(AVFormatContext *s,
if (rt->server_type != RTSP_SERVER_REAL && reply->real_challenge[0]) { if (rt->server_type != RTSP_SERVER_REAL && reply->real_challenge[0]) {
rt->server_type = RTSP_SERVER_REAL; rt->server_type = RTSP_SERVER_REAL;
continue; continue;
} else if (!strncasecmp(reply->server, "WMServer/", 9)) {
rt->server_type = RTSP_SERVER_WMS;
} else if (rt->server_type == RTSP_SERVER_REAL) { } else if (rt->server_type == RTSP_SERVER_REAL) {
strcpy(real_challenge, reply->real_challenge); strcpy(real_challenge, reply->real_challenge);
} }
......
...@@ -66,6 +66,7 @@ typedef struct RTSPHeader { ...@@ -66,6 +66,7 @@ typedef struct RTSPHeader {
int seq; /**< sequence number */ int seq; /**< sequence number */
char session_id[512]; char session_id[512];
char real_challenge[64]; /**< the RealChallenge1 field from the server */ char real_challenge[64]; /**< the RealChallenge1 field from the server */
char server[64];
} RTSPHeader; } RTSPHeader;
enum RTSPClientState { enum RTSPClientState {
...@@ -77,6 +78,7 @@ enum RTSPClientState { ...@@ -77,6 +78,7 @@ enum RTSPClientState {
enum RTSPServerType { enum RTSPServerType {
RTSP_SERVER_RTP, /*< Standard-compliant RTP-server */ RTSP_SERVER_RTP, /*< Standard-compliant RTP-server */
RTSP_SERVER_REAL, /*< Realmedia-style server */ RTSP_SERVER_REAL, /*< Realmedia-style server */
RTSP_SERVER_WMS, /*< Windows Media server */
RTSP_SERVER_LAST RTSP_SERVER_LAST
}; };
......
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