Skip to content
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

Avoid panic if there is no audio device present #341

Closed
wants to merge 1 commit into from
Closed

Avoid panic if there is no audio device present #341

wants to merge 1 commit into from

Conversation

jngbsn
Copy link
Contributor

@jngbsn jngbsn commented Aug 25, 2020

Fixes #316

@karroffel karroffel added A-Audio Sounds playback and modification C-Code-Quality A section of code that is hard to understand or change C-Feature A new feature, making something new possible labels Aug 25, 2020
let sink = Sink::new(&self.device);
sink.append(Decoder::new(Cursor::new(audio_source.clone())).unwrap());
sink.detach();
if let Some(device) = &self.device {
Copy link
Contributor

@Dispersia Dispersia Aug 26, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I believe this should be handled at a higher level, currently this would hide the reason audio playback isn't occurring. Possibly instead of using rodio::default_output_device, it could add a resource for a selected audio device from rodio::devices, and use that here instead? Then the app developer could handle which audio device to select (or pass it to the user), register a default audio source if the developer didn't select one (so would mimic current behavior), and could display an error up front so its not hidden

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I thought about that when writing this, I was considering this as a quick fix to the default behavior so that someone just trying out the engine doesn't immediately have a panic. I assumed that it would be changed at some point when the audio engine functionality is more fleshed out. Nonetheless the rodio API is changing completely in the next version, currently in master (see #310), so now I'm not sure about this change as it might be best to just wait for that to drop. @cart any thoughts? I might just close this PR if its not needed.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm short term I think its probably best to wait. Medium term once we adapt to the new rodio api, I think we need a way to gracefully handle the following cases:

  1. no audio device present (no crashes, playing sounds results in no output)
  2. audio device changes (no crashes, as soon as new device is ready audio switches to that device).

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe we should add something like a "null audio device".

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That was my thought as well, I'll close this PR for now, that way the initial issue will stay open. #310 has an initial implementation of the new API, could move the conversation over there.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

awesome. thanks!

@jngbsn jngbsn closed this Aug 26, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-Audio Sounds playback and modification C-Code-Quality A section of code that is hard to understand or change C-Feature A new feature, making something new possible
Projects
Status: No status
Development

Successfully merging this pull request may close these issues.

Panic if there is no audio device available
4 participants