RLMSwiftValueStorage.h 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. ////////////////////////////////////////////////////////////////////////////
  2. //
  3. // Copyright 2021 Realm Inc.
  4. //
  5. // Licensed under the Apache License, Version 2.0 (the "License");
  6. // you may not use this file except in compliance with the License.
  7. // You may obtain a copy of the License at
  8. //
  9. // http://www.apache.org/licenses/LICENSE-2.0
  10. //
  11. // Unless required by applicable law or agreed to in writing, software
  12. // distributed under the License is distributed on an "AS IS" BASIS,
  13. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. // See the License for the specific language governing permissions and
  15. // limitations under the License.
  16. //
  17. ////////////////////////////////////////////////////////////////////////////
  18. #import <Foundation/Foundation.h>
  19. #import <Realm/RLMConstants.h>
  20. NS_ASSUME_NONNULL_BEGIN
  21. @class RLMObjectBase, RLMProperty;
  22. /// This class implements the backing storage for `RealmProperty<>` and `RealmOptional<>`.
  23. /// This class should not be subclassed or used directly.
  24. @interface RLMSwiftValueStorage : NSProxy
  25. - (instancetype)init;
  26. @end
  27. /// Retrieves the value that is stored, or nil if it is empty.
  28. FOUNDATION_EXTERN id _Nullable RLMGetSwiftValueStorage(RLMSwiftValueStorage *);
  29. /// Sets a value on the property this instance represents for an object.
  30. FOUNDATION_EXTERN void RLMSetSwiftValueStorage(RLMSwiftValueStorage *, id _Nullable);
  31. /// Initialises managed accessors on an instance of `RLMSwiftValueStorage`
  32. /// @param parent The enclosing parent object.
  33. /// @param prop The property which this class represents.
  34. FOUNDATION_EXTERN void RLMInitializeManagedSwiftValueStorage(RLMSwiftValueStorage *,
  35. RLMObjectBase *parent,
  36. RLMProperty *prop);
  37. /// Initialises unmanaged accessors on an instance of `RLMSwiftValueStorage`
  38. /// @param parent The enclosing parent object.
  39. /// @param prop The property which this class represents.
  40. FOUNDATION_EXTERN void RLMInitializeUnmanagedSwiftValueStorage(RLMSwiftValueStorage *,
  41. RLMObjectBase *parent,
  42. RLMProperty *prop);
  43. /// Gets the property name for the RealmProperty instance. This is required for tracing the key path on
  44. /// objects that use the legacy property declaration syntax.
  45. FOUNDATION_EXTERN NSString *RLMSwiftValueStorageGetPropertyName(RLMSwiftValueStorage *);
  46. NS_ASSUME_NONNULL_END