BuildConfiguration information for use in multi-module, or Kotlin Multiplatform common code

component-build-configuration

A small library supporting Kotlin Multiplatform for utilizing BuildConfiguration details
from common code and across modules.

A full list of other kotlin-components projects and their supported Kotlin Multiplatform
frameworks can be found HERE

Get Started

// build.gradle.kts

dependencies {
    implementation("io.matthewnelson.kotlin-components:build-configuration:1")
}

// build.gradle

dependencies {
    implementation "io.matthewnelson.kotlin-components:build-configuration:1"
}

Usage (Android example using Hilt dependency injection)

// module :app

import io.matthewnelson.component.build.configuration.BuildConfiguration

@Module
@InstallIn(SingletonComponent::class)
object AppModule {
    
    @Provides
    @Singleton
    fun provideBuildConfig(): BuildConfiguration =
        BuildConfiguration(
            applicationId = BuildConfig.APPLICATION_ID,
            versionName = BuildConfig.VERSION_NAME,
            versionCode = BuildConfig.VERSION_CODE,
            isDebug = BuildConfig.DEBUG,
            platform = BuildConfiguration.Platform.Android(),
            variant = BuildConfig.BUILD_TYPE // overloaded to be either "debug" or "release" depending on `isDebug`
        )
    
    @Provides
    fun provideMyMultiPlatformClass(
        buildConfiguration: BuildConfiguration
    ): MyMultiPlatformClass =
        MyMultiPlatformClass(buildConfiguration)
}

// module :core (kotlin multiplatform project where class is in commonMain)
class MyMultiPlatformClass(private val config: BuildConfiguration) {
    
    fun doSomethingWithString(string: String): String {
        if (config.isDebug) {
            // do this
        } else {
            // do that
        }
    }
    
    fun doSomethingBasedOnPlatform(string: String) {
        when (config.platform) {
            is Platform.Android -> { /* do something */ }
            is Platform.Jvm -> { /* do something */ }
            is Platform.Js -> { /* do something */ }
            is Platform.Darwin -> { /* do something */ }
            is Platform.Linux -> { /* do something */ }
            is Platform.Mingw -> { /* do something */ }
        }
    }
}

Git

This project utilizes git submodules. You will need to initialize them when
cloning the repository via:

$ git clone --recursive https://github.com/05nelsonm/component-request.git

If you’ve already cloned the repository, run:

$ git checkout master
$ git pull
$ git submodule update --init

In order to keep submodules updated when pulling the latest code, run:

$ git pull --recurse-submodules

GitHub

View Github