Kotlin Multiplatform Broadcast
9.48K subscribers
834 photos
53 videos
1.13K links
Новости и фичи Kotlin, а также Kotlin Multiplatform

YouTubе канал: https://youtube.com/androidBroadcast
Compose Multiplatform @compose_broadcast
iOS разработка @ios_broadcast
Новости Android @android_broadcast
Реклама и прочее @android_broadcast_bot
Download Telegram
В ближайшие полгода в Kotlin Multiplatform будет много интересного:

👉 Первый публичный релиз прямого экспорта Kotlin в Swift (возможно, сторонние плагины для этого больше не понадобятся).
👉 Включение по умолчанию Concurrent Mark and Sweep (CMS) GC (быстрее и эффективнее).
👉 Реализация нового поколения формата распространения KMP библиотек (упрощение формата в фокусе).
🔥 Возможность объявлять зависимости KMP проектов в блоке dependency на уровне проекта, а не в DSL Kotlin плагина.
👉 Унификация работы inline функций между всеми стабильными таргетами (сейчас есть отличия в JVM).
👉 Включение инкрементальной компиляции klib артефактов по умолчанию.
👉 Стабилизация кросс-компиляции klib на разных платформах, что улучшит опыт разработчиков, работающих не на Mac.

У KMP даже есть свой дорожная карта разработки.

#kotlin #kmp
👍24
🐘 Планируемые улучшения в Gradle при работе с 🏝 Kotlin

👉 Поддержка Gradle Project Isolation (подробнее об этой функции здесь)
👉 Улучшение отчетов по компиляции Kotlin
👉 Поддержка Declarative Gradle
👉 Улучшение интеграции инструментов Kotlin/Native в Gradle
👉 Выпуск стабильных аргументов компилятора в Gradle DSL для упрощения конфигурации проектов на Kotlin и KMP

#kotlin #gradle
Please open Telegram to view this post
VIEW IN TELEGRAM
👍21
Channel photo updated
Совсем недавно наткнулся на полную официальную доку по API Gradle плагина Kotlin Multiplatform

#kotlin #kmp #документация
👍34
Please open Telegram to view this post
VIEW IN TELEGRAM
👍26
Новое DSL на замену Gradle Application плагина

В Kotlin 2.1.20 появилось новое экспериментальное DSL для замены функций Gradle Application плагин (несовместим с KMP Gradle плагин, начиная с Gradle 8.7)

kotlin {
jvm {
@OptIn(ExperimentalKotlinGradlePluginApi::class)
binaries {
// Configures a JavaExec task named "runJvm"
// and a Gradle distribution for the "main" compilation in this target
executable {
mainClass.set("foo.MainKt")
}

// Configures a JavaExec task named "runJvmAnother"
// and a Gradle distribution for the "main" compilation
executable(KotlinCompilation.MAIN_COMPILATION_NAME, "another") {
// Set a different class
mainClass.set("foo.MainAnotherKt")
}

// Configures a JavaExec task named "runJvmTest"
// and a Gradle distribution for the "test" compilation
executable(KotlinCompilation.TEST_COMPILATION_NAME) {
mainClass.set("foo.MainTestKt")
}

// Configures a JavaExec task named "runJvmTestAnother"
// and a Gradle distribution for the "test" compilation
executable(KotlinCompilation.TEST_COMPILATION_NAME, "another") {
mainClass.set("foo.MainAnotherTestKt")
}
}
}
}


#kotlin #gradle #kmp
👍15
Пример работы нового Common Atomic API из Kotlin 2.1.20

@OptIn(ExperimentalAtomicApi::class)
suspend fun main() {
// Initializes the atomic counter for processed items
var processedItems = AtomicInt(0)
val totalItems = 100
val items = List(totalItems) { "item$it" }
// Splits the items into chunks for processing by multiple coroutines
val chunkSize = 20
val itemChunks = items.chunked(chunkSize)
coroutineScope {
for (chunk in itemChunks) {
launch {
for (item in chunk) {
println("Processing $item in thread ${Thread.currentThread()}")
processedItems += 1 // Increment counter atomically
}
}
}
}


#kotlin
👍33
🏝 Вышла KSP для Kotlin 2.1.20. Обновляйте версию до 2.1.20-1.0.31

#kotlin #ksp
Please open Telegram to view this post
VIEW IN TELEGRAM
👍22
Что нового в UUID из Kotlin Standart Library

UUID (Universally Unique Identifier) – это стандарт для генерации уникальных идентификаторов длиной 128 бит, который широко используется для идентификации объектов в распределенных системах.


🏝 Теперь функция Uuid.parse() поддерживает не только привычный формат с дефисами (hex-and-dash), например, 550e8400-e29b-41d4-a716-446655440000, но и простой шестнадцатеричный формат без дефисов, например, 550e8400e29b41d4a716446655440000.

🏝 Появились явные функции для работы с hex-and-dash форматом:
parseHexDash() – парсинг UUID из формата с дефисами.
toHexDashString() – преобразование UUID в строку с дефисами.

🏝 UUID теперь реализует интерфейс Comparable. Это значит, что UUID можно напрямую сравнивать и сортировать, используя операторы <, > и стандартные функции вроде sorted().

⚠️ Не забывайте, поддержка UUID в стандартной библиотеке пока экспериментальная. Для её использования используйте:
@OptIn(ExperimentalUuidApi::class)
fun main() {
val uuid = Uuid.parse("550e8400e29b41d4a716446655440000")
println(uuid.toHexDashString())

val sortedUuids = listOf(
uuid,
Uuid.parse("780e8400e29b41d4a716446655440005"),
Uuid.parse("5ab88400e29b41d4a716446655440076")
).sorted()

println(sortedUuids)
}


#kotlin
Please open Telegram to view this post
VIEW IN TELEGRAM
👍53
🏝 Как в Kotlin Multiplatform открыть ссылку в системном браузере

// Kotlin Common Code
expect fun openInBrowser(
url: String,
completionHandler: (Boolean) -> Unit = {}
)

// Kotlin iOS Common
actual fun openInBrowser(
url: String,
completionHandler: (Boolean) -> Unit
) {
NSURL.URLWithString(url)?.let {
UIApplication.sharedApplication.openURL(
url = it,
options = emptyMap<Any?, Any>(),
completionHandler = completionHandler
)
}
}

actual fun openInBrowser(
url: String,
completionHandler: (Boolean) -> Unit
) {
val result = try {
context.startActivity(
Intent(Intent.ACTION_VIEW, Uri.parse(url))
.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK)
true
} catch (_: ActivityNotFoundException) {
false
}
completionHandler(result)
}

// Kotlin JVM Desktop Common
actual fun openInBrowser(
url: String,
completionHandler: (Boolean) -> Unit
) {
with(Desktop.getDesktop()) {
val result = if (isSupported(Desktop.Action.BROWSE)) {
try {
browse(URI.create(url))
true
} catch (e: IOException) {
false
} catch (e: SecurityException) {
false
}
} else false
completionHandler(result)
}
}


Источник тут

#kmp #kotlin
Please open Telegram to view this post
VIEW IN TELEGRAM
👍40
Вышла KotlinX Serialization 1.8.1 с исправлениями багов и минорными улучшениями. Также обновили Kotlin до 2.1.20

#kotlin
👍17
💉 Вышел Koin 4.0.4 с исправлениями багов и пометили Deprecated методы, нерекомендуемые для использования

#kotlin #di #koin
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8
Media is too big
VIEW IN TELEGRAM
📹 Using Platform-Specific APIs in KMP Apps (12м)

Хотите узнать, как использовать платформозависимые API в своих приложениях Kotlin Multiplatform (KMP) или запутались в связанных с этим лучших практиках?

В этом видео мы расскажует об использования механизма expect/actual для создания отличных приложений на KMP.

#kmp #kotlin #jetbrains
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10
‼️🏝 KMP Разработчики не обновляйте XCode до 16.3

В Kotlin 2.1.20 несовместим со свежей версий XCode, поддержка будет в Kotlin 2.1.21. Отложите обновление!

#kotlin #kmp #xcode
Please open Telegram to view this post
VIEW IN TELEGRAM
👍23
Разработчики, работающие с Kotlin и WebAssembly, обратите внимание! В Kotlin 2.1.20 добавили поддержкой DWARF - технологии, которая позволяет выполнять отладку кода пошагово в WASM-виртуальной машине и инспектировать значения переменных.

#kotlin #wasm
👍18
🏝 Ускорение работы Kotlin/Native 🚀

В Kotlin 2.1.20 добавили экспериментальную новый проход inline оптимизации, который по тестам JetBrains ускоряет работу кода в runtime на 9.5%

Чтобы попробовать надо передать компилятору опцию
-Xbinary=preCodegenInlineThreshold=40


#kotlin #native #производительность
Please open Telegram to view this post
VIEW IN TELEGRAM
👍42
Metro - Новый DI фреймворк на чистом Kotlin (ещё в разработке)

@DependencyGraph
interface AppGraph {
val httpClient: HttpClient

@Provides
private fun provideFileSystem(): FileSystem = FileSystem.SYSTEM
}

@Inject
class HttpClient(private val fileSystem: FileSystem)

@Inject
@Composable
fun App(circuit: Circuit)


#kotlin #di #ksp
👍35
Вышла KotlinX Coroutines 1.10.2 с исправлением багов

#kotlin #coroutines
👍26