mixer/{alsa,pulse}: convert to C++
This commit is contained in:
parent
b5e1bd5705
commit
d3e1b72d38
@ -101,7 +101,6 @@ mpd_headers = \
|
|||||||
src/mixer_plugin.h \
|
src/mixer_plugin.h \
|
||||||
src/mixer_type.h \
|
src/mixer_type.h \
|
||||||
src/mixer/software_mixer_plugin.h \
|
src/mixer/software_mixer_plugin.h \
|
||||||
src/mixer/pulse_mixer_plugin.h \
|
|
||||||
src/daemon.h \
|
src/daemon.h \
|
||||||
src/AudioCompress/config.h \
|
src/AudioCompress/config.h \
|
||||||
src/AudioCompress/compress.h \
|
src/AudioCompress/compress.h \
|
||||||
@ -812,7 +811,7 @@ libmixer_plugins_a_CPPFLAGS = $(AM_CPPFLAGS) \
|
|||||||
if HAVE_ALSA
|
if HAVE_ALSA
|
||||||
liboutput_plugins_a_SOURCES += \
|
liboutput_plugins_a_SOURCES += \
|
||||||
src/output/alsa_output_plugin.c src/output/alsa_output_plugin.h
|
src/output/alsa_output_plugin.c src/output/alsa_output_plugin.h
|
||||||
libmixer_plugins_a_SOURCES += src/mixer/alsa_mixer_plugin.c
|
libmixer_plugins_a_SOURCES += src/mixer/AlsaMixerPlugin.cxx
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if HAVE_ROAR
|
if HAVE_ROAR
|
||||||
@ -870,7 +869,8 @@ endif
|
|||||||
if HAVE_PULSE
|
if HAVE_PULSE
|
||||||
liboutput_plugins_a_SOURCES += \
|
liboutput_plugins_a_SOURCES += \
|
||||||
src/output/pulse_output_plugin.c src/output/pulse_output_plugin.h
|
src/output/pulse_output_plugin.c src/output/pulse_output_plugin.h
|
||||||
libmixer_plugins_a_SOURCES += src/mixer/pulse_mixer_plugin.c
|
libmixer_plugins_a_SOURCES += \
|
||||||
|
src/mixer/PulseMixerPlugin.cxx src/mixer/PulseMixerPlugin.h
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if HAVE_SHOUT
|
if HAVE_SHOUT
|
||||||
|
@ -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
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -77,7 +77,7 @@ find_fd(GSList **list_r, int fd)
|
|||||||
if (list == NULL)
|
if (list == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
GPollFD *p = list->data;
|
GPollFD *p = (GPollFD *)list->data;
|
||||||
if (p->fd == fd)
|
if (p->fd == fd)
|
||||||
return list_r;
|
return list_r;
|
||||||
|
|
||||||
@ -103,7 +103,7 @@ alsa_mixer_update_fd(struct alsa_mixer_source *source, const struct pollfd *p,
|
|||||||
GSList *found = *found_r;
|
GSList *found = *found_r;
|
||||||
*found_r = found->next;
|
*found_r = found->next;
|
||||||
|
|
||||||
GPollFD *q = found->data;
|
GPollFD *q = (GPollFD *)found->data;
|
||||||
if (q->events != p->events) {
|
if (q->events != p->events) {
|
||||||
/* refresh events */
|
/* refresh events */
|
||||||
g_source_remove_poll(&source->source, q);
|
g_source_remove_poll(&source->source, q);
|
||||||
@ -135,7 +135,7 @@ alsa_mixer_update_fds(struct alsa_mixer_source *source)
|
|||||||
g_free(pfds);
|
g_free(pfds);
|
||||||
|
|
||||||
for (; old != NULL; old = old->next) {
|
for (; old != NULL; old = old->next) {
|
||||||
GPollFD *q = old->data;
|
GPollFD *q = (GPollFD *)old->data;
|
||||||
g_source_remove_poll(&source->source, q);
|
g_source_remove_poll(&source->source, q);
|
||||||
g_free(q);
|
g_free(q);
|
||||||
}
|
}
|
||||||
@ -163,7 +163,7 @@ alsa_mixer_source_check(GSource *_source)
|
|||||||
struct alsa_mixer_source *source = (struct alsa_mixer_source *)_source;
|
struct alsa_mixer_source *source = (struct alsa_mixer_source *)_source;
|
||||||
|
|
||||||
for (const GSList *i = source->fds; i != NULL; i = i->next) {
|
for (const GSList *i = source->fds; i != NULL; i = i->next) {
|
||||||
const GPollFD *poll_fd = i->data;
|
const GPollFD *poll_fd = (GPollFD *)i->data;
|
||||||
if (poll_fd->revents != 0)
|
if (poll_fd->revents != 0)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -194,10 +194,12 @@ alsa_mixer_source_finalize(GSource *_source)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static GSourceFuncs alsa_mixer_source_funcs = {
|
static GSourceFuncs alsa_mixer_source_funcs = {
|
||||||
.prepare = alsa_mixer_source_prepare,
|
alsa_mixer_source_prepare,
|
||||||
.check = alsa_mixer_source_check,
|
alsa_mixer_source_check,
|
||||||
.dispatch = alsa_mixer_source_dispatch,
|
alsa_mixer_source_dispatch,
|
||||||
.finalize = alsa_mixer_source_finalize,
|
alsa_mixer_source_finalize,
|
||||||
|
nullptr,
|
||||||
|
nullptr,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -421,11 +423,11 @@ alsa_mixer_set_volume(struct mixer *mixer, unsigned volume, GError **error_r)
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct mixer_plugin alsa_mixer_plugin = {
|
const struct mixer_plugin alsa_mixer_plugin = {
|
||||||
.init = alsa_mixer_init,
|
alsa_mixer_init,
|
||||||
.finish = alsa_mixer_finish,
|
alsa_mixer_finish,
|
||||||
.open = alsa_mixer_open,
|
alsa_mixer_open,
|
||||||
.close = alsa_mixer_close,
|
alsa_mixer_close,
|
||||||
.get_volume = alsa_mixer_get_volume,
|
alsa_mixer_get_volume,
|
||||||
.set_volume = alsa_mixer_set_volume,
|
alsa_mixer_set_volume,
|
||||||
.global = true,
|
true,
|
||||||
};
|
};
|
@ -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
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -18,7 +18,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "pulse_mixer_plugin.h"
|
#include "PulseMixerPlugin.h"
|
||||||
#include "mixer_api.h"
|
#include "mixer_api.h"
|
||||||
#include "output/pulse_output_plugin.h"
|
#include "output/pulse_output_plugin.h"
|
||||||
#include "conf.h"
|
#include "conf.h"
|
||||||
@ -77,7 +77,7 @@ static void
|
|||||||
pulse_mixer_volume_cb(G_GNUC_UNUSED pa_context *context, const pa_sink_input_info *i,
|
pulse_mixer_volume_cb(G_GNUC_UNUSED pa_context *context, const pa_sink_input_info *i,
|
||||||
int eol, void *userdata)
|
int eol, void *userdata)
|
||||||
{
|
{
|
||||||
struct pulse_mixer *pm = userdata;
|
struct pulse_mixer *pm = (struct pulse_mixer *)userdata;
|
||||||
|
|
||||||
if (eol)
|
if (eol)
|
||||||
return;
|
return;
|
||||||
@ -153,16 +153,15 @@ static struct mixer *
|
|||||||
pulse_mixer_init(void *ao, G_GNUC_UNUSED const struct config_param *param,
|
pulse_mixer_init(void *ao, G_GNUC_UNUSED const struct config_param *param,
|
||||||
GError **error_r)
|
GError **error_r)
|
||||||
{
|
{
|
||||||
struct pulse_mixer *pm;
|
struct pulse_output *po = (struct pulse_output *)ao;
|
||||||
struct pulse_output *po = ao;
|
|
||||||
|
|
||||||
if (ao == NULL) {
|
if (ao == NULL) {
|
||||||
g_set_error(error_r, pulse_mixer_quark(), 0,
|
g_set_error(error_r, pulse_mixer_quark(), 0,
|
||||||
"The pulse mixer cannot work without the audio output");
|
"The pulse mixer cannot work without the audio output");
|
||||||
return false;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
pm = g_new(struct pulse_mixer,1);
|
struct pulse_mixer *pm = g_new(struct pulse_mixer,1);
|
||||||
mixer_init(&pm->base, &pulse_mixer_plugin);
|
mixer_init(&pm->base, &pulse_mixer_plugin);
|
||||||
|
|
||||||
pm->online = false;
|
pm->online = false;
|
||||||
@ -229,8 +228,11 @@ pulse_mixer_set_volume(struct mixer *mixer, unsigned volume, GError **error_r)
|
|||||||
}
|
}
|
||||||
|
|
||||||
const struct mixer_plugin pulse_mixer_plugin = {
|
const struct mixer_plugin pulse_mixer_plugin = {
|
||||||
.init = pulse_mixer_init,
|
pulse_mixer_init,
|
||||||
.finish = pulse_mixer_finish,
|
pulse_mixer_finish,
|
||||||
.get_volume = pulse_mixer_get_volume,
|
nullptr,
|
||||||
.set_volume = pulse_mixer_set_volume,
|
nullptr,
|
||||||
|
pulse_mixer_get_volume,
|
||||||
|
pulse_mixer_set_volume,
|
||||||
|
false,
|
||||||
};
|
};
|
@ -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
|
* http://www.musicpd.org
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
@ -26,6 +26,10 @@ struct pulse_mixer;
|
|||||||
struct pa_context;
|
struct pa_context;
|
||||||
struct pa_stream;
|
struct pa_stream;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
void
|
void
|
||||||
pulse_mixer_on_connect(struct pulse_mixer *pm, struct pa_context *context);
|
pulse_mixer_on_connect(struct pulse_mixer *pm, struct pa_context *context);
|
||||||
|
|
||||||
@ -36,4 +40,8 @@ void
|
|||||||
pulse_mixer_on_change(struct pulse_mixer *pm,
|
pulse_mixer_on_change(struct pulse_mixer *pm,
|
||||||
struct pa_context *context, struct pa_stream *stream);
|
struct pa_context *context, struct pa_stream *stream);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
@ -46,7 +46,15 @@ struct mixer {
|
|||||||
bool failed;
|
bool failed;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
void
|
void
|
||||||
mixer_init(struct mixer *mixer, const struct mixer_plugin *plugin);
|
mixer_init(struct mixer *mixer, const struct mixer_plugin *plugin);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
#include "pulse_output_plugin.h"
|
#include "pulse_output_plugin.h"
|
||||||
#include "output_api.h"
|
#include "output_api.h"
|
||||||
#include "mixer_list.h"
|
#include "mixer_list.h"
|
||||||
#include "mixer/pulse_mixer_plugin.h"
|
#include "mixer/PulseMixerPlugin.h"
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
|
@ -30,6 +30,10 @@ struct pa_cvolume;
|
|||||||
|
|
||||||
extern const struct audio_output_plugin pulse_output_plugin;
|
extern const struct audio_output_plugin pulse_output_plugin;
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
void
|
void
|
||||||
pulse_output_lock(struct pulse_output *po);
|
pulse_output_lock(struct pulse_output *po);
|
||||||
|
|
||||||
@ -46,4 +50,8 @@ bool
|
|||||||
pulse_output_set_volume(struct pulse_output *po,
|
pulse_output_set_volume(struct pulse_output *po,
|
||||||
const struct pa_cvolume *volume, GError **error_r);
|
const struct pa_cvolume *volume, GError **error_r);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user