Skip to content

Commit

Permalink
fix media provider
Browse files Browse the repository at this point in the history
  • Loading branch information
zzeneg committed Apr 28, 2024
1 parent 0c1611b commit 23abc13
Showing 1 changed file with 30 additions and 29 deletions.
59 changes: 30 additions & 29 deletions src/providers/media/windows.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,43 +15,40 @@ fn get_manager() -> Result<GlobalSystemMediaTransportControlsSessionManager, ()>
.map_err(|e| tracing::error!("Can not get Session Manager: {}", e));
}

fn get_session(manager: &GlobalSystemMediaTransportControlsSessionManager) -> Result<GlobalSystemMediaTransportControlsSession, ()> {
return manager
.GetCurrentSession()
.map_err(|e| tracing::error!("Can not get current Session: {}", e));
}

fn handle_session(
session: &GlobalSystemMediaTransportControlsSession,
data_sender: &mpsc::Sender<Vec<u8>>,
) -> Option<EventRegistrationToken> {
let mut synced_artist = String::new();
let mut synced_title = String::new();
if let Some((artist, title)) = get_media_data(session) {
send_data(DataType::MediaArtist, &artist, &data_sender);
send_data(DataType::MediaTitle, &title, &data_sender);
let mut synced_artist = artist;
let mut synced_title = title;

let data_sender = data_sender.clone();
let session_handler = &TypedEventHandler::new(move |_session: &Option<GlobalSystemMediaTransportControlsSession>, _| {
if let Some((artist, title)) = get_media_data(_session.as_ref().unwrap()) {
if synced_artist != artist {
synced_artist = artist;
send_data(DataType::MediaArtist, &synced_artist, &data_sender);
}
synced_artist = artist;
synced_title = title;
}

if synced_title != title {
synced_title = title;
send_data(DataType::MediaTitle, &synced_title, &data_sender);
}
let data_sender = data_sender.clone();
let session_handler = &TypedEventHandler::new(move |_session: &Option<GlobalSystemMediaTransportControlsSession>, _| {
if let Some((artist, title)) = get_media_data(_session.as_ref().unwrap()) {
if synced_artist != artist {
synced_artist = artist;
send_data(DataType::MediaArtist, &synced_artist, &data_sender);
}

Ok(())
});
if synced_title != title {
synced_title = title;
send_data(DataType::MediaTitle, &synced_title, &data_sender);
}
}

return session.MediaPropertiesChanged(session_handler).ok();
}
Ok(())
});

None
return session
.MediaPropertiesChanged(session_handler)
.map_err(|e| tracing::error!("Can not register MediaPropertiesChanged callback: {}", e))
.ok();
}

fn get_media_data(session: &GlobalSystemMediaTransportControlsSession) -> Option<(String, String)> {
Expand All @@ -63,7 +60,9 @@ fn get_media_data(session: &GlobalSystemMediaTransportControlsSession) -> Option
let artist = media_properties.Artist().unwrap_or_default().to_string();
let title = media_properties.Title().unwrap_or_default().to_string();

return Some((artist, title));
if !artist.is_empty() || !title.is_empty() {
return Some((artist, title));
}
}

None
Expand Down Expand Up @@ -103,12 +102,12 @@ impl Provider for MediaProvider {
let mut session_token: Option<EventRegistrationToken> = None;

if let Ok(manager) = get_manager() {
if let Ok(session) = get_session(&manager) {
if let Some(session) = manager.GetCurrentSession().ok() {
session_token = handle_session(&session, &data_sender);
}

let handler = TypedEventHandler::new(move |_manager: &Option<GlobalSystemMediaTransportControlsSessionManager>, _| {
if let Ok(session) = get_session(_manager.as_ref().unwrap()) {
if let Some(session) = _manager.as_ref().unwrap().GetCurrentSession().ok() {
if let Some(token) = session_token {
let _ = session.RemoveMediaPropertiesChanged(token);
}
Expand All @@ -119,7 +118,9 @@ impl Provider for MediaProvider {
Ok(())
});

let manager_token = manager.CurrentSessionChanged(&handler);
let manager_token = manager
.CurrentSessionChanged(&handler)
.map_err(|e| tracing::error!("Can not register CurrentSessionChanged callback: {}", e));

loop {
if !connected_receiver.try_recv().unwrap_or(true) {
Expand Down

0 comments on commit 23abc13

Please sign in to comment.