Skip to content

Commit

Permalink
Update Lolicon.kt
Browse files Browse the repository at this point in the history
cikiPAD authored Dec 9, 2023
1 parent 246e0da commit d892168
Showing 1 changed file with 26 additions and 68 deletions.
94 changes: 26 additions & 68 deletions src/main/kotlin/command/Lolicon.kt
Original file line number Diff line number Diff line change
@@ -31,10 +31,6 @@ import kotlinx.coroutines.runInterruptible
import kotlinx.coroutines.sync.withLock
import kotlinx.serialization.decodeFromString
import kotlinx.serialization.json.Json
import kotlinx.coroutines.async
import kotlin.system.measureTimeMillis
import kotlinx.coroutines.awaitAll
import kotlinx.coroutines.withContext
import net.mamoe.mirai.console.command.CommandSender
import net.mamoe.mirai.console.command.CommandSenderOnMessage
import net.mamoe.mirai.console.command.CompositeCommand
@@ -650,7 +646,7 @@ object Lolicon : CompositeCommand(
val notificationReceipt = getNotificationReceipt()

if (subject != null && PluginConfig.messageType == PluginConfig.Type.Forward) {
//val allTimeStart = System.currentTimeMillis()
val allTimeStart = System.currentTimeMillis()
val contact = subject as Contact
val imageMsgBuilder = ForwardMessageBuilder(contact)
imageMsgBuilder.displayStrategy = CustomDisplayStrategy
@@ -670,48 +666,32 @@ object Lolicon : CompositeCommand(
}


// val uploadStart = System.currentTimeMillis()
// var onlyUploadTime: Long = 0
// var onlyDownloadTime: Long = 0
// for (imageUrl in imageUrls) {
// runCatching {
// logger.info(imageUrl)
// val oneDownloadTimeStart = System.currentTimeMillis()
// val stream = getImageInputStream(imageUrl)
// onlyDownloadTime += (System.currentTimeMillis()-oneDownloadTimeStart)
// val oneUploadTimeStart = System.currentTimeMillis()
// val image = contact.uploadImage(stream)
// onlyUploadTime += (System.currentTimeMillis()-oneUploadTimeStart)
// imageMsgBuilder.add(contact.bot, image)
// stream
// }.onFailure {
// logger.error(it)
// imageMsgBuilder.add(contact.bot, PlainText(ReplyConfig.networkError))
// }.onSuccess {
// runInterruptible(Dispatchers.IO) {
// it.close()
// }
// }
// }

// val uploadTime = System.currentTimeMillis() - uploadStart



val uploadStart = System.currentTimeMillis()
val onlyUploadTime: Long = 0
val onlyDownloadTime: Long = 0

runCatching {
val imageUrls = // 图像 URL 列表
processImages(imageUrls, contact)
}.onFailure {
logger.error(it)
imageMsgBuilder.add(contact.bot, PlainText(ReplyConfig.networkError))
var onlyUploadTime: Long = 0
var onlyDownloadTime: Long = 0
for (imageUrl in imageUrls) {
runCatching {
logger.info(imageUrl)
val oneDownloadTimeStart = System.currentTimeMillis()
val stream = getImageInputStream(imageUrl)
onlyDownloadTime += (System.currentTimeMillis()-oneDownloadTimeStart)
val oneUploadTimeStart = System.currentTimeMillis()
val image = contact.uploadImage(stream)
onlyUploadTime += (System.currentTimeMillis()-oneUploadTimeStart)
imageMsgBuilder.add(contact.bot, image)
stream
}.onFailure {
logger.error(it)
imageMsgBuilder.add(contact.bot, PlainText(ReplyConfig.networkError))
}.onSuccess {
runInterruptible(Dispatchers.IO) {
it.close()
}
}
}

val totalTime = System.currentTimeMillis() - uploadStart
logger.info("总上传时间:$totalTime 毫秒")
val uploadTime = System.currentTimeMillis() - uploadStart



val imgReceipt = sendMessage(imageMsgBuilder.build())
@@ -723,36 +703,14 @@ object Lolicon : CompositeCommand(
recall(RecallType.IMAGE, imgReceipt, recall)
if (cooldown > 0)
cooldown(subject, cooldown)
//val allTime = System.currentTimeMillis() - allTimeStart;
//logger.info("总共耗时$allTime ms, 调用图片api接口耗时$getUrlTime ms, 下载上传图片总共耗时$uploadTime ms, 下载图片合计耗时$onlyDownloadTime ms, 上传图片合计耗时$onlyUploadTime ms")
val allTime = System.currentTimeMillis() - allTimeStart;
logger.info("总共耗时$allTime ms, 调用图片api接口耗时$getUrlTime ms, 下载上传图片总共耗时$uploadTime ms, 下载图片合计耗时$onlyDownloadTime ms, 上传图片合计耗时$onlyUploadTime ms")
}

}
}


suspend fun processImages(imageUrls: List<String>, contact: Contact) {
val onlyDownloadTime = measureTimeMillis {
val downloadTasks = imageUrls.map { imageUrl ->
async(Dispatchers.IO) {
val stream = getImageInputStream(imageUrl)
val image = contact.uploadImage(stream)
stream.close()
image
}
}
val images = downloadTasks.awaitAll()
images.forEach { image: Image ->
imageMsgBuilder.add(contact.bot, image)
}

}

logger.info("总下载时间:$onlyDownloadTime 毫秒")
}



@SubCommand("setSource", "设置图库")
@Description("设置图库, 详见帮助信息")
suspend fun CommandSenderOnMessage<MessageEvent>.set(type: String = "") {

0 comments on commit d892168

Please sign in to comment.