|
29 | 29 | import java.util.Collections; |
30 | 30 | import java.util.List; |
31 | 31 | import java.util.concurrent.CountDownLatch; |
| 32 | +import java.util.concurrent.Future; |
32 | 33 | import timber.log.Timber; |
33 | 34 |
|
34 | 35 | public class MainActivity extends AppCompatActivity { |
@@ -315,35 +316,51 @@ public void run() { |
315 | 316 | binding.checkForUpdate.setOnClickListener( |
316 | 317 | view -> { |
317 | 318 | Toast.makeText(this, "Checking for updates...", Toast.LENGTH_SHORT).show(); |
318 | | - Sentry.distribution() |
319 | | - .checkForUpdate( |
320 | | - result -> { |
321 | | - runOnUiThread( |
322 | | - () -> { |
323 | | - String message; |
324 | | - if (result instanceof UpdateStatus.NewRelease) { |
325 | | - UpdateStatus.NewRelease newRelease = (UpdateStatus.NewRelease) result; |
326 | | - message = |
327 | | - "Update available: " |
328 | | - + newRelease.getInfo().getBuildVersion() |
329 | | - + " (Build " |
330 | | - + newRelease.getInfo().getBuildNumber() |
331 | | - + ")\nDownload URL: " |
332 | | - + newRelease.getInfo().getDownloadUrl(); |
333 | | - } else if (result instanceof UpdateStatus.UpToDate) { |
334 | | - message = "App is up to date!"; |
335 | | - } else if (result instanceof UpdateStatus.NoNetwork) { |
336 | | - UpdateStatus.NoNetwork noNetwork = (UpdateStatus.NoNetwork) result; |
337 | | - message = "No network connection: " + noNetwork.getMessage(); |
338 | | - } else if (result instanceof UpdateStatus.UpdateError) { |
339 | | - UpdateStatus.UpdateError error = (UpdateStatus.UpdateError) result; |
340 | | - message = "Error checking for updates: " + error.getMessage(); |
341 | | - } else { |
342 | | - message = "Unknown status"; |
343 | | - } |
344 | | - Toast.makeText(this, message, Toast.LENGTH_LONG).show(); |
345 | | - }); |
346 | | - }); |
| 319 | + Future<UpdateStatus> future = Sentry.distribution().checkForUpdate(); |
| 320 | + // In production, convert this to use your preferred async library (RxJava, Coroutines, |
| 321 | + // etc.) |
| 322 | + // This sample uses raw threads and Future.get() for simplicity |
| 323 | + // Process result on background thread, then update UI |
| 324 | + new Thread( |
| 325 | + () -> { |
| 326 | + try { |
| 327 | + UpdateStatus result = future.get(); |
| 328 | + runOnUiThread( |
| 329 | + () -> { |
| 330 | + String message; |
| 331 | + if (result instanceof UpdateStatus.NewRelease) { |
| 332 | + UpdateStatus.NewRelease newRelease = (UpdateStatus.NewRelease) result; |
| 333 | + message = |
| 334 | + "Update available: " |
| 335 | + + newRelease.getInfo().getBuildVersion() |
| 336 | + + " (Build " |
| 337 | + + newRelease.getInfo().getBuildNumber() |
| 338 | + + ")\nDownload URL: " |
| 339 | + + newRelease.getInfo().getDownloadUrl(); |
| 340 | + } else if (result instanceof UpdateStatus.UpToDate) { |
| 341 | + message = "App is up to date!"; |
| 342 | + } else if (result instanceof UpdateStatus.NoNetwork) { |
| 343 | + UpdateStatus.NoNetwork noNetwork = (UpdateStatus.NoNetwork) result; |
| 344 | + message = "No network connection: " + noNetwork.getMessage(); |
| 345 | + } else if (result instanceof UpdateStatus.UpdateError) { |
| 346 | + UpdateStatus.UpdateError error = (UpdateStatus.UpdateError) result; |
| 347 | + message = "Error checking for updates: " + error.getMessage(); |
| 348 | + } else { |
| 349 | + message = "Unknown status"; |
| 350 | + } |
| 351 | + Toast.makeText(this, message, Toast.LENGTH_LONG).show(); |
| 352 | + }); |
| 353 | + } catch (Exception e) { |
| 354 | + runOnUiThread( |
| 355 | + () -> |
| 356 | + Toast.makeText( |
| 357 | + this, |
| 358 | + "Error checking for updates: " + e.getMessage(), |
| 359 | + Toast.LENGTH_LONG) |
| 360 | + .show()); |
| 361 | + } |
| 362 | + }) |
| 363 | + .start(); |
347 | 364 | }); |
348 | 365 |
|
349 | 366 | binding.openCameraActivity.setOnClickListener( |
|
0 commit comments