diff options
author | Petro Verkhogliad <vpetro@gmail.com> | 2016-09-27 18:09:51 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-09-27 18:09:51 -0400 |
commit | 0623aabffbe20c8c7400d6950d2f6be1d456c869 (patch) | |
tree | b42f57ee689913cf1c3b6bded0d663fe3fd57648 | |
parent | 6e874235443a1596779c799eadfd2328ea0dd72f (diff) | |
parent | 9f61546097e454d54c7633f5eba94fa0afbfbd1b (diff) | |
download | slick-codegen-plugin-0623aabffbe20c8c7400d6950d2f6be1d456c869.tar.gz slick-codegen-plugin-0623aabffbe20c8c7400d6950d2f6be1d456c869.tar.bz2 slick-codegen-plugin-0623aabffbe20c8c7400d6950d2f6be1d456c869.zip |
Merge pull request #7 from drivergroup/corect-header-for-generated-files
Corect header for generated files
-rw-r--r-- | src/main/scala/NamespacedCodegen.scala | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/src/main/scala/NamespacedCodegen.scala b/src/main/scala/NamespacedCodegen.scala index 2febded..9c6d126 100644 --- a/src/main/scala/NamespacedCodegen.scala +++ b/src/main/scala/NamespacedCodegen.scala @@ -28,11 +28,21 @@ object Generator { } +class PackageNameGenerator(pkg: String, dbModel: Model) extends SourceCodeGenerator(dbModel) { + override def code: String = + s""" + |// format: OFF + |// scalastyle:off + |package ${pkg} + | + |""".stripMargin +} + + class ImportGenerator(dbModel: Model) extends SourceCodeGenerator(dbModel) { val baseImports: String = s""" - | - |import com.drivergrp.core._ + |import com.drivergrp.core._ |import com.drivergrp.core.database._ | |""".stripMargin @@ -60,6 +70,7 @@ class ImportGenerator(dbModel: Model) extends SourceCodeGenerator(dbModel) { class Generator(uri: URI, pkg: String, dbModel: Model, outputPath: String, manualForeignKeys: Map[(String, String), (String, String)]) extends SourceCodeGenerator(dbModel) with OutputHelpers { + val packageName = new PackageNameGenerator(pkg, dbModel).code val allImports: String = new ImportGenerator(dbModel).code override def code: String = { @@ -79,11 +90,12 @@ class Generator(uri: URI, pkg: String, dbModel: Model, outputPath: String, manua | // TODO: the name for this implicit should be changed in driver core | implicit val tColType = MappedColumnType.base[com.drivergrp.core.time.Time, Long](time => time.millis, com.drivergrp.core.time.Time(_)) | ${tableCode} + | |} - """.stripMargin + |// scalastyle:on""".stripMargin writeStringToFile( - allImports + generatedSchema, + packageName + allImports + generatedSchema, outputPath, pkg, s"${schemaName}.scala" @@ -99,7 +111,7 @@ class Generator(uri: URI, pkg: String, dbModel: Model, outputPath: String, manua override def Table = new Table(_) { table => // need this in order to use our own TableClass generator - override def definitions = Seq[Def]( EntityType, PlainSqlMapper, TableClassRef, TableValue ) + override def definitions = Seq[Def]( EntityTypeRef, PlainSqlMapper, TableClassRef, TableValue ) def TableClassRef = new TableClass() { // We disable the option mapping, as it is a bit more complex to support and we don't appear to need it @@ -128,6 +140,10 @@ class Generator(uri: URI, pkg: String, dbModel: Model, outputPath: String, manua else s"(a : ${TableClass.elementType}) => Some(" + columns.map("a."+_.name ).mkString("::") + ":: HNil)" + def EntityTypeRef = new EntityTypeDef { + override def code: String = (if (classEnabled) "final " else "") + super.code + } + override def Column = new Column(_) { column => |