iot-firebase/IoT-iOS/Pods/FirebaseFirestore/Firestore/Source/Public/FIRDocumentChange.h
2020-10-05 10:08:16 +01:00

75 lines
2.5 KiB
Objective-C

/*
* Copyright 2017 Google
*
* 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>
NS_ASSUME_NONNULL_BEGIN
@class FIRQueryDocumentSnapshot;
#if defined(NS_CLOSED_ENUM)
/** An enumeration of document change types. */
typedef NS_CLOSED_ENUM(NSInteger, FIRDocumentChangeType)
#else
/** An enumeration of document change types. */
typedef NS_ENUM(NSInteger, FIRDocumentChangeType)
#endif
{
/** Indicates a new document was added to the set of documents matching the query. */
FIRDocumentChangeTypeAdded,
/** Indicates a document within the query was modified. */
FIRDocumentChangeTypeModified,
/**
* Indicates a document within the query was removed (either deleted or no longer matches
* the query.
*/
FIRDocumentChangeTypeRemoved
} NS_SWIFT_NAME(DocumentChangeType);
/**
* A `FIRDocumentChange` represents a change to the documents matching a query. It contains the
* document affected and the type of change that occurred (added, modified, or removed).
*/
NS_SWIFT_NAME(DocumentChange)
@interface FIRDocumentChange : NSObject
/** :nodoc: */
- (id)init __attribute__((unavailable("FIRDocumentChange cannot be created directly.")));
/** The type of change that occurred (added, modified, or removed). */
@property(nonatomic, readonly) FIRDocumentChangeType type;
/** The document affected by this change. */
@property(nonatomic, strong, readonly) FIRQueryDocumentSnapshot *document;
/**
* The index of the changed document in the result set immediately prior to this FIRDocumentChange
* (i.e. supposing that all prior FIRDocumentChange objects have been applied). NSNotFound for
* FIRDocumentChangeTypeAdded events.
*/
@property(nonatomic, readonly) NSUInteger oldIndex;
/**
* The index of the changed document in the result set immediately after this FIRDocumentChange
* (i.e. supposing that all prior FIRDocumentChange objects and the current FIRDocumentChange object
* have been applied). NSNotFound for FIRDocumentChangeTypeRemoved events.
*/
@property(nonatomic, readonly) NSUInteger newIndex;
@end
NS_ASSUME_NONNULL_END