scalaxb.compiler.Config.scala Maven / Gradle / Ivy
/*
* Copyright (c) 2015 e.e d3si9n
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package scalaxb.compiler
import java.io.File
import scala.collection.immutable.{ Map, Set, Seq }
import scala.reflect.ClassTag
case class Config(items: Map[String, ConfigEntry]) {
import Config._
import ConfigEntry._
def values: Vector[ConfigEntry] = items.values.toVector
def packageNames: Map[Option[String], Option[String]] =
(get[PackageNames] getOrElse defaultPackageNames).value
def classPrefix: Option[String] =
get[ClassPrefix] map {_.value}
def classPostfix: Option[String] =
get[ClassPostfix] map {_.value}
def paramPrefix: Option[String] =
get[ParamPrefix] map {_.value}
def attributePrefix: Option[String] =
get[AttributePrefix] map {_.value}
def opOutputWrapperPostfix: String =
(get[OpOutputWrapperPostfix] getOrElse defaultOpOutputWrapperPostfix).value
def outdir: File =
(get[Outdir] getOrElse defaultOutdir).value
def packageDir: Boolean = values contains GeneratePackageDir
def wrappedComplexTypes: List[String] =
(get[WrappedComplexTypes] getOrElse defaultWrappedComplexTypes).value
def prependFamilyName: Boolean = values contains PrependFamilyName
def seperateProtocol: Boolean = values contains SeperateProtocol
def protocolFileName: String =
(get[ProtocolFileName] getOrElse defaultProtocolFileName).value
def protocolPackageName: Option[String] =
(get[ProtocolPackageName] getOrElse defaultProtocolPackageName).value
def defaultNamespace: Option[String] =
(get[DefaultNamespace] getOrElse defaultDefaultNamespace).value
def generateRuntime: Boolean = values contains GenerateRuntime
def generateDispatchClient: Boolean = values contains GenerateDispatchClient
def generateHttp4sClient: Boolean = values contains GenerateHttp4sClient
def generateDispatchAs: Boolean = values contains GenerateDispatchAs
def generateGigahorseClient: Boolean = values contains GenerateGigahorseClient
def contentsSizeLimit: Int =
(get[ContentsSizeLimit] getOrElse defaultContentsSizeLimit).value
def sequenceChunkSize: Int =
(get[SequenceChunkSize] getOrElse defaultSequenceChunkSize).value
def namedAttributes: Boolean = values contains NamedAttributes
def laxAny: Boolean = values contains LaxAny
def httpClientStyle: HttpClientStyle = get[HttpClientStyle] getOrElse HttpClientStyle.Future
def taglessClient: Boolean = httpClientStyle == HttpClientStyle.Tagless
def mapK: Boolean = values contains GenerateMapK
def dispatchVersion: String =
(get[DispatchVersion] getOrElse defaultDispatchVersion).value
def http4sVersion: String =
(get[Http4sVersion] getOrElse defaultHttp4sVersion).value
def gigahorseVersion: String =
(get[GigahorseVersion] getOrElse defaultGigahorseVersion).value
def gigahorseBackend: String =
(get[GigahorseBackend] getOrElse defaultGigahorseBackend).value
def varArg: Boolean = values contains VarArg
def ignoreUnknown: Boolean = values contains IgnoreUnknown
def autoPackages: Boolean = values contains AutoPackages
def generateMutable: Boolean = values contains GenerateMutable
def generateVisitor: Boolean = values contains GenerateVisitor
def generateLens: Boolean = values contains GenerateLens
def capitalizeWords: Boolean = values contains CapitalizeWords
def symbolEncodingStrategy = get[SymbolEncoding.Strategy] getOrElse defaultSymbolEncodingStrategy
def enumNameMaxLength: Int = (get[EnumNameMaxLength] getOrElse defaultEnumNameMaxLength).value
def useLists: Boolean = values contains UseLists
def jaxbPackage = get[JaxbPackage] getOrElse defaultJaxbPackage
private def get[A <: ConfigEntry: ClassTag]: Option[A] =
items.get(implicitly[ClassTag[A]].runtimeClass.getName).asInstanceOf[Option[A]]
def update(item: ConfigEntry): Config =
copy(items = items.updated(item.name, item))
def remove(item: ConfigEntry): Config =
copy(items = items - item.name)
}
object Config {
import ConfigEntry._
def apply(xs: Vector[ConfigEntry]): Config =
xs.foldLeft(new Config(Map())) { (acc, x) => acc.update(x) }
val defaultPackageNames = PackageNames(Map(None -> None))
val defaultOpOutputWrapperPostfix = OpOutputWrapperPostfix(Defaults.opOutputWrapperPostfix)
val defaultOutdir = Outdir(new File("."))
val defaultWrappedComplexTypes = WrappedComplexTypes(Nil)
val defaultProtocolFileName = ProtocolFileName("xmlprotocol.scala")
val defaultProtocolPackageName = ProtocolPackageName(None)
val defaultDefaultNamespace = DefaultNamespace(None)
val defaultContentsSizeLimit = ContentsSizeLimit(Int.MaxValue)
val defaultSequenceChunkSize = SequenceChunkSize(10)
val defaultDispatchVersion = DispatchVersion(scalaxb.BuildInfo.defaultDispatchVersion)
val defaultHttp4sVersion = Http4sVersion(scalaxb.BuildInfo.defaultHttp4sVersion)
val defaultGigahorseVersion = GigahorseVersion(scalaxb.BuildInfo.defaultGigahorseVersion)
val defaultGigahorseBackend = GigahorseBackend(scalaxb.BuildInfo.defaultGigahorseBackend)
val defaultSymbolEncodingStrategy = SymbolEncoding.Legacy151
val defaultEnumNameMaxLength = EnumNameMaxLength(50)
val defaultJaxbPackage = JaxbPackage.Javax
val default = Config(
Vector(defaultPackageNames, defaultOpOutputWrapperPostfix, defaultOutdir,
defaultWrappedComplexTypes, SeperateProtocol, defaultProtocolFileName,
defaultProtocolPackageName, GenerateRuntime, GenerateDispatchClient,
defaultContentsSizeLimit, defaultSequenceChunkSize,
HttpClientStyle.Future, defaultDispatchVersion)
)
}
sealed trait ConfigEntry {
def name: String = getClass.getName
}
object ConfigEntry {
case class PackageNames(value: Map[Option[String], Option[String]]) extends ConfigEntry
case class ClassPrefix(value: String) extends ConfigEntry
case class ClassPostfix(value: String) extends ConfigEntry
case class ParamPrefix(value: String) extends ConfigEntry
case class AttributePrefix(value: String) extends ConfigEntry
case class OpOutputWrapperPostfix(value: String) extends ConfigEntry
case class Outdir(value: File) extends ConfigEntry
case object GeneratePackageDir extends ConfigEntry
case class WrappedComplexTypes(value: List[String]) extends ConfigEntry
case object PrependFamilyName extends ConfigEntry
case object SeperateProtocol extends ConfigEntry
case class ProtocolFileName(value: String) extends ConfigEntry
case class ProtocolPackageName(value: Option[String]) extends ConfigEntry
case class DefaultNamespace(value: Option[String]) extends ConfigEntry
case object GenerateRuntime extends ConfigEntry
case object GenerateDispatchClient extends ConfigEntry
case object GenerateHttp4sClient extends ConfigEntry
case object GenerateDispatchAs extends ConfigEntry
case object GenerateGigahorseClient extends ConfigEntry
case class ContentsSizeLimit(value: Int) extends ConfigEntry
case class SequenceChunkSize(value: Int) extends ConfigEntry
case object NamedAttributes extends ConfigEntry
case object LaxAny extends ConfigEntry
case class DispatchVersion(value: String) extends ConfigEntry
case class Http4sVersion(value: String) extends ConfigEntry
case class GigahorseVersion(value: String) extends ConfigEntry
case class GigahorseBackend(value: String) extends ConfigEntry
case object VarArg extends ConfigEntry
case object IgnoreUnknown extends ConfigEntry
case object AutoPackages extends ConfigEntry
case object GenerateMutable extends ConfigEntry
case object GenerateVisitor extends ConfigEntry
case object GenerateLens extends ConfigEntry
case object CapitalizeWords extends ConfigEntry
case class EnumNameMaxLength(value: Int) extends ConfigEntry
case object UseLists extends ConfigEntry
case object GenerateMapK extends ConfigEntry
sealed abstract class HttpClientStyle extends ConfigEntry with Product with Serializable {
final override def name: String = classOf[HttpClientStyle].getName
}
object HttpClientStyle {
case object Sync extends HttpClientStyle
case object Future extends HttpClientStyle
case object Tagless extends HttpClientStyle
}
object SymbolEncoding {
sealed abstract class Strategy(val alias: String, val description: String) extends ConfigEntry with Product with Serializable {
final override def name: String = classOf[Strategy].getName
}
case object Discard extends Strategy("discard", "Discards any characters that are invalid in Scala identifiers, such as dots and hyphens")
case object SymbolName extends Strategy("symbol-name", "Replaces `.`, `-`, `:`, and trailing `_` in class names with `Dot`, `Hyphen`, `Colon`, and `Underscore`")
case object UnicodePoint extends Strategy("unicode-point", "Replaces symbols with a 'u' followed by the 4-digit hexadecimal code of the character (e.g. `_` => `u005f`)")
case object DecimalAscii extends Strategy("decimal-ascii", "Replaces symbols with a 'u' followed by the decimal code of the character (e.g. `_` => `u95`)")
case object Legacy151 extends Strategy("legacy-1.5.1", "Same as decimal-ascii except that _trailing_ underscores are replaced with `u93` (as introduced in v1.5.1)")
val values = Seq(Discard, SymbolName, UnicodePoint, DecimalAscii, Legacy151)
def apply(alias: String): Option[Strategy] = values.find(_.alias == alias)
def withName(alias: String): Strategy = apply(alias).getOrElse {
throw new IllegalArgumentException(s"""Unknown symbol encoding strategy "${alias}"; possible values are ${values.map(_.alias).mkString(", ")}.""")
}
private[compiler] implicit val scoptRead: scopt.Read[Strategy] = scopt.Read.reads(withName)
}
sealed abstract class JaxbPackage(val packageName: String) extends ConfigEntry with Product with Serializable {
final override def name: String = classOf[JaxbPackage].getName
}
object JaxbPackage {
case object Javax extends JaxbPackage("javax")
case object Jakarta extends JaxbPackage("jakarta")
val values = Seq(Javax, Jakarta)
def apply(packageName: String): Option[JaxbPackage] = values.find(_.packageName == packageName)
def withPackageName(packageName: String): JaxbPackage = apply(packageName).getOrElse {
throw new IllegalArgumentException(s"""Unknown jaxb package "${packageName}"; possible values are ${values.map(_.packageName).mkString(", ")}.""")
}
private[compiler] implicit val scoptRead: scopt.Read[JaxbPackage] = scopt.Read.reads(withPackageName)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy