Newer
Older
bremer-ios-app / Pods / Realm / include / RLMSwiftValueStorage.h
yhornisse on 10 Sep 2023 2 KB Initial Commit
////////////////////////////////////////////////////////////////////////////
//
// Copyright 2021 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 <Realm/RLMConstants.h>

RLM_HEADER_AUDIT_BEGIN(nullability, sendability)

@class RLMObjectBase, RLMProperty;

/// This class implements the backing storage for `RealmProperty<>` and `RealmOptional<>`.
/// This class should not be subclassed or used directly.
@interface RLMSwiftValueStorage : NSProxy
- (instancetype)init;
@end
/// Retrieves the value that is stored, or nil if it is empty.
FOUNDATION_EXTERN id _Nullable RLMGetSwiftValueStorage(RLMSwiftValueStorage *);
/// Sets a value on the property this instance represents for an object.
FOUNDATION_EXTERN void RLMSetSwiftValueStorage(RLMSwiftValueStorage *, id _Nullable);

/// Initialises managed accessors on an instance of `RLMSwiftValueStorage`
/// @param parent The enclosing parent object.
/// @param prop The property which this class represents.
FOUNDATION_EXTERN void RLMInitializeManagedSwiftValueStorage(RLMSwiftValueStorage *,
                                                             RLMObjectBase *parent,
                                                             RLMProperty *prop);

/// Initialises unmanaged accessors on an instance of `RLMSwiftValueStorage`
/// @param parent The enclosing parent object.
/// @param prop The property which this class represents.
FOUNDATION_EXTERN void RLMInitializeUnmanagedSwiftValueStorage(RLMSwiftValueStorage *,
                                                               RLMObjectBase *parent,
                                                               RLMProperty *prop);

/// Gets the property name for the RealmProperty instance. This is required for tracing the key path on
/// objects that use the legacy property declaration syntax.
FOUNDATION_EXTERN NSString *RLMSwiftValueStorageGetPropertyName(RLMSwiftValueStorage *);

RLM_HEADER_AUDIT_END(nullability, sendability)