Read from repository configs instead of hardcoding repos/arch for update

This commit is contained in:
2024-11-16 00:30:19 +11:00
parent 1b6883c9df
commit e8d101edb5
4 changed files with 56 additions and 46 deletions

View File

@ -41,25 +41,7 @@ struct DpkSearchCommand: AsyncParsableCommand {
let match: any PatternMatcher
match = try matcher.init(patterns: patterns, ignoreCase: !self.caseSensitive)
let repositories: [String], architectures: [String]
do {
repositories = try await PropertyFile.read(name: "repositories")
} catch {
print("Failed to read repositories: \(error.localizedDescription)")
throw .failure
}
do {
architectures = try await PropertyFile.read(name: "arch")
} catch {
print("Failed to read arch: \(error.localizedDescription)")
throw .failure
}
let localRepositories = repositories.flatMap { repo in
architectures.map { arch in
URL(filePath: ApkIndexRepository(name: repo, arch: arch).localName, directoryHint: .notDirectory)
}
}
let localRepositories = try await RepositoriesConfig().localRepositories
let index: ApkIndex
do {
index = ApkIndex.merge(try localRepositories.map(ApkIndex.init))
@ -75,12 +57,3 @@ struct DpkSearchCommand: AsyncParsableCommand {
}
}
}
struct PropertyFile {
static func read(name: String) async throws -> [String] {
try await URL(filePath: name, directoryHint: .notDirectory).lines
.map { $0.trimmingCharacters(in: .whitespaces) }
.filter { !$0.isEmpty && $0.first != "#" } // Ignore empty & commented lines
.reduce(into: [String]()) { $0.append($1) }
}
}