forked from eden-emu/eden
		
	audio_core: SelectSink should default to auto if sink_id is invalid
This commit is contained in:
		
							parent
							
								
									3fab1ddf64
								
							
						
					
					
						commit
						b5cfe1d2f4
					
				
					 1 changed files with 7 additions and 12 deletions
				
			
		|  | @ -56,22 +56,17 @@ void AddAddressSpace(Kernel::VMManager& address_space) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SelectSink(std::string sink_id) { | void SelectSink(std::string sink_id) { | ||||||
|     if (sink_id == "auto") { |  | ||||||
|         // Auto-select.
 |  | ||||||
|         // g_sink_details is ordered in terms of desirability, with the best choice at the front.
 |  | ||||||
|         const auto& sink_detail = g_sink_details.front(); |  | ||||||
|         DSP::HLE::SetSink(sink_detail.factory()); |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     auto iter = |     auto iter = | ||||||
|         std::find_if(g_sink_details.begin(), g_sink_details.end(), |         std::find_if(g_sink_details.begin(), g_sink_details.end(), | ||||||
|                      [sink_id](const auto& sink_detail) { return sink_detail.id == sink_id; }); |                      [sink_id](const auto& sink_detail) { return sink_detail.id == sink_id; }); | ||||||
| 
 | 
 | ||||||
|     if (iter == g_sink_details.end()) { |     if (sink_id == "auto" || iter == g_sink_details.end()) { | ||||||
|         LOG_ERROR(Audio, "AudioCore::SelectSink given invalid sink_id"); |         if (sink_id != "auto") { | ||||||
|         DSP::HLE::SetSink(std::make_unique<NullSink>()); |             LOG_ERROR(Audio, "AudioCore::SelectSink given invalid sink_id %s", sink_id.c_str()); | ||||||
|         return; |         } | ||||||
|  |         // Auto-select.
 | ||||||
|  |         // g_sink_details is ordered in terms of desirability, with the best choice at the front.
 | ||||||
|  |         iter = g_sink_details.begin(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     DSP::HLE::SetSink(iter->factory()); |     DSP::HLE::SetSink(iter->factory()); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 MerryMage
						MerryMage