mapper: allocate playlist path from heap
Don't pass a static buffer to map_spl_utf8_to_fs().
This commit is contained in:
parent
886ed1b225
commit
80fa9183e4
21
src/mapper.c
21
src/mapper.c
@ -164,23 +164,20 @@ map_fs_to_utf8(const char *path_fs, char *buffer)
|
|||||||
return fs_charset_to_utf8(buffer, path_fs);
|
return fs_charset_to_utf8(buffer, path_fs);
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *rpp2app_r(char *dst, const char *rel_path)
|
|
||||||
{
|
|
||||||
pfx_dir(dst, rel_path, strlen(rel_path),
|
|
||||||
playlist_dir, playlist_dir_length);
|
|
||||||
return dst;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
map_spl_path(void)
|
map_spl_path(void)
|
||||||
{
|
{
|
||||||
return playlist_dir;
|
return playlist_dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *
|
char *
|
||||||
map_spl_utf8_to_fs(const char *name, char *buffer)
|
map_spl_utf8_to_fs(const char *name)
|
||||||
{
|
{
|
||||||
rpp2app_r(buffer, utf8_to_fs_charset(buffer, name));
|
char *filename = g_strconcat(name, "." PLAYLIST_FILE_SUFFIX, NULL);
|
||||||
g_strlcat(buffer, "." PLAYLIST_FILE_SUFFIX, MPD_PATH_MAX);
|
char *path;
|
||||||
return buffer;
|
|
||||||
|
path = g_build_filename(playlist_dir, filename, NULL);
|
||||||
|
g_free(filename);
|
||||||
|
|
||||||
|
return path;
|
||||||
}
|
}
|
||||||
|
@ -93,9 +93,10 @@ map_spl_path(void);
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Maps a playlist name (without the ".m3u" suffix) to a file system
|
* Maps a playlist name (without the ".m3u" suffix) to a file system
|
||||||
* path.
|
* path. The return value is allocated on the heap and must be freed
|
||||||
|
* with g_free().
|
||||||
*/
|
*/
|
||||||
const char *
|
char *
|
||||||
map_spl_utf8_to_fs(const char *name, char *buffer);
|
map_spl_utf8_to_fs(const char *name);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -1203,17 +1203,19 @@ enum playlist_result savePlaylist(const char *utf8file)
|
|||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
struct stat sb;
|
struct stat sb;
|
||||||
char path_max_tmp[MPD_PATH_MAX];
|
char *path;
|
||||||
const char *path;
|
|
||||||
|
|
||||||
if (!is_valid_playlist_name(utf8file))
|
if (!is_valid_playlist_name(utf8file))
|
||||||
return PLAYLIST_RESULT_BAD_NAME;
|
return PLAYLIST_RESULT_BAD_NAME;
|
||||||
|
|
||||||
path = map_spl_utf8_to_fs(utf8file, path_max_tmp);
|
path = map_spl_utf8_to_fs(utf8file);
|
||||||
if (!stat(path, &sb))
|
if (!stat(path, &sb)) {
|
||||||
|
g_free(path);
|
||||||
return PLAYLIST_RESULT_LIST_EXISTS;
|
return PLAYLIST_RESULT_LIST_EXISTS;
|
||||||
|
}
|
||||||
|
|
||||||
while (!(fp = fopen(path, "w")) && errno == EINTR);
|
while (!(fp = fopen(path, "w")) && errno == EINTR);
|
||||||
|
g_free(path);
|
||||||
|
|
||||||
if (fp == NULL)
|
if (fp == NULL)
|
||||||
return PLAYLIST_RESULT_ERRNO;
|
return PLAYLIST_RESULT_ERRNO;
|
||||||
|
@ -115,14 +115,14 @@ static enum playlist_result
|
|||||||
spl_save(GPtrArray *list, const char *utf8path)
|
spl_save(GPtrArray *list, const char *utf8path)
|
||||||
{
|
{
|
||||||
FILE *file;
|
FILE *file;
|
||||||
char path_max_tmp[MPD_PATH_MAX];
|
char *path_fs;
|
||||||
const char *path_fs;
|
|
||||||
|
|
||||||
assert(utf8path != NULL);
|
assert(utf8path != NULL);
|
||||||
|
|
||||||
path_fs = map_spl_utf8_to_fs(utf8path, path_max_tmp);
|
path_fs = map_spl_utf8_to_fs(utf8path);
|
||||||
|
|
||||||
while (!(file = fopen(path_fs, "w")) && errno == EINTR);
|
while (!(file = fopen(path_fs, "w")) && errno == EINTR);
|
||||||
|
g_free(path_fs);
|
||||||
if (file == NULL)
|
if (file == NULL)
|
||||||
return PLAYLIST_RESULT_ERRNO;
|
return PLAYLIST_RESULT_ERRNO;
|
||||||
|
|
||||||
@ -142,14 +142,15 @@ spl_load(const char *utf8path)
|
|||||||
GPtrArray *list;
|
GPtrArray *list;
|
||||||
char buffer[MPD_PATH_MAX];
|
char buffer[MPD_PATH_MAX];
|
||||||
char path_max_tmp[MPD_PATH_MAX];
|
char path_max_tmp[MPD_PATH_MAX];
|
||||||
const char *path_fs;
|
char *path_fs;
|
||||||
|
|
||||||
if (!is_valid_playlist_name(utf8path))
|
if (!is_valid_playlist_name(utf8path))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
path_fs = map_spl_utf8_to_fs(utf8path, path_max_tmp);
|
path_fs = map_spl_utf8_to_fs(utf8path);
|
||||||
|
|
||||||
while (!(file = fopen(path_fs, "r")) && errno == EINTR);
|
while (!(file = fopen(path_fs, "r")) && errno == EINTR);
|
||||||
|
g_free(path_fs);
|
||||||
if (file == NULL)
|
if (file == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -257,16 +258,16 @@ spl_move_index(const char *utf8path, unsigned src, unsigned dest)
|
|||||||
enum playlist_result
|
enum playlist_result
|
||||||
spl_clear(const char *utf8path)
|
spl_clear(const char *utf8path)
|
||||||
{
|
{
|
||||||
char filename[MPD_PATH_MAX];
|
char *path_fs;
|
||||||
const char *path_fs;
|
|
||||||
FILE *file;
|
FILE *file;
|
||||||
|
|
||||||
if (!is_valid_playlist_name(utf8path))
|
if (!is_valid_playlist_name(utf8path))
|
||||||
return PLAYLIST_RESULT_BAD_NAME;
|
return PLAYLIST_RESULT_BAD_NAME;
|
||||||
|
|
||||||
path_fs = map_spl_utf8_to_fs(utf8path, filename);
|
path_fs = map_spl_utf8_to_fs(utf8path);
|
||||||
|
|
||||||
while (!(file = fopen(path_fs, "w")) && errno == EINTR);
|
while (!(file = fopen(path_fs, "w")) && errno == EINTR);
|
||||||
|
g_free(path_fs);
|
||||||
if (file == NULL)
|
if (file == NULL)
|
||||||
return PLAYLIST_RESULT_ERRNO;
|
return PLAYLIST_RESULT_ERRNO;
|
||||||
|
|
||||||
@ -279,12 +280,13 @@ spl_clear(const char *utf8path)
|
|||||||
enum playlist_result
|
enum playlist_result
|
||||||
spl_delete(const char *name_utf8)
|
spl_delete(const char *name_utf8)
|
||||||
{
|
{
|
||||||
char filename[MPD_PATH_MAX];
|
char *path_fs;
|
||||||
const char *path_fs;
|
int ret;
|
||||||
|
|
||||||
path_fs = map_spl_utf8_to_fs(name_utf8, filename);
|
path_fs = map_spl_utf8_to_fs(name_utf8);
|
||||||
|
ret = unlink(path_fs);
|
||||||
if (unlink(path_fs) < 0)
|
g_free(path_fs);
|
||||||
|
if (ret < 0)
|
||||||
return errno == ENOENT
|
return errno == ENOENT
|
||||||
? PLAYLIST_RESULT_NO_SUCH_LIST
|
? PLAYLIST_RESULT_NO_SUCH_LIST
|
||||||
: PLAYLIST_RESULT_ERRNO;
|
: PLAYLIST_RESULT_ERRNO;
|
||||||
@ -323,15 +325,15 @@ spl_append_song(const char *utf8path, struct song *song)
|
|||||||
{
|
{
|
||||||
FILE *file;
|
FILE *file;
|
||||||
struct stat st;
|
struct stat st;
|
||||||
char path_max_tmp[MPD_PATH_MAX];
|
char *path_fs;
|
||||||
const char *path_fs;
|
|
||||||
|
|
||||||
if (!is_valid_playlist_name(utf8path))
|
if (!is_valid_playlist_name(utf8path))
|
||||||
return PLAYLIST_RESULT_BAD_NAME;
|
return PLAYLIST_RESULT_BAD_NAME;
|
||||||
|
|
||||||
path_fs = map_spl_utf8_to_fs(utf8path, path_max_tmp);
|
path_fs = map_spl_utf8_to_fs(utf8path);
|
||||||
|
|
||||||
while (!(file = fopen(path_fs, "a")) && errno == EINTR);
|
while (!(file = fopen(path_fs, "a")) && errno == EINTR);
|
||||||
|
g_free(path_fs);
|
||||||
if (file == NULL) {
|
if (file == NULL) {
|
||||||
int save_errno = errno;
|
int save_errno = errno;
|
||||||
while (fclose(file) != 0 && errno == EINTR);
|
while (fclose(file) != 0 && errno == EINTR);
|
||||||
@ -381,20 +383,10 @@ spl_append_uri(const char *url, const char *utf8file)
|
|||||||
return PLAYLIST_RESULT_NO_SUCH_SONG;
|
return PLAYLIST_RESULT_NO_SUCH_SONG;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum playlist_result
|
static enum playlist_result
|
||||||
spl_rename(const char *utf8from, const char *utf8to)
|
spl_rename_internal(const char *from_path_fs, const char *to_path_fs)
|
||||||
{
|
{
|
||||||
struct stat st;
|
struct stat st;
|
||||||
char from[MPD_PATH_MAX];
|
|
||||||
char to[MPD_PATH_MAX];
|
|
||||||
const char *from_path_fs, *to_path_fs;
|
|
||||||
|
|
||||||
if (!is_valid_playlist_name(utf8from) ||
|
|
||||||
!is_valid_playlist_name(utf8to))
|
|
||||||
return PLAYLIST_RESULT_BAD_NAME;
|
|
||||||
|
|
||||||
from_path_fs = map_spl_utf8_to_fs(utf8from, from);
|
|
||||||
to_path_fs = map_spl_utf8_to_fs(utf8to, to);
|
|
||||||
|
|
||||||
if (stat(from_path_fs, &st) != 0)
|
if (stat(from_path_fs, &st) != 0)
|
||||||
return PLAYLIST_RESULT_NO_SUCH_LIST;
|
return PLAYLIST_RESULT_NO_SUCH_LIST;
|
||||||
@ -408,3 +400,24 @@ spl_rename(const char *utf8from, const char *utf8to)
|
|||||||
idle_add(IDLE_STORED_PLAYLIST);
|
idle_add(IDLE_STORED_PLAYLIST);
|
||||||
return PLAYLIST_RESULT_SUCCESS;
|
return PLAYLIST_RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum playlist_result
|
||||||
|
spl_rename(const char *utf8from, const char *utf8to)
|
||||||
|
{
|
||||||
|
char *from_path_fs, *to_path_fs;
|
||||||
|
static enum playlist_result ret;
|
||||||
|
|
||||||
|
if (!is_valid_playlist_name(utf8from) ||
|
||||||
|
!is_valid_playlist_name(utf8to))
|
||||||
|
return PLAYLIST_RESULT_BAD_NAME;
|
||||||
|
|
||||||
|
from_path_fs = map_spl_utf8_to_fs(utf8from);
|
||||||
|
to_path_fs = map_spl_utf8_to_fs(utf8to);
|
||||||
|
|
||||||
|
ret = spl_rename_internal(from_path_fs, to_path_fs);
|
||||||
|
|
||||||
|
g_free(from_path_fs);
|
||||||
|
g_free(to_path_fs);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user