database: I/O error handling in db_save()
Check ferror() instead of the fprintf() return value.
This commit is contained in:
parent
1a4cfc3d90
commit
c422344190
@ -251,7 +251,9 @@ db_save(void)
|
|||||||
|
|
||||||
fprintf(fp, "%s\n", DIRECTORY_INFO_END);
|
fprintf(fp, "%s\n", DIRECTORY_INFO_END);
|
||||||
|
|
||||||
if (directory_save(fp, music_root) < 0) {
|
directory_save(fp, music_root);
|
||||||
|
|
||||||
|
if (ferror(fp)) {
|
||||||
g_warning("Failed to write to database file: %s",
|
g_warning("Failed to write to database file: %s",
|
||||||
strerror(errno));
|
strerror(errno));
|
||||||
while (fclose(fp) && errno == EINTR);
|
while (fclose(fp) && errno == EINTR);
|
||||||
|
@ -39,43 +39,38 @@ directory_quark(void)
|
|||||||
return g_quark_from_static_string("directory");
|
return g_quark_from_static_string("directory");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO error checking */
|
void
|
||||||
int
|
|
||||||
directory_save(FILE *fp, struct directory *directory)
|
directory_save(FILE *fp, struct directory *directory)
|
||||||
{
|
{
|
||||||
struct dirvec *children = &directory->children;
|
struct dirvec *children = &directory->children;
|
||||||
size_t i;
|
size_t i;
|
||||||
int retv;
|
|
||||||
|
|
||||||
if (!directory_is_root(directory)) {
|
if (!directory_is_root(directory)) {
|
||||||
fprintf(fp, DIRECTORY_MTIME "%lu\n",
|
fprintf(fp, DIRECTORY_MTIME "%lu\n",
|
||||||
(unsigned long)directory->mtime);
|
(unsigned long)directory->mtime);
|
||||||
|
|
||||||
retv = fprintf(fp, "%s%s\n", DIRECTORY_BEGIN,
|
fprintf(fp, "%s%s\n", DIRECTORY_BEGIN,
|
||||||
directory_get_path(directory));
|
directory_get_path(directory));
|
||||||
if (retv < 0)
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < children->nr; ++i) {
|
for (i = 0; i < children->nr; ++i) {
|
||||||
struct directory *cur = children->base[i];
|
struct directory *cur = children->base[i];
|
||||||
char *base = g_path_get_basename(cur->path);
|
char *base = g_path_get_basename(cur->path);
|
||||||
|
|
||||||
retv = fprintf(fp, DIRECTORY_DIR "%s\n", base);
|
fprintf(fp, DIRECTORY_DIR "%s\n", base);
|
||||||
g_free(base);
|
g_free(base);
|
||||||
if (retv < 0)
|
|
||||||
return -1;
|
directory_save(fp, cur);
|
||||||
if (directory_save(fp, cur) < 0)
|
|
||||||
return -1;
|
if (ferror(fp))
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
songvec_save(fp, &directory->songs);
|
songvec_save(fp, &directory->songs);
|
||||||
|
|
||||||
if (!directory_is_root(directory) &&
|
if (!directory_is_root(directory))
|
||||||
fprintf(fp, DIRECTORY_END "%s\n",
|
fprintf(fp, DIRECTORY_END "%s\n",
|
||||||
directory_get_path(directory)) < 0)
|
directory_get_path(directory));
|
||||||
return -1;
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct directory *
|
static struct directory *
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
struct directory;
|
struct directory;
|
||||||
|
|
||||||
int
|
void
|
||||||
directory_save(FILE *fp, struct directory *directory);
|
directory_save(FILE *fp, struct directory *directory);
|
||||||
|
|
||||||
bool
|
bool
|
||||||
|
Loading…
Reference in New Issue
Block a user