output/pipewire: check pw_stream_connect() errors

This commit is contained in:
Max Kellermann 2021-10-20 11:07:46 +02:00
parent 1f780b7209
commit f447b7615e
4 changed files with 105 additions and 8 deletions

View File

@ -0,0 +1,34 @@
/*
* Copyright 2003-2021 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include "Error.hxx"
#include <spa/utils/result.h>
namespace PipeWire {
ErrorCategory error_category;
std::string
ErrorCategory::message(int condition) const
{
return spa_strerror(condition);
}
} // namespace Avahi

View File

@ -0,0 +1,45 @@
/*
* Copyright 2003-2021 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program 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.
*
* This program 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 this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#pragma once
#include <system_error>
struct AvahiClient;
namespace PipeWire {
class ErrorCategory final : public std::error_category {
public:
const char *name() const noexcept override {
return "pipewire";
}
std::string message(int condition) const override;
};
extern ErrorCategory error_category;
inline std::system_error
MakeError(int error, const char *msg) noexcept
{
return std::system_error(error, error_category, msg);
}
} // namespace PipeWire

View File

@ -12,3 +12,17 @@ pipewire_dep = declare_dependency(
# disable it at the command line # disable it at the command line
compile_args: ['-Wno-pedantic'], compile_args: ['-Wno-pedantic'],
) )
pipewire = static_library(
'pipewire',
'Error.cxx',
include_directories: inc,
dependencies: [
pipewire_dep,
],
)
pipewire_dep = declare_dependency(
link_with: pipewire,
dependencies: pipewire_dep,
)

View File

@ -18,6 +18,7 @@
*/ */
#include "PipeWireOutputPlugin.hxx" #include "PipeWireOutputPlugin.hxx"
#include "lib/pipewire/Error.hxx"
#include "lib/pipewire/ThreadLoop.hxx" #include "lib/pipewire/ThreadLoop.hxx"
#include "../OutputAPI.hxx" #include "../OutputAPI.hxx"
#include "../Error.hxx" #include "../Error.hxx"
@ -488,14 +489,17 @@ PipeWireOutput::Open(AudioFormat &audio_format)
params[0] = spa_format_audio_raw_build(&pod_builder, params[0] = spa_format_audio_raw_build(&pod_builder,
SPA_PARAM_EnumFormat, &raw); SPA_PARAM_EnumFormat, &raw);
pw_stream_connect(stream, int error =
PW_DIRECTION_OUTPUT, pw_stream_connect(stream,
target_id, PW_DIRECTION_OUTPUT,
(enum pw_stream_flags)(PW_STREAM_FLAG_AUTOCONNECT | target_id,
PW_STREAM_FLAG_INACTIVE | (enum pw_stream_flags)(PW_STREAM_FLAG_AUTOCONNECT |
PW_STREAM_FLAG_MAP_BUFFERS | PW_STREAM_FLAG_INACTIVE |
PW_STREAM_FLAG_RT_PROCESS), PW_STREAM_FLAG_MAP_BUFFERS |
params, 1); PW_STREAM_FLAG_RT_PROCESS),
params, 1);
if (error < 0)
throw PipeWire::MakeError(error, "Failed to connect stream");
} }
void void