//////////////////////////////////////////////////////////////////////////// // // Copyright 2016 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 #import #import namespace realm { class ObjectSchema; class Schema; class Table; struct Property; } class RLMObservationInfo; @class RLMRealm, RLMSchema, RLMObjectSchema, RLMProperty; NS_ASSUME_NONNULL_BEGIN namespace std { // Add specializations so that NSString can be used as the key for hash containers template<> struct hash { size_t operator()(__unsafe_unretained NSString *const str) const { return [str hash]; } }; template<> struct equal_to { bool operator()(__unsafe_unretained NSString * lhs, __unsafe_unretained NSString *rhs) const { return [lhs isEqualToString:rhs]; } }; } // The per-RLMRealm object schema information which stores the cached table // reference, handles table column lookups, and tracks observed objects class RLMClassInfo { public: RLMClassInfo(RLMRealm *, RLMObjectSchema *, const realm::ObjectSchema *); __unsafe_unretained RLMRealm *const realm; __unsafe_unretained RLMObjectSchema *const rlmObjectSchema; const realm::ObjectSchema *const objectSchema; // Storage for the functionality in RLMObservation for handling indirect // changes to KVO-observed things std::vector observedObjects; // Get the table for this object type. Will return nullptr only if it's a // read-only Realm that is missing the table entirely. realm::Table *_Nullable table() const; // Get the RLMProperty for a given table column, or `nil` if it is a column // not used by the current schema RLMProperty *_Nullable propertyForTableColumn(NSUInteger) const noexcept; // Get the RLMProperty that's used as the primary key, or `nil` if there is // no primary key for the current schema RLMProperty *_Nullable propertyForPrimaryKey() const noexcept; // Get the table column for the given property. The property must be a valid // persisted property. NSUInteger tableColumn(NSString *propertyName) const; NSUInteger tableColumn(RLMProperty *property) const; // Get the info for the target of the link at the given property index. RLMClassInfo &linkTargetType(size_t propertyIndex); // Get the info for the target of the given property RLMClassInfo &linkTargetType(realm::Property const& property); void releaseTable() { m_table = nullptr; } private: mutable realm::Table *_Nullable m_table = nullptr; std::vector m_linkTargets; }; // A per-RLMRealm object schema map which stores RLMClassInfo keyed on the name class RLMSchemaInfo { using impl = std::unordered_map; public: RLMSchemaInfo() = default; RLMSchemaInfo(RLMRealm *realm); RLMSchemaInfo clone(realm::Schema const& source_schema, RLMRealm *target_realm); // Look up by name, throwing if it's not present RLMClassInfo& operator[](NSString *name); impl::iterator begin() noexcept; impl::iterator end() noexcept; impl::const_iterator begin() const noexcept; impl::const_iterator end() const noexcept; private: std::unordered_map m_objects; }; NS_ASSUME_NONNULL_END