mirror of
https://github.com/mamoe/mirai.git
synced 2025-04-25 21:23:55 +08:00
[Review] Remove Channels.kt
This commit is contained in:
parent
1059ab44bc
commit
3c0bc21816
@ -1,134 +0,0 @@
|
||||
/*
|
||||
* Copyright 2019-2020 Mamoe Technologies and contributors.
|
||||
*
|
||||
* 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证.
|
||||
* Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link.
|
||||
*
|
||||
* https://github.com/mamoe/mirai/blob/master/LICENSE
|
||||
*/
|
||||
|
||||
@file:JvmName("Utils")
|
||||
@file:JvmMultifileClass
|
||||
|
||||
package net.mamoe.mirai.utils
|
||||
|
||||
|
||||
import kotlinx.coroutines.io.ByteReadChannel
|
||||
import kotlinx.coroutines.io.ByteWriteChannel
|
||||
import kotlinx.coroutines.io.readAvailable
|
||||
import kotlinx.io.core.Output
|
||||
import kotlinx.serialization.InternalSerializationApi
|
||||
import java.io.OutputStream
|
||||
import kotlin.jvm.JvmMultifileClass
|
||||
import kotlin.jvm.JvmName
|
||||
|
||||
// copyTo
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst]. 不会关闭 [dst]
|
||||
*/
|
||||
@OptIn(InternalSerializationApi::class)
|
||||
@MiraiExperimentalApi
|
||||
public suspend fun ByteReadChannel.copyTo(dst: OutputStream) {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.write(buffer, 0, size)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst]. 不会关闭 [dst]
|
||||
*/
|
||||
@MiraiExperimentalApi
|
||||
public suspend fun ByteReadChannel.copyTo(dst: Output) {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.writeFully(buffer, 0, size)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst]. 不会关闭 [dst]
|
||||
*/
|
||||
@MiraiExperimentalApi
|
||||
public suspend fun ByteReadChannel.copyTo(dst: ByteWriteChannel) {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.writeFully(buffer, 0, size)
|
||||
}
|
||||
}
|
||||
|
||||
// copyAndClose
|
||||
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst], 最终关闭 [dst]
|
||||
*/
|
||||
@MiraiExperimentalApi
|
||||
@OptIn(InternalSerializationApi::class)
|
||||
public suspend fun ByteReadChannel.copyAndClose(dst: OutputStream) { // 在 JVM 这个 API 不是 internal 的
|
||||
try {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.write(buffer, 0, size)
|
||||
}
|
||||
} finally {
|
||||
dst.close()
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst], 最终关闭 [dst]
|
||||
*/
|
||||
@MiraiExperimentalApi
|
||||
public suspend fun ByteReadChannel.copyAndClose(dst: Output) {
|
||||
try {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.writeFully(buffer, 0, size)
|
||||
}
|
||||
} finally {
|
||||
dst.close()
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst], 最终关闭 [dst]
|
||||
*/
|
||||
@MiraiExperimentalApi
|
||||
public suspend fun ByteReadChannel.copyAndClose(dst: ByteWriteChannel) {
|
||||
@Suppress("DuplicatedCode")
|
||||
try {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.writeFully(buffer, 0, size)
|
||||
}
|
||||
} finally {
|
||||
@Suppress("DuplicatedCode")
|
||||
dst.close(null)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 从接收者管道读取所有数据并写入 [dst], 最终关闭 [dst]
|
||||
*/
|
||||
@MiraiExperimentalApi
|
||||
public suspend fun ByteReadChannel.copyAndClose(dst: io.ktor.utils.io.ByteWriteChannel) {
|
||||
@Suppress("DuplicatedCode")
|
||||
try {
|
||||
val buffer = ByteArray(2048)
|
||||
var size: Int
|
||||
while (this.readAvailable(buffer).also { size = it } > 0) {
|
||||
dst.writeFully(buffer, 0, size)
|
||||
}
|
||||
} finally {
|
||||
@Suppress("DuplicatedCode")
|
||||
dst.close(null)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user