output/httpd/IcyMetaDataServer: use CopyString() instead of g_strlcpy()

This commit is contained in:
Max Kellermann 2014-12-01 22:25:18 +01:00
parent 15213a041d
commit 7363d50a1e
2 changed files with 7 additions and 20 deletions

View File

@ -348,8 +348,6 @@ AC_ARG_ENABLE(httpd-output,
AS_HELP_STRING([--enable-httpd-output],
[enables the HTTP server output]),,
[enable_httpd_output=auto])
MPD_DEPENDS([enable_httpd_output], [enable_glib],
[Cannot use --enable-httpd-output with --disable-glib])
AC_ARG_ENABLE(inotify,
AS_HELP_STRING([--disable-inotify],

View File

@ -22,8 +22,8 @@
#include "Page.hxx"
#include "tag/Tag.hxx"
#include "util/FormatString.hxx"
#include <glib.h>
#include "util/StringUtil.hxx"
#include "util/Macros.hxx"
#include <string.h>
@ -95,25 +95,14 @@ icy_server_metadata_page(const Tag &tag, const TagType *types)
// Length + Metadata - "StreamTitle='';StreamUrl='';" = 4081 - 28
char stream_title[(1 + 255 - 28) * 16];
char *p = stream_title, *const end = stream_title + ARRAY_SIZE(stream_title);
stream_title[0] = '\0';
unsigned position = 0;
while (position < sizeof(stream_title) && item <= last_item) {
size_t length = 0;
while (p < end && item <= last_item) {
p = CopyString(p, tag_items[item++], end - p);
length = g_strlcpy(stream_title + position,
tag_items[item++],
sizeof(stream_title) - position);
position += length;
if (item <= last_item) {
length = g_strlcpy(stream_title + position,
" - ",
sizeof(stream_title) - position);
position += length;
}
if (item <= last_item)
p = CopyString(p, " - ", end - p);
}
char *icy_string = icy_server_metadata_string(stream_title, "");