output: use GLib instead of log.h/util.h

This commit is contained in:
Max Kellermann 2008-11-25 17:47:46 +01:00
parent 0277921e6a
commit 7918785c78
4 changed files with 39 additions and 38 deletions

View File

@ -21,7 +21,6 @@
#include "output_api.h" #include "output_api.h"
#include "output_control.h" #include "output_control.h"
#include "output_internal.h" #include "output_internal.h"
#include "log.h"
#include "path.h" #include "path.h"
#include "client.h" #include "client.h"
#include "idle.h" #include "idle.h"
@ -73,12 +72,12 @@ void initAudioDriver(void)
if (!audio_output_init(output, param)) { if (!audio_output_init(output, param)) {
if (param) if (param)
{ {
FATAL("problems configuring output device " g_error("problems configuring output device "
"defined at line %i\n", param->line); "defined at line %i\n", param->line);
} }
else else
{ {
FATAL("No audio_output specified and unable to " g_error("No audio_output specified and unable to "
"detect a default audio output device\n"); "detect a default audio output device\n");
} }
} }
@ -86,7 +85,7 @@ void initAudioDriver(void)
/* require output names to be unique: */ /* require output names to be unique: */
for (j = 0; j < i; j++) { for (j = 0; j < i; j++) {
if (!strcmp(output->name, audioOutputArray[j].name)) { if (!strcmp(output->name, audioOutputArray[j].name)) {
FATAL("output devices with identical " g_error("output devices with identical "
"names: %s\n", output->name); "names: %s\n", output->name);
} }
} }
@ -109,7 +108,7 @@ void initAudioConfig(void)
return; return;
if (0 != parseAudioConfig(&configured_audio_format, param->value)) { if (0 != parseAudioConfig(&configured_audio_format, param->value)) {
FATAL("error parsing \"%s\" at line %i\n", g_error("error parsing \"%s\" at line %i\n",
CONF_AUDIO_OUTPUT_FORMAT, param->line); CONF_AUDIO_OUTPUT_FORMAT, param->line);
} }
} }
@ -123,12 +122,12 @@ int parseAudioConfig(struct audio_format *audioFormat, char *conf)
audioFormat->sample_rate = strtol(conf, &test, 10); audioFormat->sample_rate = strtol(conf, &test, 10);
if (*test != ':') { if (*test != ':') {
ERROR("error parsing audio output format: %s\n", conf); g_warning("error parsing audio output format: %s\n", conf);
return -1; return -1;
} }
if (audioFormat->sample_rate <= 0) { if (audioFormat->sample_rate <= 0) {
ERROR("sample rate %u is not >= 0\n", g_warning("sample rate %u is not >= 0\n",
audioFormat->sample_rate); audioFormat->sample_rate);
return -1; return -1;
} }
@ -136,13 +135,13 @@ int parseAudioConfig(struct audio_format *audioFormat, char *conf)
audioFormat->bits = (uint8_t)strtoul(test + 1, &test, 10); audioFormat->bits = (uint8_t)strtoul(test + 1, &test, 10);
if (*test != ':') { if (*test != ':') {
ERROR("error parsing audio output format: %s\n", conf); g_warning("error parsing audio output format: %s\n", conf);
return -1; return -1;
} }
if (audioFormat->bits != 16 && audioFormat->bits != 24 && if (audioFormat->bits != 16 && audioFormat->bits != 24 &&
audioFormat->bits != 8) { audioFormat->bits != 8) {
ERROR("bits %u can not be used for audio output\n", g_warning("bits %u can not be used for audio output\n",
audioFormat->bits); audioFormat->bits);
return -1; return -1;
} }
@ -150,7 +149,7 @@ int parseAudioConfig(struct audio_format *audioFormat, char *conf)
audioFormat->channels = (uint8_t)strtoul(test + 1, &test, 10); audioFormat->channels = (uint8_t)strtoul(test + 1, &test, 10);
if (*test != '\0') { if (*test != '\0') {
ERROR("error parsing audio output format: %s\n", conf); g_warning("error parsing audio output format: %s\n", conf);
return -1; return -1;
} }
@ -159,8 +158,8 @@ int parseAudioConfig(struct audio_format *audioFormat, char *conf)
case 2: case 2:
break; break;
default: default:
ERROR("channels %i can not be used for audio output\n", g_warning("channels %u can not be used for audio output\n",
(int)audioFormat->channels); audioFormat->channels);
return -1; return -1;
} }
@ -418,7 +417,7 @@ void readAudioDevicesState(FILE *fp)
continue; continue;
errline: errline:
/* nonfatal */ /* nonfatal */
ERROR("invalid line in state_file: %s\n", buffer); g_warning("invalid line in state_file: %s\n", buffer);
} }
} }

View File

@ -24,7 +24,6 @@
#include "audio_format.h" #include "audio_format.h"
#include "tag.h" #include "tag.h"
#include "conf.h" #include "conf.h"
#include "log.h"
#include <stdbool.h> #include <stdbool.h>

View File

@ -20,9 +20,10 @@
#include "output_api.h" #include "output_api.h"
#include "output_internal.h" #include "output_internal.h"
#include "output_list.h" #include "output_list.h"
#include "log.h"
#include "audio.h" #include "audio.h"
#include <glib.h>
#define AUDIO_OUTPUT_TYPE "type" #define AUDIO_OUTPUT_TYPE "type"
#define AUDIO_OUTPUT_NAME "name" #define AUDIO_OUTPUT_NAME "name"
#define AUDIO_OUTPUT_FORMAT "format" #define AUDIO_OUTPUT_FORMAT "format"
@ -30,7 +31,7 @@
#define getBlockParam(name, str, force) { \ #define getBlockParam(name, str, force) { \
bp = getBlockParam(param, name); \ bp = getBlockParam(param, name); \
if(force && bp == NULL) { \ if(force && bp == NULL) { \
FATAL("couldn't find parameter \"%s\" in audio output " \ g_error("couldn't find parameter \"%s\" in audio output " \
"definition beginning at %i\n", \ "definition beginning at %i\n", \
name, param->line); \ name, param->line); \
} \ } \
@ -53,22 +54,22 @@ int audio_output_init(struct audio_output *ao, ConfigParam * param)
plugin = audio_output_plugin_get(type); plugin = audio_output_plugin_get(type);
if (plugin == NULL) { if (plugin == NULL) {
FATAL("couldn't find audio output plugin for type " g_error("couldn't find audio output plugin for type "
"\"%s\" at line %i\n", type, param->line); "\"%s\" at line %i\n", type, param->line);
} }
} else { } else {
unsigned i; unsigned i;
WARNING("No \"%s\" defined in config file\n", g_warning("No \"%s\" defined in config file\n",
CONF_AUDIO_OUTPUT); CONF_AUDIO_OUTPUT);
WARNING("Attempt to detect audio output device\n"); g_warning("Attempt to detect audio output device\n");
audio_output_plugins_for_each(plugin, i) { audio_output_plugins_for_each(plugin, i) {
if (plugin->test_default_device) { if (plugin->test_default_device) {
WARNING("Attempting to detect a %s audio " g_warning("Attempting to detect a %s audio "
"device\n", plugin->name); "device\n", plugin->name);
if (plugin->test_default_device()) { if (plugin->test_default_device()) {
WARNING("Successfully detected a %s " g_warning("Successfully detected a %s "
"audio device\n", plugin->name); "audio device\n", plugin->name);
break; break;
} }
@ -76,7 +77,7 @@ int audio_output_init(struct audio_output *ao, ConfigParam * param)
} }
if (plugin == NULL) { if (plugin == NULL) {
WARNING("Unable to detect an audio device\n"); g_warning("Unable to detect an audio device\n");
return 0; return 0;
} }
@ -96,7 +97,7 @@ int audio_output_init(struct audio_output *ao, ConfigParam * param)
if (format) { if (format) {
if (0 != parseAudioConfig(&ao->reqAudioFormat, format)) { if (0 != parseAudioConfig(&ao->reqAudioFormat, format)) {
FATAL("error parsing format at line %i\n", bp->line); g_error("error parsing format at line %i\n", bp->line);
} }
} else } else
audio_format_clear(&ao->reqAudioFormat); audio_format_clear(&ao->reqAudioFormat);

View File

@ -19,9 +19,11 @@
#include "output_thread.h" #include "output_thread.h"
#include "output_api.h" #include "output_api.h"
#include "output_internal.h" #include "output_internal.h"
#include "utils.h"
#include <glib.h>
#include <assert.h> #include <assert.h>
#include <stdlib.h>
#include <errno.h>
enum { enum {
/** after a failure, wait this number of seconds before /** after a failure, wait this number of seconds before
@ -46,7 +48,7 @@ static void convertAudioFormat(struct audio_output *audioOutput,
if (size > audioOutput->convBufferLen) { if (size > audioOutput->convBufferLen) {
if (audioOutput->convBuffer != NULL) if (audioOutput->convBuffer != NULL)
free(audioOutput->convBuffer); free(audioOutput->convBuffer);
audioOutput->convBuffer = xmalloc(size); audioOutput->convBuffer = g_malloc(size);
audioOutput->convBufferLen = size; audioOutput->convBufferLen = size;
} }
@ -164,5 +166,5 @@ void audio_output_thread_start(struct audio_output *ao)
pthread_attr_init(&attr); pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED); pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
if (pthread_create(&ao->thread, &attr, audio_output_task, ao)) if (pthread_create(&ao->thread, &attr, audio_output_task, ao))
FATAL("Failed to spawn output task: %s\n", strerror(errno)); g_error("Failed to spawn output task: %s\n", strerror(errno));
} }