From 2f6e9b884ca9927d61a9fb3c599ba4556a6cba27 Mon Sep 17 00:00:00 2001 From: Martin Nonnenmacher Date: Tue, 19 Sep 2023 08:42:57 +0200 Subject: [PATCH] feat(migrate): Add path conventions for package configuration files Apply the path conventions from the ort-config repository also to package configuration files. Signed-off-by: Martin Nonnenmacher --- .../migrate/src/main/kotlin/MigrateCommand.kt | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/plugins/commands/migrate/src/main/kotlin/MigrateCommand.kt b/plugins/commands/migrate/src/main/kotlin/MigrateCommand.kt index 18f74de0cef23..2d3c1225e2196 100644 --- a/plugins/commands/migrate/src/main/kotlin/MigrateCommand.kt +++ b/plugins/commands/migrate/src/main/kotlin/MigrateCommand.kt @@ -92,6 +92,7 @@ class MigrateCommand : OrtCommand( } }.toMap() + val configsDir = getCommonParentFile(pkgConfigFiles.keys) candidateFiles -= pkgConfigFiles.keys echo("Skipping ${candidateFiles.size} files of unknown format.") @@ -129,7 +130,18 @@ class MigrateCommand : OrtCommand( } if (configWithFixedId != config) { - configYamlMapper.writeValue(file, configWithFixedId) + val oldPath = file.relativeTo(configsDir).path + val newName = if (configWithFixedId.sourceArtifactUrl != null) "source-artifact" else "vcs" + val newPath = "${configWithFixedId.id.toPath(emptyValue = "_")}/$newName.yml" + val newFile = configsDir.resolve(newPath) + + // TODO: Maybe make this optional to support layouts that do not follow ort-config conventions. + if (newPath != oldPath) { + configsDir.resolve(oldPath).delete() + newFile.parentFile.safeMkdirs() + } + + configYamlMapper.writeValue(newFile, configWithFixedId) } } }