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-jvm Show documentation
Show all versions of cinterop-jvm 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:3.0.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 - 2025 Weber Informatics LLC | Privacy Policy