forked from eden-emu/eden
		
	android: Fix game content installer
Before this would run on the main thread and freeze the device. Additionally this fixes the result dialog not appearing if a config change happens during the installation by getting the activity's fragment manager when needed.
This commit is contained in:
		
							parent
							
								
									d833fc383d
								
							
						
					
					
						commit
						50d4e0f4f7
					
				
					 2 changed files with 80 additions and 85 deletions
				
			
		|  | @ -34,7 +34,7 @@ class IndeterminateProgressDialogFragment : DialogFragment() { | |||
|                 when (val result = taskViewModel.result.value) { | ||||
|                     is String -> Toast.makeText(requireContext(), result, Toast.LENGTH_LONG).show() | ||||
|                     is MessageDialogFragment -> result.show( | ||||
|                         parentFragmentManager, | ||||
|                         requireActivity().supportFragmentManager, | ||||
|                         MessageDialogFragment.TAG | ||||
|                     ) | ||||
|                 } | ||||
|  |  | |||
|  | @ -501,96 +501,91 @@ class MainActivity : AppCompatActivity(), ThemeProvider { | |||
|                 var errorBaseGame = 0 | ||||
|                 var errorExtension = 0 | ||||
|                 var errorOther = 0 | ||||
|                 var errorTotal = 0 | ||||
|                 lifecycleScope.launch { | ||||
|                     documents.forEach { | ||||
|                         when (NativeLibrary.installFileToNand(it.toString())) { | ||||
|                             NativeLibrary.InstallFileToNandResult.Success -> { | ||||
|                                 installSuccess += 1 | ||||
|                             } | ||||
| 
 | ||||
|                             NativeLibrary.InstallFileToNandResult.SuccessFileOverwritten -> { | ||||
|                                 installOverwrite += 1 | ||||
|                             } | ||||
| 
 | ||||
|                             NativeLibrary.InstallFileToNandResult.ErrorBaseGame -> { | ||||
|                                 errorBaseGame += 1 | ||||
|                             } | ||||
| 
 | ||||
|                             NativeLibrary.InstallFileToNandResult.ErrorFilenameExtension -> { | ||||
|                                 errorExtension += 1 | ||||
|                             } | ||||
| 
 | ||||
|                             else -> { | ||||
|                                 errorOther += 1 | ||||
|                             } | ||||
|                 documents.forEach { | ||||
|                     when (NativeLibrary.installFileToNand(it.toString())) { | ||||
|                         NativeLibrary.InstallFileToNandResult.Success -> { | ||||
|                             installSuccess += 1 | ||||
|                         } | ||||
|                     } | ||||
|                     withContext(Dispatchers.Main) { | ||||
|                         val separator = System.getProperty("line.separator") ?: "\n" | ||||
|                         val installResult = StringBuilder() | ||||
|                         if (installSuccess > 0) { | ||||
|                             installResult.append( | ||||
|                                 getString( | ||||
|                                     R.string.install_game_content_success_install, | ||||
|                                     installSuccess | ||||
|                                 ) | ||||
|                             ) | ||||
|                             installResult.append(separator) | ||||
| 
 | ||||
|                         NativeLibrary.InstallFileToNandResult.SuccessFileOverwritten -> { | ||||
|                             installOverwrite += 1 | ||||
|                         } | ||||
|                         if (installOverwrite > 0) { | ||||
|                             installResult.append( | ||||
|                                 getString( | ||||
|                                     R.string.install_game_content_success_overwrite, | ||||
|                                     installOverwrite | ||||
|                                 ) | ||||
|                             ) | ||||
|                             installResult.append(separator) | ||||
| 
 | ||||
|                         NativeLibrary.InstallFileToNandResult.ErrorBaseGame -> { | ||||
|                             errorBaseGame += 1 | ||||
|                         } | ||||
|                         errorTotal = errorBaseGame + errorExtension + errorOther | ||||
|                         if (errorTotal > 0) { | ||||
|                             installResult.append(separator) | ||||
|                             installResult.append( | ||||
|                                 getString( | ||||
|                                     R.string.install_game_content_failed_count, | ||||
|                                     errorTotal | ||||
|                                 ) | ||||
|                             ) | ||||
|                             installResult.append(separator) | ||||
|                             if (errorBaseGame > 0) { | ||||
|                                 installResult.append(separator) | ||||
|                                 installResult.append( | ||||
|                                     getString(R.string.install_game_content_failure_base) | ||||
|                                 ) | ||||
|                                 installResult.append(separator) | ||||
|                             } | ||||
|                             if (errorExtension > 0) { | ||||
|                                 installResult.append(separator) | ||||
|                                 installResult.append( | ||||
|                                     getString(R.string.install_game_content_failure_file_extension) | ||||
|                                 ) | ||||
|                                 installResult.append(separator) | ||||
|                             } | ||||
|                             if (errorOther > 0) { | ||||
|                                 installResult.append( | ||||
|                                     getString(R.string.install_game_content_failure_description) | ||||
|                                 ) | ||||
|                                 installResult.append(separator) | ||||
|                             } | ||||
|                             MessageDialogFragment.newInstance( | ||||
|                                 titleId = R.string.install_game_content_failure, | ||||
|                                 descriptionString = installResult.toString().trim(), | ||||
|                                 helpLinkId = R.string.install_game_content_help_link | ||||
|                             ).show(supportFragmentManager, MessageDialogFragment.TAG) | ||||
|                         } else { | ||||
|                             MessageDialogFragment.newInstance( | ||||
|                                 titleId = R.string.install_game_content_success, | ||||
|                                 descriptionString = installResult.toString().trim() | ||||
|                             ).show(supportFragmentManager, MessageDialogFragment.TAG) | ||||
| 
 | ||||
|                         NativeLibrary.InstallFileToNandResult.ErrorFilenameExtension -> { | ||||
|                             errorExtension += 1 | ||||
|                         } | ||||
| 
 | ||||
|                         else -> { | ||||
|                             errorOther += 1 | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|                 return@newInstance installSuccess + installOverwrite + errorTotal | ||||
| 
 | ||||
|                 val separator = System.getProperty("line.separator") ?: "\n" | ||||
|                 val installResult = StringBuilder() | ||||
|                 if (installSuccess > 0) { | ||||
|                     installResult.append( | ||||
|                         getString( | ||||
|                             R.string.install_game_content_success_install, | ||||
|                             installSuccess | ||||
|                         ) | ||||
|                     ) | ||||
|                     installResult.append(separator) | ||||
|                 } | ||||
|                 if (installOverwrite > 0) { | ||||
|                     installResult.append( | ||||
|                         getString( | ||||
|                             R.string.install_game_content_success_overwrite, | ||||
|                             installOverwrite | ||||
|                         ) | ||||
|                     ) | ||||
|                     installResult.append(separator) | ||||
|                 } | ||||
|                 val errorTotal: Int = errorBaseGame + errorExtension + errorOther | ||||
|                 if (errorTotal > 0) { | ||||
|                     installResult.append(separator) | ||||
|                     installResult.append( | ||||
|                         getString( | ||||
|                             R.string.install_game_content_failed_count, | ||||
|                             errorTotal | ||||
|                         ) | ||||
|                     ) | ||||
|                     installResult.append(separator) | ||||
|                     if (errorBaseGame > 0) { | ||||
|                         installResult.append(separator) | ||||
|                         installResult.append( | ||||
|                             getString(R.string.install_game_content_failure_base) | ||||
|                         ) | ||||
|                         installResult.append(separator) | ||||
|                     } | ||||
|                     if (errorExtension > 0) { | ||||
|                         installResult.append(separator) | ||||
|                         installResult.append( | ||||
|                             getString(R.string.install_game_content_failure_file_extension) | ||||
|                         ) | ||||
|                         installResult.append(separator) | ||||
|                     } | ||||
|                     if (errorOther > 0) { | ||||
|                         installResult.append( | ||||
|                             getString(R.string.install_game_content_failure_description) | ||||
|                         ) | ||||
|                         installResult.append(separator) | ||||
|                     } | ||||
|                     return@newInstance MessageDialogFragment.newInstance( | ||||
|                         titleId = R.string.install_game_content_failure, | ||||
|                         descriptionString = installResult.toString().trim(), | ||||
|                         helpLinkId = R.string.install_game_content_help_link | ||||
|                     ) | ||||
|                 } else { | ||||
|                     return@newInstance MessageDialogFragment.newInstance( | ||||
|                         titleId = R.string.install_game_content_success, | ||||
|                         descriptionString = installResult.toString().trim() | ||||
|                     ) | ||||
|                 } | ||||
|             }.show(supportFragmentManager, IndeterminateProgressDialogFragment.TAG) | ||||
|         } | ||||
|     } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Charles Lombardo
						Charles Lombardo