project/VersionGenerator.scala (23 lines of code) (raw):

/* * Licensed to the Apache Software Foundation (ASF) under one or more * license agreements; and to You under the Apache License, version 2.0: * * https://www.apache.org/licenses/LICENSE-2.0 * * This file is part of the Apache Pekko project, which was derived from Akka. */ import sbt._ import sbt.Keys._ /** * Generate version.conf and org/apache/pekko/kafka/Version.scala files based on the version setting. * * This was adapted from https://github.com/apache/incubator-pekko/blob/main/project/VersionGenerator.scala */ object VersionGenerator { val settings: Seq[Setting[_]] = inConfig(Compile)( Seq( resourceGenerators += generateVersion(resourceManaged, _ / "version.conf", """|pekko.kafka.version = "%s" |"""), sourceGenerators += generateVersion( sourceManaged, _ / "org" / "apache" / "pekko" / "kafka" / "Version.scala", """|package org.apache.pekko.kafka | |object Version { | val current: String = "%s" |} |"""))) def generateVersion(dir: SettingKey[File], locate: File => File, template: String) = Def.task[Seq[File]] { val file = locate(dir.value) val content = template.stripMargin.format(version.value) if (!file.exists || IO.read(file) != content) IO.write(file, content) Seq(file) } }