mixer/{alsa,pulse}: convert to C++
This commit is contained in:
		| @@ -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 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Max Kellermann
					Max Kellermann