aboutsummaryrefslogtreecommitdiff
path: root/kamon-core/src/main/scala/kamon/util/ConfigTools.scala
diff options
context:
space:
mode:
authorIvan Topolnjak <ivantopo@gmail.com>2015-01-29 03:42:27 +0100
committerIvan Topolnjak <ivantopo@gmail.com>2015-01-29 03:42:27 +0100
commit75bd9503aebee628da394a935816991e7a790092 (patch)
treef4df3333826cec805fadc14894579f1bc1054279 /kamon-core/src/main/scala/kamon/util/ConfigTools.scala
parent61089a75240f5cc21b056087f1d633dd31981c61 (diff)
parent9839db9d46312435822b6b5faffbbc445af80077 (diff)
downloadKamon-75bd9503aebee628da394a935816991e7a790092.tar.gz
Kamon-75bd9503aebee628da394a935816991e7a790092.tar.bz2
Kamon-75bd9503aebee628da394a935816991e7a790092.zip
Merge branch 'wip/improve-metric-recorders-infrastructure'
Conflicts: kamon-system-metrics/src/main/scala/kamon/system/SystemMetricsCollector.scala
Diffstat (limited to 'kamon-core/src/main/scala/kamon/util/ConfigTools.scala')
-rw-r--r--kamon-core/src/main/scala/kamon/util/ConfigTools.scala26
1 files changed, 26 insertions, 0 deletions
diff --git a/kamon-core/src/main/scala/kamon/util/ConfigTools.scala b/kamon-core/src/main/scala/kamon/util/ConfigTools.scala
new file mode 100644
index 00000000..9810428e
--- /dev/null
+++ b/kamon-core/src/main/scala/kamon/util/ConfigTools.scala
@@ -0,0 +1,26 @@
+package kamon.util
+
+import java.util.concurrent.TimeUnit
+
+import com.typesafe.config.Config
+
+import scala.concurrent.duration.FiniteDuration
+
+object ConfigTools {
+ implicit class Syntax(val config: Config) extends AnyVal {
+ // We are using the deprecated .getNanoseconds option to keep Kamon source code compatible with
+ // versions of Akka using older typesafe-config versions.
+
+ def getFiniteDuration(path: String): FiniteDuration =
+ FiniteDuration(config.getNanoseconds(path), TimeUnit.NANOSECONDS)
+
+ def firstLevelKeys: Set[String] = {
+ import scala.collection.JavaConverters._
+
+ config.entrySet().asScala.map {
+ case entry ⇒ entry.getKey.takeWhile(_ != '.')
+ } toSet
+ }
+ }
+
+}