diff --git a/analyzer/src/main/kotlin/Analyzer.kt b/analyzer/src/main/kotlin/Analyzer.kt index 675746fde7d2f..592511e92026f 100644 --- a/analyzer/src/main/kotlin/Analyzer.kt +++ b/analyzer/src/main/kotlin/Analyzer.kt @@ -35,7 +35,7 @@ import org.ossreviewtoolkit.model.Repository import org.ossreviewtoolkit.model.VcsInfo import org.ossreviewtoolkit.model.config.AnalyzerConfiguration import org.ossreviewtoolkit.model.config.RepositoryConfiguration -import org.ossreviewtoolkit.model.readValue +import org.ossreviewtoolkit.model.readValueOrNull import org.ossreviewtoolkit.utils.Environment import org.ossreviewtoolkit.utils.ORT_REPO_CONFIG_FILENAME import org.ossreviewtoolkit.utils.log @@ -57,13 +57,11 @@ class Analyzer(private val config: AnalyzerConfiguration) { val actualRepositoryConfigurationFile = repositoryConfigurationFile ?: absoluteProjectPath.resolve(ORT_REPO_CONFIG_FILENAME) - val repositoryConfiguration = if (actualRepositoryConfigurationFile.isFile) { + val repositoryConfiguration = actualRepositoryConfigurationFile.takeIf { it.isFile }?.let { log.info { "Using configuration file '${actualRepositoryConfigurationFile.absolutePath}'." } - actualRepositoryConfigurationFile.readValue() - } else { - RepositoryConfiguration() - } + actualRepositoryConfigurationFile.readValueOrNull() + } ?: RepositoryConfiguration() log.debug { "Using the following configuration settings:\n$repositoryConfiguration" } diff --git a/analyzer/src/main/kotlin/curation/FilePackageCurationProvider.kt b/analyzer/src/main/kotlin/curation/FilePackageCurationProvider.kt index 31413d541b8cc..a871c8d622030 100644 --- a/analyzer/src/main/kotlin/curation/FilePackageCurationProvider.kt +++ b/analyzer/src/main/kotlin/curation/FilePackageCurationProvider.kt @@ -25,7 +25,7 @@ import org.ossreviewtoolkit.analyzer.PackageCurationProvider import org.ossreviewtoolkit.model.FileFormat import org.ossreviewtoolkit.model.Identifier import org.ossreviewtoolkit.model.PackageCuration -import org.ossreviewtoolkit.model.readValue +import org.ossreviewtoolkit.model.readValueOrDefault /** * A [PackageCurationProvider] that loads [PackageCuration]s from a single file. Supports all file formats specified @@ -33,7 +33,7 @@ import org.ossreviewtoolkit.model.readValue */ class FilePackageCurationProvider(curationFile: File) : PackageCurationProvider { internal val packageCurations: List by lazy { - curationFile.readValue>() + curationFile.readValueOrDefault(emptyList()) } override fun getCurationsFor(pkgId: Identifier) = packageCurations.filter { it.isApplicable(pkgId) } diff --git a/cli/src/main/kotlin/commands/EvaluatorCommand.kt b/cli/src/main/kotlin/commands/EvaluatorCommand.kt index bafe8c356a373..bb5af81416372 100644 --- a/cli/src/main/kotlin/commands/EvaluatorCommand.kt +++ b/cli/src/main/kotlin/commands/EvaluatorCommand.kt @@ -45,9 +45,11 @@ import org.ossreviewtoolkit.GroupTypes.StringType import org.ossreviewtoolkit.evaluator.Evaluator import org.ossreviewtoolkit.model.FileFormat import org.ossreviewtoolkit.model.OrtResult +import org.ossreviewtoolkit.model.PackageCuration import org.ossreviewtoolkit.model.Severity import org.ossreviewtoolkit.model.config.CopyrightGarbage import org.ossreviewtoolkit.model.config.LicenseFilenamePatterns +import org.ossreviewtoolkit.model.config.RepositoryConfiguration import org.ossreviewtoolkit.model.config.createFileArchiver import org.ossreviewtoolkit.model.config.orEmpty import org.ossreviewtoolkit.model.licenses.DefaultLicenseInfoProvider @@ -55,6 +57,7 @@ import org.ossreviewtoolkit.model.licenses.LicenseClassifications import org.ossreviewtoolkit.model.licenses.LicenseInfoResolver import org.ossreviewtoolkit.model.licenses.orEmpty import org.ossreviewtoolkit.model.readValue +import org.ossreviewtoolkit.model.readValueOrDefault import org.ossreviewtoolkit.model.utils.mergeLabels import org.ossreviewtoolkit.model.writeValue import org.ossreviewtoolkit.utils.ORT_COPYRIGHT_GARBAGE_FILENAME @@ -239,11 +242,13 @@ class EvaluatorCommand : CliktCommand(name = "evaluate", help = "Evaluate ORT re } repositoryConfigurationFile?.let { - ortResultInput = ortResultInput?.replaceConfig(it.readValue()) + val config = it.readValueOrDefault(RepositoryConfiguration()) + ortResultInput = ortResultInput?.replaceConfig(config) } packageCurationsFile?.let { - ortResultInput = ortResultInput?.replacePackageCurations(it.readValue()) + val curations = it.readValueOrDefault(emptyList()) + ortResultInput = ortResultInput?.replacePackageCurations(curations) } val finalOrtResult = requireNotNull(ortResultInput) { diff --git a/cli/src/main/kotlin/commands/ReporterCommand.kt b/cli/src/main/kotlin/commands/ReporterCommand.kt index 16ee758347596..8416e0e41c918 100644 --- a/cli/src/main/kotlin/commands/ReporterCommand.kt +++ b/cli/src/main/kotlin/commands/ReporterCommand.kt @@ -45,6 +45,7 @@ import org.ossreviewtoolkit.GlobalOptions import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.config.CopyrightGarbage import org.ossreviewtoolkit.model.config.LicenseFilenamePatterns +import org.ossreviewtoolkit.model.config.RepositoryConfiguration import org.ossreviewtoolkit.model.config.Resolutions import org.ossreviewtoolkit.model.config.createFileArchiver import org.ossreviewtoolkit.model.config.orEmpty @@ -53,6 +54,7 @@ import org.ossreviewtoolkit.model.licenses.LicenseClassifications import org.ossreviewtoolkit.model.licenses.LicenseInfoResolver import org.ossreviewtoolkit.model.licenses.orEmpty import org.ossreviewtoolkit.model.readValue +import org.ossreviewtoolkit.model.readValueOrDefault import org.ossreviewtoolkit.model.utils.DefaultResolutionProvider import org.ossreviewtoolkit.reporter.DefaultLicenseTextProvider import org.ossreviewtoolkit.reporter.HowToFixTextProvider @@ -207,7 +209,8 @@ class ReporterCommand : CliktCommand( } repositoryConfigurationFile?.let { - ortResult = ortResult.replaceConfig(it.readValue()) + val config = it.readValueOrDefault(RepositoryConfiguration()) + ortResult = ortResult.replaceConfig(config) } val resolutionProvider = DefaultResolutionProvider() diff --git a/cli/src/main/kotlin/commands/UploadCurationsCommand.kt b/cli/src/main/kotlin/commands/UploadCurationsCommand.kt index 71f8e068d6564..d3082ddc274f1 100644 --- a/cli/src/main/kotlin/commands/UploadCurationsCommand.kt +++ b/cli/src/main/kotlin/commands/UploadCurationsCommand.kt @@ -48,7 +48,7 @@ import org.ossreviewtoolkit.clients.clearlydefined.ErrorResponse import org.ossreviewtoolkit.clients.clearlydefined.HarvestStatus import org.ossreviewtoolkit.model.PackageCuration import org.ossreviewtoolkit.model.jsonMapper -import org.ossreviewtoolkit.model.readValue +import org.ossreviewtoolkit.model.readValueOrDefault import org.ossreviewtoolkit.model.utils.toClearlyDefinedCoordinates import org.ossreviewtoolkit.model.utils.toClearlyDefinedSourceLocation import org.ossreviewtoolkit.utils.OkHttpClientHelper @@ -95,7 +95,7 @@ class UploadCurationsCommand : CliktCommand( } override fun run() { - val curations = inputFile.readValue>() + val curations = inputFile.readValueOrDefault(emptyList()) val curationsToCoordinates = curations.mapNotNull { curation -> curation.id.toClearlyDefinedCoordinates()?.let { coordinates -> curation to coordinates