commonMain.io.realm.kotlin.internal.interop.Callback.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cinterop Show documentation
Show all versions of cinterop Show documentation
Wrapper for interacting with Realm Kotlin native code. This artifact is not supposed to be consumed directly, but through 'io.realm.kotlin:gradle-plugin:1.13.0' instead.
The newest version!
/*
* Copyright 2020 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.
*/
package io.realm.kotlin.internal.interop
// TODO Could be replace by lambda. See realm_app_config_new networkTransportFactory for example.
interface Callback {
fun onChange(change: T)
}
interface LogCallback {
// Passes core log levels as shorts to avoid unnecessary jumping between the SDK and JNI
fun log(logLevel: Short, categoryValue: String, message: String?)
}
fun interface CompactOnLaunchCallback {
fun invoke(totalBytes: Long, usedBytes: Long): Boolean
}
fun interface MigrationCallback {
fun migrate(
oldRealm: FrozenRealmPointer,
newRealm: LiveRealmPointer,
schema: RealmSchemaPointer
)
}
// The underlying Core implementation can also pass in Realm pointer, but since it is not
// useful during construction, we omit it from this callback as it is only used as a signal.
fun interface DataInitializationCallback {
fun invoke()
}
interface SyncThreadObserver {
// Should return the name of the Java Sync thread.
fun threadName(): String
// Called when the underlying Sync thread is created
fun onCreated()
// Called when the underlying Sync thread is destroyed
fun onDestroyed()
// Called when an error occurred on the underlying Sync thread
fun onError(error: String)
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy