aboutsummaryrefslogtreecommitdiff
path: root/kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala
diff options
context:
space:
mode:
authorDiego <diegolparra@gmail.com>2016-07-10 17:56:25 -0300
committerDiego <diegolparra@gmail.com>2016-07-10 17:56:25 -0300
commitb4bd6588ad568d2c049b5473189858e487693e29 (patch)
tree2e07c1a1668e1a94e1c3589a9117071f5bf9c47a /kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala
parentef927dc672bea427d4de89b8d0ea0bd18bd71285 (diff)
downloadKamon-b4bd6588ad568d2c049b5473189858e487693e29.tar.gz
Kamon-b4bd6588ad568d2c049b5473189858e487693e29.tar.bz2
Kamon-b4bd6588ad568d2c049b5473189858e487693e29.zip
= core: minor refactor
Diffstat (limited to 'kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala')
-rw-r--r--kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala42
1 files changed, 30 insertions, 12 deletions
diff --git a/kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala b/kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala
index 973eab5a..e747b731 100644
--- a/kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala
+++ b/kamon-core/src/main/scala/kamon/trace/MetricsOnlyContext.scala
@@ -21,15 +21,18 @@ import java.util.concurrent.ConcurrentLinkedQueue
import akka.event.LoggingAdapter
import kamon.Kamon
import kamon.metric.{ SegmentMetrics, TraceMetrics }
-import kamon.trace.States.Status
import kamon.util.{ NanoInterval, RelativeNanoTimestamp }
import scala.annotation.tailrec
import scala.collection.concurrent.TrieMap
-private[kamon] class MetricsOnlyContext(traceName: String, val token: String, traceTags: Map[String, String], currentStatus: Status, val levelOfDetail: LevelOfDetail,
- val startTimestamp: RelativeNanoTimestamp, log: LoggingAdapter)
- extends TraceContext {
+private[kamon] class MetricsOnlyContext(traceName: String,
+ val token: String,
+ traceTags: Map[String, String],
+ currentStatus: Status,
+ val levelOfDetail: LevelOfDetail,
+ val startTimestamp: RelativeNanoTimestamp,
+ log: LoggingAdapter) extends TraceContext {
@volatile private var _name = traceName
@volatile private var _status = currentStatus
@@ -40,7 +43,7 @@ private[kamon] class MetricsOnlyContext(traceName: String, val token: String, tr
private val _tags = TrieMap.empty[String, String] ++= traceTags
def rename(newName: String): Unit =
- if (States.Open == status)
+ if (Status.Open == status)
_name = newName
else
log.warning("Can't rename trace from [{}] to [{}] because the trace is already closed.", name, newName)
@@ -53,7 +56,7 @@ private[kamon] class MetricsOnlyContext(traceName: String, val token: String, tr
def removeTag(key: String, value: String): Boolean = _tags.remove(key, value)
private def finish(withError: Boolean): Unit = {
- _status = if (withError) States.FinishedWithError else States.FinishedSuccessfully
+ _status = if (withError) Status.FinishedWithError else Status.FinishedSuccessfully
val traceElapsedTime = NanoInterval.since(startTimestamp)
_elapsedTime = traceElapsedTime
@@ -95,7 +98,13 @@ private[kamon] class MetricsOnlyContext(traceName: String, val token: String, tr
}
}
- protected def finishSegment(segmentName: String, category: String, library: String, duration: NanoInterval, segmentTags: Map[String, String], isFinishedWithError: Boolean): Unit = {
+ protected def finishSegment(segmentName: String,
+ category: String,
+ library: String,
+ duration: NanoInterval,
+ segmentTags: Map[String, String],
+ isFinishedWithError: Boolean): Unit = {
+
_finishedSegments.add(SegmentLatencyData(segmentName, category, library, duration, segmentTags, isFinishedWithError))
if (isClosed) {
@@ -110,13 +119,17 @@ private[kamon] class MetricsOnlyContext(traceName: String, val token: String, tr
// will be returned.
def elapsedTime: NanoInterval = _elapsedTime
- class MetricsOnlySegment(segmentName: String, val category: String, val library: String, segmentTags: Map[String, String]) extends Segment {
+ class MetricsOnlySegment(segmentName: String,
+ val category: String,
+ val library: String,
+ segmentTags: Map[String, String]) extends Segment {
+
private val _startTimestamp = RelativeNanoTimestamp.now
protected val _tags = TrieMap.empty[String, String] ++= segmentTags
@volatile private var _segmentName = segmentName
@volatile private var _elapsedTime = NanoInterval.default
- @volatile private var _status: Status = States.Open
+ @volatile private var _status: Status = Status.Open
def name: String = _segmentName
def isEmpty: Boolean = false
@@ -126,13 +139,13 @@ private[kamon] class MetricsOnlyContext(traceName: String, val token: String, tr
def removeTag(key: String, value: String): Boolean = _tags.remove(key, value)
def rename(newName: String): Unit =
- if (States.Open == status)
+ if (Status.Open == status)
_segmentName = newName
else
log.warning("Can't rename segment from [{}] to [{}] because the segment is already closed.", name, newName)
private def finish(withError: Boolean): Unit = {
- _status = if (withError) States.FinishedWithError else States.FinishedSuccessfully
+ _status = if (withError) Status.FinishedWithError else Status.FinishedSuccessfully
val segmentElapsedTime = NanoInterval.since(_startTimestamp)
_elapsedTime = segmentElapsedTime
@@ -154,4 +167,9 @@ private[kamon] class MetricsOnlyContext(traceName: String, val token: String, tr
}
}
-case class SegmentLatencyData(name: String, category: String, library: String, duration: NanoInterval, tags: Map[String, String], isFinishedWithError: Boolean) \ No newline at end of file
+case class SegmentLatencyData(name: String,
+ category: String,
+ library: String,
+ duration: NanoInterval,
+ tags: Map[String, String],
+ isFinishedWithError: Boolean) \ No newline at end of file