therealbluepandabear
03/02/2021, 5:20 AMfun main() {
    val capitalsService: CapitalsService = CapitalsServiceImpl(CapitalsRepositoryImpl())
    capitalsService.getCapitals()
}
interface CapitalsService {
    fun getCapitals(): List<Capital>
}
class CapitalsServiceImpl(private val capitalsRepository: CapitalsRepository) : CapitalsService {
    override fun getCapitals(): List<Capital> = capitalsRepository.getCapitals()
}
interface CapitalsRepository {
    fun getCapitals(): List<Capital>
}
class CapitalsRepositoryImpl : CapitalsRepository {
    override fun getCapitals() = listOf(Capital("Paris", Country("France", "Europe", 67399000), 2175601))
}
data class Country(val countryName: String?, val continent: String?, val population: Int?)
data class Capital(val cityName: String?, val capitalOf: Country?, val population: Int?)Matteo Mirk
03/02/2021, 8:53 AMJoel
03/02/2021, 3:25 PMs/fun getCapitals(): List<Capital>/val capitals: List<Capital>capitalsval capitals = listOf(...)Joel
03/02/2021, 3:26 PMIterableListDmitry Kandalov
03/05/2021, 9:26 AMJoel
03/05/2021, 3:04 PMImplDefaultIThingMatteo Mirk
03/05/2021, 3:20 PMCapitalsConstantCapitals, HttpCapitals, FileCapitalsDmitry Kandalov
03/05/2021, 3:48 PMStubCapitalsRepositoryInMemoryCapitalsRepositoryDbCapitalsRepositoryinvoke()interface Foo {
    fun bar()
    
    companion object {
        operator fun invoke() = object : Foo {
            override fun bar() = 123
        }
    }
}