Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
sschuberth committed Mar 18, 2024
1 parent a705e6a commit cd8b2ad
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 9 deletions.
1 change: 1 addition & 0 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ maven-resolver-transport-http = { module = "org.apache.maven.resolver:maven-reso
maven-resolver-transport-wagon = { module = "org.apache.maven.resolver:maven-resolver-transport-wagon", version.ref = "mavenResolver" }
mockk = { module = "io.mockk:mockk", version.ref = "mockk" }
mordant = { module = "com.github.ajalt.mordant:mordant", version.ref = "mordant" }
mordantCoroutines = { module = "com.github.ajalt.mordant:mordant-coroutines", version.ref = "mordant" }
okhttp = { module = "com.squareup.okhttp3:okhttp", version.ref = "okhttp" }
postgres = { module = "org.postgresql:postgresql", version.ref = "postgres" }
postgresEmbedded = { module = "com.opentable.components:otj-pg-embedded", version.ref = "postgresEmbedded" }
Expand Down
2 changes: 2 additions & 0 deletions plugins/commands/downloader/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -33,4 +33,6 @@ dependencies {

implementation(libs.clikt)
implementation(libs.kotlinx.coroutines)
implementation(libs.mordant)
implementation(libs.mordantCoroutines)
}
53 changes: 44 additions & 9 deletions plugins/commands/downloader/src/main/kotlin/DownloaderCommand.kt
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
package org.ossreviewtoolkit.plugins.commands.downloader

import com.github.ajalt.clikt.core.ProgramResult
import com.github.ajalt.clikt.core.terminal
import com.github.ajalt.clikt.parameters.groups.default
import com.github.ajalt.clikt.parameters.groups.mutuallyExclusiveOptions
import com.github.ajalt.clikt.parameters.groups.required
Expand All @@ -34,14 +35,27 @@ import com.github.ajalt.clikt.parameters.options.split
import com.github.ajalt.clikt.parameters.options.switch
import com.github.ajalt.clikt.parameters.types.enum
import com.github.ajalt.clikt.parameters.types.file
import com.github.ajalt.mordant.animation.coroutines.animateInCoroutine
import com.github.ajalt.mordant.animation.progress.MultiProgressBarAnimation
import com.github.ajalt.mordant.animation.progress.addTask
import com.github.ajalt.mordant.animation.progress.advance
import com.github.ajalt.mordant.rendering.TextAlign
import com.github.ajalt.mordant.widgets.progress.percentage
import com.github.ajalt.mordant.widgets.progress.progressBar
import com.github.ajalt.mordant.widgets.progress.progressBarContextLayout
import com.github.ajalt.mordant.widgets.progress.progressBarLayout
import com.github.ajalt.mordant.widgets.progress.text
import com.github.ajalt.mordant.widgets.progress.timeRemaining

import java.io.File

import kotlin.time.measureTime

import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.ExperimentalCoroutinesApi
import kotlinx.coroutines.async
import kotlinx.coroutines.awaitAll
import kotlinx.coroutines.launch
import kotlinx.coroutines.runBlocking
import kotlinx.coroutines.withContext

Expand Down Expand Up @@ -316,21 +330,42 @@ class DownloaderCommand : OrtCommand(
}
}

@OptIn(ExperimentalCoroutinesApi::class)
private suspend fun downloadAllPackages(
packageDownloadDirs: Map<Package, File>,
failureMessages: MutableList<String>
failureMessages: MutableList<String>,
maxParallelDownloads: Int = 8
) {
withContext(Dispatchers.IO) {
packageDownloadDirs.entries.mapIndexed { index, (pkg, dir) ->
async {
val progress = "${index + 1} of ${packageDownloadDirs.size}"
val parallelDownloads = packageDownloadDirs.size.coerceAtMost(maxParallelDownloads)

val overallLayout = progressBarLayout {
text(if (dryRun) "Verifying" else "Downloading", align = TextAlign.LEFT)
progressBar()
percentage()
timeRemaining()
}

val taskLayout = progressBarContextLayout<Package> {
text(fps = animationFps, align = TextAlign.LEFT) { "> Package '${context.id.toCoordinates()}'..." }
percentage()
}

val progress = MultiProgressBarAnimation(terminal).animateInCoroutine()
val overall = progress.addTask(overallLayout, total = packageDownloadDirs.size.toLong())
val tasks = List(parallelDownloads) { progress.addTask(taskLayout, context = Package.EMPTY, total = 1) }

val verb = if (dryRun) "Verifying" else "Starting"
echo("$verb download for '${pkg.id.toCoordinates()}' ($progress).")
withContext(Dispatchers.IO.limitedParallelism(parallelDownloads)) {
launch { progress.execute() }

downloadPackage(pkg, dir, failureMessages).also {
if (!dryRun) echo("Finished download for ${pkg.id.toCoordinates()} ($progress).")
packageDownloadDirs.entries.mapIndexed { index, (pkg, dir) ->
async {
with(tasks[index % parallelDownloads]) {
update { context = pkg }
downloadPackage(pkg, dir, failureMessages)
advance()
}

overall.advance()
}
}.awaitAll()
}
Expand Down

0 comments on commit cd8b2ad

Please sign in to comment.