From 42a5440a7661d1d283bbdc9fec8f3b66267baae6 Mon Sep 17 00:00:00 2001 From: Yair Morgenstern Date: Fri, 11 Aug 2023 11:52:33 +0300 Subject: [PATCH] Safeguard against errors in establishing the URL connection to Github --- .../unciv/ui/screens/pickerscreens/GitHub.kt | 29 ++++++++++++------- 1 file changed, 18 insertions(+), 11 deletions(-) diff --git a/core/src/com/unciv/ui/screens/pickerscreens/GitHub.kt b/core/src/com/unciv/ui/screens/pickerscreens/GitHub.kt index 389c4681b4..e3ecb14c7c 100644 --- a/core/src/com/unciv/ui/screens/pickerscreens/GitHub.kt +++ b/core/src/com/unciv/ui/screens/pickerscreens/GitHub.kt @@ -46,18 +46,25 @@ object Github { * @return The [InputStream] if successful, `null` otherwise. */ fun download(url: String, action: (HttpURLConnection) -> Unit = {}): InputStream? { - with(URL(url).openConnection() as HttpURLConnection) - { - action(this) - - return try { - inputStream - } catch (ex: Exception) { - Log.error("Exception during GitHub download", ex) - val reader = BufferedReader(InputStreamReader(errorStream)) - Log.error("Message from GitHub: %s", reader.readText()) - null + try { + // Problem type 1 - opening the URL connection + with(URL(url).openConnection() as HttpURLConnection) + { + action(this) + // Problem type 2 - getting the information + try { + return inputStream + } catch (ex: Exception) { + // No error handling, just log the message. + // NOTE that this 'read error stream' CAN ALSO fail, but will be caught by the big try/catch + val reader = BufferedReader(InputStreamReader(errorStream)) + Log.error("Message from GitHub: %s", reader.readText()) + throw ex + } } + } catch (ex: Exception) { + Log.error("Exception during GitHub download", ex) + return null } }