From ddf9939c4edb4c48b3ebbf76c3a410c0f09b21b6 Mon Sep 17 00:00:00 2001 From: Stewart Stewart Date: Fri, 26 May 2017 11:47:42 -0700 Subject: backport slick/slick#1733 to use longvarchar in hsqldb --- .../xyz/driver/core/database/PatchedHsqldbProfile.scala | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 src/main/scala/xyz/driver/core/database/PatchedHsqldbProfile.scala diff --git a/src/main/scala/xyz/driver/core/database/PatchedHsqldbProfile.scala b/src/main/scala/xyz/driver/core/database/PatchedHsqldbProfile.scala new file mode 100644 index 0000000..a2220e9 --- /dev/null +++ b/src/main/scala/xyz/driver/core/database/PatchedHsqldbProfile.scala @@ -0,0 +1,17 @@ +package xyz.driver.core.database + +import slick.driver.HsqldbDriver +import slick.jdbc.JdbcType +import slick.ast.FieldSymbol +import slick.profile.RelationalProfile + +trait PatchedHsqldbProfile extends HsqldbDriver { + override def defaultSqlTypeName(tmd: JdbcType[_], sym: Option[FieldSymbol]): String = tmd.sqlType match { + case java.sql.Types.VARCHAR => + val size = sym.flatMap(_.findColumnOption[RelationalProfile.ColumnOption.Length]) + size.fold("LONGVARCHAR")(l => if(l.varying) s"VARCHAR(${l.length})" else s"CHAR(${l.length})") + case _ => super.defaultSqlTypeName(tmd, sym) + } +} + +object PatchedHsqldbProfile extends PatchedHsqldbProfile -- cgit v1.2.3