-
Notifications
You must be signed in to change notification settings - Fork 445
PipeWire implementation #938
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Open
midoriiro
wants to merge
18
commits into
RustAudio:master
Choose a base branch
from
midoriiro:master
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 15 commits
Commits
Show all changes
18 commits
Select commit
Hold shift + click to select a range
bee0c4a
PipeWire implementation
midoriiro f4fce9c
Refactor client implementation/test + replace mpsc with crossbeam cha…
midoriiro b45bab8
Optimize imports
midoriiro 0a541b3
Add testcontainer and some tests depending of server configuration
midoriiro 70643fc
Optimize imports
midoriiro a5a4e87
Add tini as container entrypoint to handle process signal termination…
midoriiro 82dc7a3
Move items to test_utils module. Refactor tests to user containerized…
midoriiro e6838d3
Optimize imports
midoriiro 2b7258a
Replace listener trigger policy by control flow object. That give mor…
midoriiro 101fef5
Testing if listeners are properly released. Avoid server fixture crea…
midoriiro a9212f8
Remove serial_test dependency. All tests a containerized, no need to …
midoriiro ac9f825
Optimize imports
midoriiro e97ec08
Install libpipewire in jobs workflow
midoriiro faf68c6
Fix device stream callback
midoriiro a2f95fa
Better handling how to run tests (local and containers). Better handl…
midoriiro 5118f4a
Remove pipewire sub crates and use pipewire-client external crate
midoriiro 135eb4c
Add PipeWire information in README.md
midoriiro b32afbf
Merge branch 'master' into master
midoriiro File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
/target | ||
/Cargo.lock | ||
target/ | ||
Cargo.lock | ||
.cargo/ | ||
.DS_Store | ||
recorded.wav | ||
|
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
[package] | ||
name = "pipewire-client" | ||
version = "0.1.0" | ||
edition = "2021" | ||
authors = ["Alexis Bekhdadi <[email protected]>"] | ||
description = "PipeWire Client" | ||
repository = "https://github.com/RustAudio/cpal/" | ||
documentation = "" | ||
license = "Apache-2.0" | ||
keywords = ["pipewire", "client"] | ||
|
||
[dependencies] | ||
pipewire = { version = "0.8" } | ||
pipewire-spa-utils = { version = "0.1", path = "../pipewire-spa-utils"} | ||
pipewire-common = { version = "0.1", path = "../pipewire-common" } | ||
serde_json = "1.0" | ||
crossbeam-channel = "0.5" | ||
uuid = { version = "1.12", features = ["v4"] } | ||
tokio = { version = "1", features = ["full"] } | ||
tokio-util = "0.7" | ||
libc = "0.2" | ||
|
||
[dev-dependencies] | ||
rstest = "0.24" | ||
serial_test = "3.2" | ||
ctor = "0.2" | ||
pipewire-test-utils = { version = "0.1", path = "../pipewire-test-utils" } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
use crate::client::api::internal::InternalApi; | ||
use crate::error::Error; | ||
use crate::messages::{MessageRequest, MessageResponse}; | ||
use crate::states::{DefaultAudioNodesState, GlobalObjectState, SettingsState}; | ||
use std::sync::Arc; | ||
|
||
pub struct CoreApi { | ||
pub(crate) api: Arc<InternalApi>, | ||
} | ||
|
||
impl CoreApi { | ||
pub(crate) fn new(api: Arc<InternalApi>) -> Self { | ||
CoreApi { | ||
api, | ||
} | ||
} | ||
|
||
pub(crate) fn check_session_manager_registered(&self) -> Result<(), Error> { | ||
let request = MessageRequest::CheckSessionManagerRegistered; | ||
let response = self.api.send_request(&request); | ||
match response { | ||
Ok(MessageResponse::CheckSessionManagerRegistered{ | ||
session_manager_registered, | ||
error | ||
}) => { | ||
if session_manager_registered { | ||
return Ok(()); | ||
} | ||
Err(error.unwrap()) | ||
}, | ||
Err(value) => Err(value), | ||
Ok(value) => Err(Error { | ||
description: format!("Received unexpected response: {:?}", value), | ||
}), | ||
} | ||
} | ||
|
||
pub fn quit(&self) { | ||
let request = MessageRequest::Quit; | ||
self.api.send_request_without_response(&request).unwrap(); | ||
} | ||
|
||
pub fn get_settings(&self) -> Result<SettingsState, Error> { | ||
let request = MessageRequest::Settings; | ||
let response = self.api.send_request(&request); | ||
match response { | ||
Ok(MessageResponse::Settings(value)) => Ok(value), | ||
Err(value) => Err(value), | ||
Ok(value) => Err(Error { | ||
description: format!("Received unexpected response: {:?}", value), | ||
}), | ||
} | ||
} | ||
|
||
pub(crate) fn get_settings_state(&self) -> Result<GlobalObjectState, Error> { | ||
let request = MessageRequest::SettingsState; | ||
let response = self.api.send_request(&request); | ||
match response { | ||
Ok(MessageResponse::SettingsState(value)) => Ok(value), | ||
Err(value) => Err(value), | ||
Ok(value) => Err(Error { | ||
description: format!("Received unexpected response: {:?}", value), | ||
}), | ||
} | ||
} | ||
|
||
pub fn get_default_audio_nodes(&self) -> Result<DefaultAudioNodesState, Error> { | ||
let request = MessageRequest::DefaultAudioNodes; | ||
let response = self.api.send_request(&request); | ||
match response { | ||
Ok(MessageResponse::DefaultAudioNodes(value)) => Ok(value), | ||
Err(value) => Err(value), | ||
Ok(value) => Err(Error { | ||
description: format!("Received unexpected response: {:?}", value), | ||
}), | ||
} | ||
} | ||
|
||
pub(crate) fn get_default_audio_nodes_state(&self) -> Result<GlobalObjectState, Error> { | ||
let request = MessageRequest::DefaultAudioNodesState; | ||
let response = self.api.send_request(&request); | ||
match response { | ||
Ok(MessageResponse::DefaultAudioNodesState(value)) => Ok(value), | ||
Err(value) => Err(value), | ||
Ok(value) => Err(Error { | ||
description: format!("Received unexpected response: {:?}", value), | ||
}), | ||
} | ||
} | ||
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
use crate::test_utils::fixtures::{isolated_client, shared_client, PipewireTestClient}; | ||
use rstest::rstest; | ||
use serial_test::serial; | ||
|
||
#[rstest] | ||
#[serial] | ||
fn quit(#[from(isolated_client)] client: PipewireTestClient) { | ||
client.core().quit(); | ||
} | ||
|
||
#[rstest] | ||
#[serial] | ||
pub fn settings(#[from(shared_client)] client: PipewireTestClient) { | ||
let settings = client.core().get_settings().unwrap(); | ||
assert_eq!(true, settings.sample_rate > u32::default()); | ||
assert_eq!(true, settings.default_buffer_size > u32::default()); | ||
assert_eq!(true, settings.min_buffer_size > u32::default()); | ||
assert_eq!(true, settings.max_buffer_size > u32::default()); | ||
assert_eq!(true, settings.allowed_sample_rates[0] > u32::default()); | ||
} | ||
|
||
#[rstest] | ||
#[serial] | ||
pub fn default_audio_nodes(#[from(shared_client)] client: PipewireTestClient) { | ||
let default_audio_nodes = client.core().get_default_audio_nodes().unwrap(); | ||
assert_eq!(false, default_audio_nodes.sink.is_empty()); | ||
assert_eq!(false, default_audio_nodes.source.is_empty()); | ||
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
use crate::client::channel::ClientChannel; | ||
use crate::error::Error; | ||
use crate::messages::{MessageRequest, MessageResponse}; | ||
use std::time::Duration; | ||
|
||
pub(crate) struct InternalApi { | ||
pub(crate) channel: ClientChannel<MessageRequest, MessageResponse>, | ||
pub(crate) timeout: Duration | ||
} | ||
|
||
impl InternalApi { | ||
pub(crate) fn new( | ||
channel: ClientChannel<MessageRequest, MessageResponse>, | ||
timeout: Duration | ||
) -> Self { | ||
InternalApi { | ||
channel, | ||
timeout, | ||
} | ||
} | ||
|
||
pub(crate) fn wait_response_with_timeout(&self, timeout: Duration) -> Result<MessageResponse, Error> { | ||
self.channel.receive_timeout(timeout) | ||
} | ||
|
||
pub(crate) fn send_request(&self, request: &MessageRequest) -> Result<MessageResponse, Error> { | ||
let response = self.channel.send(request.clone()); | ||
match response { | ||
Ok(value) => { | ||
match value { | ||
MessageResponse::Error(value) => Err(value), | ||
_ => Ok(value) | ||
} | ||
} | ||
Err(value) => Err(value) | ||
} | ||
} | ||
|
||
pub(crate) fn send_request_without_response(&self, request: &MessageRequest) -> Result<(), Error> { | ||
self.channel.fire(request.clone()).map(move |_| ()) | ||
} | ||
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
mod core; | ||
pub(crate) use core::CoreApi; | ||
#[cfg(test)] | ||
#[path = "core_test.rs"] | ||
mod core_test; | ||
|
||
mod node; | ||
pub(crate) use node::NodeApi; | ||
#[cfg(test)] | ||
#[path = "node_test.rs"] | ||
mod node_test; | ||
|
||
mod stream; | ||
pub(crate) use stream::StreamApi; | ||
#[cfg(test)] | ||
#[path = "stream_test.rs"] | ||
mod stream_test; | ||
|
||
mod internal; | ||
pub(crate) use internal::InternalApi; |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The jack feature was already defined implicitly. This line appears to be redefining it, which could cause confusion. Verify if this is intentional.
Copilot uses AI. Check for mistakes.