Use strncasecmp instead of strncmp when comparing HTTP headers. It seems

some versions of shoutcast send "content-type" in all lowercase, and I
don't trust other servers to get the case right for the rest of the headers
we look for.

git-svn-id: https://svn.musicpd.org/mpd/trunk@6482 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
J. Alexander Treuman 2007-06-04 19:02:23 +00:00
parent caa17db85e
commit cbdc0b1534

View File

@ -610,13 +610,13 @@ static int getHTTPHello(InputStream * inStream)
cur = strstr(data->buffer, "\r\n"); cur = strstr(data->buffer, "\r\n");
while (cur && cur != needle) { while (cur && cur != needle) {
if (0 == strncmp(cur, "\r\nContent-Length: ", 18)) { if (0 == strncasecmp(cur, "\r\nContent-Length: ", 18)) {
if (!inStream->size) if (!inStream->size)
inStream->size = atol(cur + 18); inStream->size = atol(cur + 18);
} else if (0 == strncmp(cur, "\r\nicy-metaint:", 14)) { } else if (0 == strncasecmp(cur, "\r\nicy-metaint:", 14)) {
data->icyMetaint = atoi(cur + 14); data->icyMetaint = atoi(cur + 14);
} else if (0 == strncmp(cur, "\r\nicy-name:", 11) || } else if (0 == strncasecmp(cur, "\r\nicy-name:", 11) ||
0 == strncmp(cur, "\r\nice-name:", 11)) { 0 == strncasecmp(cur, "\r\nice-name:", 11)) {
int incr = 11; int incr = 11;
char *temp = strstr(cur + incr, "\r\n"); char *temp = strstr(cur + incr, "\r\n");
if (!temp) if (!temp)
@ -630,7 +630,7 @@ static int getHTTPHello(InputStream * inStream)
*temp = '\r'; *temp = '\r';
DEBUG("inputStream_http: metaName: %s\n", DEBUG("inputStream_http: metaName: %s\n",
inStream->metaName); inStream->metaName);
} else if (0 == strncmp(cur, "\r\nx-audiocast-name:", 19)) { } else if (0 == strncasecmp(cur, "\r\nx-audiocast-name:", 19)) {
int incr = 19; int incr = 19;
char *temp = strstr(cur + incr, "\r\n"); char *temp = strstr(cur + incr, "\r\n");
if (!temp) if (!temp)
@ -644,7 +644,7 @@ static int getHTTPHello(InputStream * inStream)
*temp = '\r'; *temp = '\r';
DEBUG("inputStream_http: metaName: %s\n", DEBUG("inputStream_http: metaName: %s\n",
inStream->metaName); inStream->metaName);
} else if (0 == strncmp(cur, "\r\nContent-Type:", 15)) { } else if (0 == strncasecmp(cur, "\r\nContent-Type:", 15)) {
int incr = 15; int incr = 15;
char *temp = strstr(cur + incr, "\r\n"); char *temp = strstr(cur + incr, "\r\n");
if (!temp) if (!temp)