aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/core/date.scala
diff options
context:
space:
mode:
authorStewart Stewart <stewinsalot@gmail.com>2016-12-22 17:27:40 -0500
committerStewart Stewart <stewinsalot@gmail.com>2016-12-22 17:27:40 -0500
commita4c857745817092ccb9d2b12d83df74a0f2e25e5 (patch)
tree72f85d7713de52c1f67ea6be202fe657a4e120f8 /src/main/scala/xyz/driver/core/date.scala
parent687919e7c163e1ff8a002f1a2c24e4b37f75f20d (diff)
downloaddriver-core-a4c857745817092ccb9d2b12d83df74a0f2e25e5.tar.gz
driver-core-a4c857745817092ccb9d2b12d83df74a0f2e25e5.tar.bz2
driver-core-a4c857745817092ccb9d2b12d83df74a0f2e25e5.zip
add Date#toString and Date.fromString
Diffstat (limited to 'src/main/scala/xyz/driver/core/date.scala')
-rw-r--r--src/main/scala/xyz/driver/core/date.scala13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/main/scala/xyz/driver/core/date.scala b/src/main/scala/xyz/driver/core/date.scala
index ab19074..bb88501 100644
--- a/src/main/scala/xyz/driver/core/date.scala
+++ b/src/main/scala/xyz/driver/core/date.scala
@@ -21,5 +21,16 @@ object date {
val DECEMBER = tagMonth(Calendar.DECEMBER)
}
- final case class Date(year: Int, month: Month, day: Int)
+ final case class Date(year: Int, month: Month, day: Int) {
+ override def toString = f"$year%04d-${month + 1}%02d-$day%02d"
+ }
+
+ object Date {
+ def fromString(dateString: String): Option[Date] = {
+ util.Try(dateString.split("-").map(_.toInt)).toOption collect {
+ case Array(year, month, day) if (1 to 12 contains month) && (1 to 31 contains day) =>
+ Date(year, tagMonth(month - 1), day)
+ }
+ }
+ }
}