mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-26 01:30:15 +00:00 
			
		
		
		
	experimentally add support of natives
This commit is contained in:
		| @@ -13,7 +13,7 @@ ktor = "2.2.4" | |||||||
| ksp = "1.8.10-1.0.9" | ksp = "1.8.10-1.0.9" | ||||||
| kotlin-poet = "1.12.0" | kotlin-poet = "1.12.0" | ||||||
|  |  | ||||||
| microutils = "0.17.5" | microutils = "0.17.6-branch_0.17.6-build419" | ||||||
|  |  | ||||||
| github-release-plugin = "2.4.1" | github-release-plugin = "2.4.1" | ||||||
| dokka = "1.8.10" | dokka = "1.8.10" | ||||||
|   | |||||||
| @@ -13,6 +13,8 @@ kotlin { | |||||||
|         browser() |         browser() | ||||||
|         nodejs() |         nodejs() | ||||||
|     } |     } | ||||||
|  |     linuxX64() | ||||||
|  |     mingwX64() | ||||||
|  |  | ||||||
|     sourceSets { |     sourceSets { | ||||||
|         commonMain { |         commonMain { | ||||||
|   | |||||||
| @@ -0,0 +1,6 @@ | |||||||
|  | package dev.inmo.tgbotapi.extensions.behaviour_builder | ||||||
|  |  | ||||||
|  | import kotlinx.coroutines.CoroutineScope | ||||||
|  | import kotlinx.coroutines.Dispatchers | ||||||
|  |  | ||||||
|  | actual var defaultCoroutineScopeProvider: () -> CoroutineScope = { CoroutineScope(Dispatchers.Default) } | ||||||
| @@ -0,0 +1,6 @@ | |||||||
|  | package dev.inmo.tgbotapi.extensions.behaviour_builder | ||||||
|  |  | ||||||
|  | import kotlinx.coroutines.CoroutineScope | ||||||
|  | import kotlinx.coroutines.Dispatchers | ||||||
|  |  | ||||||
|  | actual var defaultCoroutineScopeProvider: () -> CoroutineScope = { CoroutineScope(Dispatchers.Default) } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | package dev.inmo.tgbotapi.requests.abstracts | ||||||
|  |  | ||||||
|  | import dev.inmo.micro_utils.common.MPPFile | ||||||
|  | import dev.inmo.micro_utils.ktor.common.input | ||||||
|  | import dev.inmo.tgbotapi.requests.abstracts.MultipartFile | ||||||
|  |  | ||||||
|  | actual fun MPPFile.asMultipartFile(): MultipartFile = MultipartFile(this.name) { | ||||||
|  |     input() | ||||||
|  | } | ||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | package dev.inmo.tgbotapi.utils | ||||||
|  |  | ||||||
|  | import io.ktor.utils.io.ByteReadChannel | ||||||
|  | import io.ktor.utils.io.core.Input | ||||||
|  | import io.ktor.utils.io.readRemaining | ||||||
|  |  | ||||||
|  | actual suspend fun ByteReadChannel.asInput(): Input = readRemaining() | ||||||
| @@ -0,0 +1,11 @@ | |||||||
|  | package dev.inmo.tgbotapi.utils | ||||||
|  |  | ||||||
|  | import kotlinx.serialization.Serializable | ||||||
|  |  | ||||||
|  | //actual typealias MimeType = MimeType | ||||||
|  |  | ||||||
|  | @Serializable(MimeTypeSerializer::class) | ||||||
|  | actual data class MimeType( | ||||||
|  |     actual val raw: String | ||||||
|  | ) | ||||||
|  | internal actual fun createMimeType(raw: String): MimeType = MimeType(raw) | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | package dev.inmo.tgbotapi.requests.abstracts | ||||||
|  |  | ||||||
|  | import dev.inmo.micro_utils.common.MPPFile | ||||||
|  | import dev.inmo.micro_utils.ktor.common.input | ||||||
|  | import dev.inmo.tgbotapi.requests.abstracts.MultipartFile | ||||||
|  |  | ||||||
|  | actual fun MPPFile.asMultipartFile(): MultipartFile = MultipartFile(this.name) { | ||||||
|  |     input() | ||||||
|  | } | ||||||
| @@ -0,0 +1,7 @@ | |||||||
|  | package dev.inmo.tgbotapi.utils | ||||||
|  |  | ||||||
|  | import io.ktor.utils.io.ByteReadChannel | ||||||
|  | import io.ktor.utils.io.core.Input | ||||||
|  | import io.ktor.utils.io.readRemaining | ||||||
|  |  | ||||||
|  | actual suspend fun ByteReadChannel.asInput(): Input = readRemaining() | ||||||
| @@ -0,0 +1,11 @@ | |||||||
|  | package dev.inmo.tgbotapi.utils | ||||||
|  |  | ||||||
|  | import kotlinx.serialization.Serializable | ||||||
|  |  | ||||||
|  | //actual typealias MimeType = MimeType | ||||||
|  |  | ||||||
|  | @Serializable(MimeTypeSerializer::class) | ||||||
|  | actual data class MimeType( | ||||||
|  |     actual val raw: String | ||||||
|  | ) | ||||||
|  | internal actual fun createMimeType(raw: String): MimeType = MimeType(raw) | ||||||
| @@ -160,6 +160,7 @@ import dev.inmo.tgbotapi.types.chat.member.AdministratorChatMember | |||||||
| import dev.inmo.tgbotapi.types.chat.member.AdministratorChatMemberImpl | import dev.inmo.tgbotapi.types.chat.member.AdministratorChatMemberImpl | ||||||
| import dev.inmo.tgbotapi.types.chat.member.BannedChatMember | import dev.inmo.tgbotapi.types.chat.member.BannedChatMember | ||||||
| import dev.inmo.tgbotapi.types.chat.member.ChatMember | import dev.inmo.tgbotapi.types.chat.member.ChatMember | ||||||
|  | import dev.inmo.tgbotapi.types.chat.member.ChatMemberUpdated | ||||||
| import dev.inmo.tgbotapi.types.chat.member.KickedChatMember | import dev.inmo.tgbotapi.types.chat.member.KickedChatMember | ||||||
| import dev.inmo.tgbotapi.types.chat.member.LeftChatMember | import dev.inmo.tgbotapi.types.chat.member.LeftChatMember | ||||||
| import dev.inmo.tgbotapi.types.chat.member.LeftChatMemberImpl | import dev.inmo.tgbotapi.types.chat.member.LeftChatMemberImpl | ||||||
| @@ -659,6 +660,15 @@ public inline fun WithUser.chatMemberOrThrow(): ChatMember = this as | |||||||
| public inline fun <T> WithUser.ifChatMember(block: (ChatMember) -> T): T? = chatMemberOrNull() | public inline fun <T> WithUser.ifChatMember(block: (ChatMember) -> T): T? = chatMemberOrNull() | ||||||
|     ?.let(block) |     ?.let(block) | ||||||
|  |  | ||||||
|  | public inline fun WithUser.chatMemberUpdatedOrNull(): ChatMemberUpdated? = this as? | ||||||
|  |     dev.inmo.tgbotapi.types.chat.member.ChatMemberUpdated | ||||||
|  |  | ||||||
|  | public inline fun WithUser.chatMemberUpdatedOrThrow(): ChatMemberUpdated = this as | ||||||
|  |     dev.inmo.tgbotapi.types.chat.member.ChatMemberUpdated | ||||||
|  |  | ||||||
|  | public inline fun <T> WithUser.ifChatMemberUpdated(block: (ChatMemberUpdated) -> T): T? = | ||||||
|  |     chatMemberUpdatedOrNull() ?.let(block) | ||||||
|  |  | ||||||
| public inline fun WithUser.kickedChatMemberOrNull(): KickedChatMember? = this as? | public inline fun WithUser.kickedChatMemberOrNull(): KickedChatMember? = this as? | ||||||
|     dev.inmo.tgbotapi.types.chat.member.KickedChatMember |     dev.inmo.tgbotapi.types.chat.member.KickedChatMember | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user