All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jetbrains.kotlin.container.DefaultImplementation.kt Maven / Gradle / Ivy

There is a newer version: 2.0.20-Beta2
Show newest version
/*
 * Copyright 2010-2017 JetBrains s.r.o.
 *
 * 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 org.jetbrains.kotlin.container

import kotlin.reflect.KClass

/**
 * Use to assist injection to provide a default implementation for a certain component and reduce boilerplate in injector code.
 * Argument class must be a non-abstract component class or a kotlin object implementing target interface.
 * Avoid using when there is no clear 'default' behaviour for a component.
 *
 * NB: DefaultImplementation are *discriminated* during resolution of components, meaning that:
 * - if there is exactly one non-default implementation and zero or several default, non-default will be chosen.
 * - if there is none non-default implementations, default will be chosen
 *
 * Such configurations may arise, for example, for multiplatform modules: consider analyzing JVM+JS module, where JS contributes
 * default implementation of some particular service, and JVM contributes non-default.
 *
 * If you need more fine-grained control of clashes resolution, consider using [PlatformExtensionsClashResolver]
 **/
annotation class DefaultImplementation(val impl: KClass<*>)




© 2015 - 2024 Weber Informatics LLC | Privacy Policy