/*** This file is part of pavucontrol. Copyright 2006-2008 Lennart Poettering Copyright 2009 Colin Guthrie pavucontrol is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. pavucontrol is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with pavucontrol. If not, see . ***/ #ifdef HAVE_CONFIG_H #include #endif #include "sinkwidget.h" // #include #if HAVE_EXT_DEVICE_RESTORE_API # include # include #endif SinkWidget::SinkWidget(MainWindow *parent) : DeviceWidget(parent, "sink") { #if HAVE_EXT_DEVICE_RESTORE_API uint8_t i = 0; encodings[i].encoding = PA_ENCODING_PCM; encodings[i].widget = encodingFormatPCM; connect(encodings[i].widget, &QCheckBox::toggled, this, &SinkWidget::onEncodingsChange); ++i; encodings[i].encoding = PA_ENCODING_AC3_IEC61937; encodings[i].widget = encodingFormatAC3; connect(encodings[i].widget, &QCheckBox::toggled, this, &SinkWidget::onEncodingsChange); ++i; encodings[i].encoding = PA_ENCODING_EAC3_IEC61937; encodings[i].widget = encodingFormatEAC3; connect(encodings[i].widget, &QCheckBox::toggled, this, &SinkWidget::onEncodingsChange); ++i; encodings[i].encoding = PA_ENCODING_MPEG_IEC61937; encodings[i].widget = encodingFormatMPEG; connect(encodings[i].widget, &QCheckBox::toggled, this, &SinkWidget::onEncodingsChange); ++i; encodings[i].encoding = PA_ENCODING_DTS_IEC61937; encodings[i].widget = encodingFormatDTS; connect(encodings[i].widget, &QCheckBox::toggled, this, &SinkWidget::onEncodingsChange); ++i; encodings[i].encoding = PA_ENCODING_INVALID; encodings[i].widget = encodingFormatAAC; encodings[i].widget->setEnabled(false); #ifdef PA_ENCODING_MPEG2_AAC_IEC61937 if (pa_context_get_server_protocol_version(get_context()) >= 28) { encodings[i].encoding = PA_ENCODING_MPEG2_AAC_IEC61937; connect(encodings[i].widget, &QCheckBox::toggled, this, &SinkWidget::onEncodingsChange); encodings[i].widget->setEnabled(true); } #endif #endif } void SinkWidget::executeVolumeUpdate() { pa_operation* o; if (!(o = pa_context_set_sink_volume_by_index(get_context(), index, &volume, nullptr, nullptr))) { show_error(tr("pa_context_set_sink_volume_by_index() failed").toUtf8().constData()); return; } pa_operation_unref(o); } void SinkWidget::onMuteToggleButton() { DeviceWidget::onMuteToggleButton(); if (updating) return; pa_operation* o; if (!(o = pa_context_set_sink_mute_by_index(get_context(), index, muteToggleButton->isChecked(), nullptr, nullptr))) { show_error(tr("pa_context_set_sink_mute_by_index() failed").toUtf8().constData()); return; } pa_operation_unref(o); } void SinkWidget::onDefaultToggleButton() { pa_operation* o; if (updating) return; if (!(o = pa_context_set_default_sink(get_context(), name.constData(), nullptr, nullptr))) { show_error(tr("pa_context_set_default_sink() failed").toUtf8().constData()); return; } pa_operation_unref(o); update_default_sinks(mpMainWindow); } void SinkWidget::onPortChange() { if (updating) return; int sel = portList->currentIndex(); if (sel != -1) { pa_operation* o; QByteArray port = portList->itemData(sel).toString().toUtf8(); if (!(o = pa_context_set_sink_port_by_index(get_context(), index, port.constData(), nullptr, nullptr))) { show_error(tr("pa_context_set_sink_port_by_index() failed").toUtf8().constData()); return; } pa_operation_unref(o); } } void SinkWidget::setDigital(bool digital) { #if HAVE_EXT_DEVICE_RESTORE_API if (digital) { encodingSelect->show(); advancedOptions->setEnabled(true); } else { /* advancedOptions is disabled by default */ encodingSelect->hide(); } #endif } void SinkWidget::onEncodingsChange() { #if HAVE_EXT_DEVICE_RESTORE_API pa_operation* o; uint8_t n_formats = 0; pa_format_info **formats; if (updating) return; formats = (pa_format_info**)malloc(sizeof(pa_format_info*) * PAVU_NUM_ENCODINGS); for (auto & encoding : encodings) { if (encoding.widget->isChecked()) { formats[n_formats] = pa_format_info_new(); formats[n_formats]->encoding = encoding.encoding; ++n_formats; } } if (!(o = pa_ext_device_restore_save_formats(get_context(), PA_DEVICE_TYPE_SINK, index, n_formats, formats, nullptr, nullptr))) { show_error(tr("pa_ext_device_restore_save_sink_formats() failed").toUtf8().constData()); free(formats); return; } free(formats); pa_operation_unref(o); #endif }