fifo: use GLib logging

This commit is contained in:
Max Kellermann 2008-12-29 17:29:31 +01:00
parent 409ee38b42
commit eddf5e1e5e

View File

@ -17,7 +17,6 @@
*/ */
#include "../output_api.h" #include "../output_api.h"
#include "../log.h"
#include "../utils.h" #include "../utils.h"
#include "../timer.h" #include "../timer.h"
@ -25,6 +24,9 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <fcntl.h> #include <fcntl.h>
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "fifo"
#define FIFO_BUFFER_SIZE 65536 /* pipe capacity on Linux >= 2.6.11 */ #define FIFO_BUFFER_SIZE 65536 /* pipe capacity on Linux >= 2.6.11 */
typedef struct _FifoData { typedef struct _FifoData {
@ -63,11 +65,11 @@ static void freeFifoData(FifoData *fd)
static void removeFifo(FifoData *fd) static void removeFifo(FifoData *fd)
{ {
DEBUG("Removing FIFO \"%s\"\n", fd->path); g_debug("Removing FIFO \"%s\"", fd->path);
if (unlink(fd->path) < 0) { if (unlink(fd->path) < 0) {
ERROR("Could not remove FIFO \"%s\": %s\n", g_warning("Could not remove FIFO \"%s\": %s",
fd->path, strerror(errno)); fd->path, strerror(errno));
return; return;
} }
@ -95,8 +97,8 @@ static void closeFifo(FifoData *fd)
static int makeFifo(FifoData *fd) static int makeFifo(FifoData *fd)
{ {
if (mkfifo(fd->path, 0666) < 0) { if (mkfifo(fd->path, 0666) < 0) {
ERROR("Couldn't create FIFO \"%s\": %s\n", g_warning("Couldn't create FIFO \"%s\": %s",
fd->path, strerror(errno)); fd->path, strerror(errno));
return -1; return -1;
} }
@ -115,13 +117,14 @@ static int checkFifo(FifoData *fd)
return makeFifo(fd); return makeFifo(fd);
} }
ERROR("Failed to stat FIFO \"%s\": %s\n", g_warning("Failed to stat FIFO \"%s\": %s",
fd->path, strerror(errno)); fd->path, strerror(errno));
return -1; return -1;
} }
if (!S_ISFIFO(st.st_mode)) { if (!S_ISFIFO(st.st_mode)) {
ERROR("\"%s\" already exists, but is not a FIFO\n", fd->path); g_warning("\"%s\" already exists, but is not a FIFO",
fd->path);
return -1; return -1;
} }
@ -135,16 +138,16 @@ static bool openFifo(FifoData *fd)
fd->input = open(fd->path, O_RDONLY|O_NONBLOCK); fd->input = open(fd->path, O_RDONLY|O_NONBLOCK);
if (fd->input < 0) { if (fd->input < 0) {
ERROR("Could not open FIFO \"%s\" for reading: %s\n", g_warning("Could not open FIFO \"%s\" for reading: %s",
fd->path, strerror(errno)); fd->path, strerror(errno));
closeFifo(fd); closeFifo(fd);
return false; return false;
} }
fd->output = open(fd->path, O_WRONLY|O_NONBLOCK); fd->output = open(fd->path, O_WRONLY|O_NONBLOCK);
if (fd->output < 0) { if (fd->output < 0) {
ERROR("Could not open FIFO \"%s\" for writing: %s\n", g_warning("Could not open FIFO \"%s\" for writing: %s",
fd->path, strerror(errno)); fd->path, strerror(errno));
closeFifo(fd); closeFifo(fd);
return false; return false;
} }
@ -162,14 +165,14 @@ static void *fifo_initDriver(mpd_unused struct audio_output *ao,
blockParam = getBlockParam(param, "path"); blockParam = getBlockParam(param, "path");
if (!blockParam) { if (!blockParam) {
FATAL("No \"path\" parameter specified for fifo output " g_error("No \"path\" parameter specified for fifo output "
"defined at line %i\n", param->line); "defined at line %i", param->line);
} }
path = parsePath(blockParam->value); path = parsePath(blockParam->value);
if (!path) { if (!path) {
FATAL("Could not parse \"path\" parameter for fifo output " g_error("Could not parse \"path\" parameter for fifo output "
"at line %i\n", blockParam->line); "at line %i", blockParam->line);
} }
fd = newFifoData(); fd = newFifoData();
@ -226,8 +229,8 @@ static void fifo_dropBufferedAudio(void *data)
bytes = read(fd->input, buf, FIFO_BUFFER_SIZE); bytes = read(fd->input, buf, FIFO_BUFFER_SIZE);
if (bytes < 0 && errno != EAGAIN) { if (bytes < 0 && errno != EAGAIN) {
WARNING("Flush of FIFO \"%s\" failed: %s\n", g_warning("Flush of FIFO \"%s\" failed: %s",
fd->path, strerror(errno)); fd->path, strerror(errno));
} }
} }
@ -257,8 +260,8 @@ fifo_playAudio(void *data, const char *playChunk, size_t size)
continue; continue;
} }
ERROR("Closing FIFO output \"%s\" due to write error: " g_warning("Closing FIFO output \"%s\" due to write error: %s",
"%s\n", fd->path, strerror(errno)); fd->path, strerror(errno));
return false; return false;
} }