playlist: added is_valid_playlist_name()

The function valid_playlist_name() checks the name, but it insists on
reporting an eventual error to the client.  The new function
is_valid_playlist_name() is more generic: it just returns a boolean,
and does not care what the caller will use it for.  The old function
valid_playlist_name() will be removed later.
This commit is contained in:
Max Kellermann 2008-09-07 13:37:04 +02:00
parent 59efed3e8e
commit dc353eca80
2 changed files with 10 additions and 3 deletions

View File

@ -1509,11 +1509,16 @@ void findSongsInPlaylist(int fd, int numItems, LocateTagItem * items)
* protocol (and compatibility with all clients) to support idiots who * protocol (and compatibility with all clients) to support idiots who
* put '\r' and '\n' in filenames isn't going to happen, either. * put '\r' and '\n' in filenames isn't going to happen, either.
*/ */
int is_valid_playlist_name(const char *utf8path)
{
return strchr(utf8path, '/') == NULL &&
strchr(utf8path, '\n') == NULL &&
strchr(utf8path, '\r') == NULL;
}
int valid_playlist_name(int err_fd, const char *utf8path) int valid_playlist_name(int err_fd, const char *utf8path)
{ {
if (strchr(utf8path, '/') || if (!is_valid_playlist_name(utf8path)) {
strchr(utf8path, '\n') ||
strchr(utf8path, '\r')) {
commandError(err_fd, ACK_ERROR_ARG, "playlist name \"%s\" is " commandError(err_fd, ACK_ERROR_ARG, "playlist name \"%s\" is "
"invalid: playlist names may not contain slashes," "invalid: playlist names may not contain slashes,"
" newlines or carriage returns", " newlines or carriage returns",

View File

@ -137,6 +137,8 @@ void searchForSongsInPlaylist(int fd, int numItems, LocateTagItem * items);
void findSongsInPlaylist(int fd, int numItems, LocateTagItem * items); void findSongsInPlaylist(int fd, int numItems, LocateTagItem * items);
int is_valid_playlist_name(const char *utf8path);
int valid_playlist_name(int err_fd, const char *utf8path); int valid_playlist_name(int err_fd, const char *utf8path);
#endif #endif