output/solaris: convert to C++

This commit is contained in:
Max Kellermann 2013-04-17 01:08:35 +02:00
parent 750b2ad6a8
commit 4aeec4bb60
4 changed files with 44 additions and 29 deletions

View File

@ -880,7 +880,7 @@ endif
if ENABLE_SOLARIS_OUTPUT
liboutput_plugins_a_SOURCES += \
src/output/solaris_output_plugin.c src/output/solaris_output_plugin.h
src/output/SolarisOutputPlugin.cxx src/output/SolarisOutputPlugin.hxx
endif
if ENABLE_WINMM_OUTPUT

View File

@ -34,7 +34,7 @@
#include "output/RecorderOutputPlugin.hxx"
#include "output/RoarOutputPlugin.hxx"
#include "output/ShoutOutputPlugin.hxx"
#include "output/solaris_output_plugin.h"
#include "output/SolarisOutputPlugin.hxx"
#include "output/WinmmOutputPlugin.hxx"
const struct audio_output_plugin *const audio_output_plugins[] = {

View File

@ -1,5 +1,5 @@
/*
* Copyright (C) 2003-2011 The Music Player Daemon Project
* Copyright (C) 2003-2013 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
@ -18,7 +18,7 @@
*/
#include "config.h"
#include "solaris_output_plugin.h"
#include "SolarisOutputPlugin.hxx"
#include "output_api.h"
#include "fd_util.h"
@ -53,13 +53,22 @@ struct audio_info {
#undef G_LOG_DOMAIN
#define G_LOG_DOMAIN "solaris_output"
struct solaris_output {
struct SolarisOutput {
struct audio_output base;
/* configuration */
const char *device;
int fd;
bool Initialize(const config_param *param, GError **error_r) {
return ao_base_init(&base, &solaris_output_plugin, param,
error_r);
}
void Deinitialize() {
ao_base_finish(&base);
}
};
/**
@ -81,13 +90,12 @@ solaris_output_test_default_device(void)
}
static struct audio_output *
solaris_output_init(const struct config_param *param, GError **error_r)
solaris_output_init(const config_param *param, GError **error_r)
{
struct solaris_output *so = g_new(struct solaris_output, 1);
if (!ao_base_init(&so->base, &solaris_output_plugin, param, error_r)) {
g_free(so);
return NULL;
SolarisOutput *so = new SolarisOutput();
if (!so->Initialize(param, error_r)) {
delete so;
return nullptr;
}
so->device = config_get_block_string(param, "device", "/dev/audio");
@ -98,17 +106,17 @@ solaris_output_init(const struct config_param *param, GError **error_r)
static void
solaris_output_finish(struct audio_output *ao)
{
struct solaris_output *so = (struct solaris_output *)ao;
SolarisOutput *so = (SolarisOutput *)ao;
ao_base_finish(&so->base);
g_free(so);
so->Deinitialize();
delete so;
}
static bool
solaris_output_open(struct audio_output *ao, struct audio_format *audio_format,
GError **error)
{
struct solaris_output *so = (struct solaris_output *)ao;
SolarisOutput *so = (SolarisOutput *)ao;
struct audio_info info;
int ret, flags;
@ -161,7 +169,7 @@ solaris_output_open(struct audio_output *ao, struct audio_format *audio_format,
static void
solaris_output_close(struct audio_output *ao)
{
struct solaris_output *so = (struct solaris_output *)ao;
SolarisOutput *so = (SolarisOutput *)ao;
close(so->fd);
}
@ -170,7 +178,7 @@ static size_t
solaris_output_play(struct audio_output *ao, const void *chunk, size_t size,
GError **error)
{
struct solaris_output *so = (struct solaris_output *)ao;
SolarisOutput *so = (SolarisOutput *)ao;
ssize_t nbytes;
nbytes = write(so->fd, chunk, size);
@ -186,18 +194,25 @@ solaris_output_play(struct audio_output *ao, const void *chunk, size_t size,
static void
solaris_output_cancel(struct audio_output *ao)
{
struct solaris_output *so = (struct solaris_output *)ao;
SolarisOutput *so = (SolarisOutput *)ao;
ioctl(so->fd, I_FLUSH);
}
const struct audio_output_plugin solaris_output_plugin = {
.name = "solaris",
.test_default_device = solaris_output_test_default_device,
.init = solaris_output_init,
.finish = solaris_output_finish,
.open = solaris_output_open,
.close = solaris_output_close,
.play = solaris_output_play,
.cancel = solaris_output_cancel,
"solaris",
solaris_output_test_default_device,
solaris_output_init,
solaris_output_finish,
nullptr,
nullptr,
solaris_output_open,
solaris_output_close,
nullptr,
nullptr,
solaris_output_play,
nullptr,
solaris_output_cancel,
nullptr,
nullptr,
};

View File

@ -1,5 +1,5 @@
/*
* Copyright (C) 2003-2011 The Music Player Daemon Project
* Copyright (C) 2003-2013 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
@ -17,8 +17,8 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef MPD_SOLARIS_OUTPUT_PLUGIN_H
#define MPD_SOLARIS_OUTPUT_PLUGIN_H
#ifndef MPD_SOLARIS_OUTPUT_PLUGIN_HXX
#define MPD_SOLARIS_OUTPUT_PLUGIN_HXX
extern const struct audio_output_plugin solaris_output_plugin;