filesbox/app/filesbox_ios/FilesBox/Pods/Realm/include/RLMRealm+Sync.h
2023-09-21 10:53:23 +08:00

57 lines
1.8 KiB
Objective-C

////////////////////////////////////////////////////////////////////////////
//
// Copyright 2017 Realm Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
////////////////////////////////////////////////////////////////////////////
#import <Foundation/Foundation.h>
#import "RLMRealm.h"
@class RLMResults, RLMSyncSession;
/**
A callback used to vend the results of a partial sync fetch.
*/
typedef void(^RLMPartialSyncFetchCallback)(RLMResults * _Nullable results, NSError * _Nullable error);
NS_ASSUME_NONNULL_BEGIN
///
@interface RLMRealm (Sync)
/**
If the Realm is a partially synchronized Realm, fetch and synchronize the objects
of a given object type that match the given query (in string format).
The results will be returned asynchronously in the callback.
Use `-[RLMResults addNotificationBlock:]` to be notified to changes to the set of
synchronized objects.
@warning Partial synchronization is a tech preview. Its APIs are subject to change.
*/
- (void)subscribeToObjects:(Class)type where:(NSString *)query callback:(RLMPartialSyncFetchCallback)callback
__deprecated_msg("Use -[RLMResults subscribe]");
/**
Get the RLMSyncSession used by this Realm. Will be nil if this is not a
synchronized Realm.
*/
@property (nonatomic, nullable, readonly) RLMSyncSession *syncSession;
@end
NS_ASSUME_NONNULL_END