From 73cc44e9a82ba8089359f33724d4ca6c79abc123 Mon Sep 17 00:00:00 2001 From: Aleh Dzenisiuk Date: Mon, 22 Jan 2024 19:08:52 +0100 Subject: [PATCH] MMMLoadable: add async/await helpers --- MMMLoadable.podspec | 8 ++++---- Sources/MMMLoadable/MMMLoadable.swift | 28 +++++++++++++++++++++++++++ 2 files changed, 32 insertions(+), 4 deletions(-) diff --git a/MMMLoadable.podspec b/MMMLoadable.podspec index 725ddf7..7b29fd2 100644 --- a/MMMLoadable.podspec +++ b/MMMLoadable.podspec @@ -6,7 +6,7 @@ Pod::Spec.new do |s| s.name = "MMMLoadable" - s.version = "2.0.0" + s.version = "2.1.0" s.summary = "A simple model for async calculations" s.description = "#{s.summary}." s.homepage = "https://github.com/mediamonks/#{s.name}" @@ -14,9 +14,9 @@ Pod::Spec.new do |s| s.authors = "MediaMonks" s.source = { :git => "https://github.com/mediamonks/#{s.name}.git", :tag => s.version.to_s } - s.ios.deployment_target = '11.0' - s.watchos.deployment_target = '3.0' - s.tvos.deployment_target = '10.0' + s.ios.deployment_target = '14.0' + s.watchos.deployment_target = '6.0' + s.tvos.deployment_target = '13.0' s.subspec 'ObjC' do |ss| ss.source_files = [ "Sources/#{s.name}ObjC/*.{h,m}" ] diff --git a/Sources/MMMLoadable/MMMLoadable.swift b/Sources/MMMLoadable/MMMLoadable.swift index 350f7d9..0a6389e 100644 --- a/Sources/MMMLoadable/MMMLoadable.swift +++ b/Sources/MMMLoadable/MMMLoadable.swift @@ -31,6 +31,34 @@ extension MMMPureLoadableProtocol { block(self) } } + + /// Waits for the receiver to stop syncing and continues if `isContentsAvailable`; throws otherwise. + public func doneSyncing() async throws { + try await contentsAfterDoneSyncing { _ in } + } + + /// Waits for the receiver to stop syncing; then, if `isContentsAvailable`, returns the result of the given closure; + /// throws otherwise. + public func contentsAfterDoneSyncing(_ grabContents: @escaping (Self) throws -> T) async throws -> T { + try await withCheckedThrowingContinuation { continuation in + DispatchQueue.main.async { + var waiter: MMMSimpleLoadableWaiter? + waiter = MMMSimpleLoadableWaiter.whenDoneSyncing(self) { + do { + if self.isContentsAvailable { + continuation.resume(returning: try grabContents(self)) + } else { + throw self.error ?? NSError(domain: self, message: "Unspecified error") + } + } catch { + continuation.resume(throwing: error) + } + // We need to keep the waiter around while waiting. + _ = waiter + } + } + } + } } /// Forwards all calls in `MMMPureLoadableProtocol` to another object.