| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- /*
- * 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 "Firestore/Source/Remote/FSTWatchChange.h"
- #include <utility>
- #import "Firestore/Source/Model/FSTDocument.h"
- #include "Firestore/core/src/firebase/firestore/model/document_key.h"
- using firebase::firestore::model::DocumentKey;
- using firebase::firestore::model::TargetId;
- using firebase::firestore::remote::ExistenceFilter;
- NS_ASSUME_NONNULL_BEGIN
- @implementation FSTWatchChange
- @end
- @implementation FSTDocumentWatchChange {
- DocumentKey _documentKey;
- }
- - (instancetype)initWithUpdatedTargetIDs:(NSArray<NSNumber *> *)updatedTargetIDs
- removedTargetIDs:(NSArray<NSNumber *> *)removedTargetIDs
- documentKey:(DocumentKey)documentKey
- document:(nullable FSTMaybeDocument *)document {
- self = [super init];
- if (self) {
- _updatedTargetIDs = updatedTargetIDs;
- _removedTargetIDs = removedTargetIDs;
- _documentKey = std::move(documentKey);
- _document = document;
- }
- return self;
- }
- - (const firebase::firestore::model::DocumentKey &)documentKey {
- return _documentKey;
- }
- - (BOOL)isEqual:(id)other {
- if (other == self) {
- return YES;
- }
- if (![other isMemberOfClass:[FSTDocumentWatchChange class]]) {
- return NO;
- }
- FSTDocumentWatchChange *otherChange = (FSTDocumentWatchChange *)other;
- return [_updatedTargetIDs isEqual:otherChange.updatedTargetIDs] &&
- [_removedTargetIDs isEqual:otherChange.removedTargetIDs] &&
- _documentKey == otherChange.documentKey &&
- (_document == otherChange.document || [_document isEqual:otherChange.document]);
- }
- - (NSUInteger)hash {
- NSUInteger hash = self.updatedTargetIDs.hash;
- hash = hash * 31 + self.removedTargetIDs.hash;
- hash = hash * 31 + self.documentKey.Hash();
- hash = hash * 31 + self.document.hash;
- return hash;
- }
- @end
- @interface FSTExistenceFilterWatchChange ()
- - (instancetype)initWithFilter:(ExistenceFilter)filter
- targetID:(TargetId)targetID NS_DESIGNATED_INITIALIZER;
- @end
- @implementation FSTExistenceFilterWatchChange {
- ExistenceFilter _filter;
- }
- + (instancetype)changeWithFilter:(ExistenceFilter)filter targetID:(TargetId)targetID {
- return [[FSTExistenceFilterWatchChange alloc] initWithFilter:filter targetID:targetID];
- }
- - (instancetype)initWithFilter:(ExistenceFilter)filter targetID:(TargetId)targetID {
- self = [super init];
- if (self) {
- _filter = filter;
- _targetID = targetID;
- }
- return self;
- }
- - (const ExistenceFilter &)filter {
- return _filter;
- }
- - (BOOL)isEqual:(id)other {
- if (other == self) {
- return YES;
- }
- if (![other isMemberOfClass:[FSTExistenceFilterWatchChange class]]) {
- return NO;
- }
- FSTExistenceFilterWatchChange *otherChange = (FSTExistenceFilterWatchChange *)other;
- return _filter == otherChange->_filter && _targetID == otherChange->_targetID;
- }
- - (NSUInteger)hash {
- return _filter.count();
- }
- @end
- @implementation FSTWatchTargetChange
- - (instancetype)initWithState:(FSTWatchTargetChangeState)state
- targetIDs:(NSArray<NSNumber *> *)targetIDs
- resumeToken:(NSData *)resumeToken
- cause:(nullable NSError *)cause {
- self = [super init];
- if (self) {
- _state = state;
- _targetIDs = targetIDs;
- _resumeToken = [resumeToken copy];
- _cause = cause;
- }
- return self;
- }
- - (BOOL)isEqual:(id)other {
- if (other == self) {
- return YES;
- }
- if (![other isMemberOfClass:[FSTWatchTargetChange class]]) {
- return NO;
- }
- FSTWatchTargetChange *otherChange = (FSTWatchTargetChange *)other;
- return _state == otherChange->_state && [_targetIDs isEqual:otherChange->_targetIDs] &&
- [_resumeToken isEqual:otherChange->_resumeToken] &&
- (_cause == otherChange->_cause || [_cause isEqual:otherChange->_cause]);
- }
- - (NSUInteger)hash {
- NSUInteger hash = (NSUInteger)self.state;
- hash = hash * 31 + self.targetIDs.hash;
- hash = hash * 31 + self.resumeToken.hash;
- hash = hash * 31 + self.cause.hash;
- return hash;
- }
- @end
- NS_ASSUME_NONNULL_END
|