From 75b76ec0ee76220c83df58d6e813deea65e4c8d6 Mon Sep 17 00:00:00 2001 From: Leandro Alonso Date: Thu, 19 Dec 2024 13:34:17 -0300 Subject: [PATCH] Remove [weak self] for watchOS 10 --- .../Public/Refresh/RefreshManager.swift | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/Modules/Server/Sources/PocketCastsServer/Public/Refresh/RefreshManager.swift b/Modules/Server/Sources/PocketCastsServer/Public/Refresh/RefreshManager.swift index 248e3b67c8..a416626b4f 100644 --- a/Modules/Server/Sources/PocketCastsServer/Public/Refresh/RefreshManager.swift +++ b/Modules/Server/Sources/PocketCastsServer/Public/Refresh/RefreshManager.swift @@ -2,6 +2,9 @@ import Foundation import PocketCastsDataModel import PocketCastsUtils import UIKit +#if os(watchOS) + import WatchKit +#endif public class RefreshManager { public static let shared = RefreshManager() @@ -65,6 +68,7 @@ public class RefreshManager { refresh(podcasts: DataManager.sharedManager.allPodcasts(includeUnsubscribed: false)) } + #if !os(watchOS) private func refresh(podcasts: [Podcast], completion: (() -> Void)? = nil) { UserDefaults.standard.set(Date(), forKey: ServerConstants.UserDefaults.lastRefreshStartTime) @@ -78,6 +82,40 @@ public class RefreshManager { } } } + #endif + + #if os(watchOS) + // Watch OS 10 has a very very very weird issue that happened after using Xcode 16: + // if the refresh call uses a [weak self] the system kills the app. + // I'm not entirely sure why that happens but removing the weak part fixes the issue. + // We can safely remove this method once we remove support to watchOS 10. + private func refresh(podcasts: [Podcast], completion: (() -> Void)? = nil) { + UserDefaults.standard.set(Date(), forKey: ServerConstants.UserDefaults.lastRefreshStartTime) + + DispatchQueue.global().async { + let watchOsMajorVersion = WKInterfaceDevice.current().systemVersion.split(separator: ".")[safe: 0] + + if watchOsMajorVersion == "10" { + // Let's not use [weak self] so the app is not killed + MainServerHandler.shared.refresh(podcasts: podcasts) { refreshResponse in + self.processPodcastRefreshResponse(refreshResponse) { _ in + completion?() + } + } + + return + } + + MainServerHandler.shared.refresh(podcasts: podcasts) { [weak self] refreshResponse in + guard let self = self else { return } + + self.processPodcastRefreshResponse(refreshResponse) { _ in + completion?() + } + } + } + } + #endif public func refreshPodcasts(completion: @escaping (RefreshFetchResult) -> Void) { DispatchQueue.global().async {