diff options
author | 2015-02-25 16:45:20 +0100 | |
---|---|---|
committer | 2015-02-25 16:45:20 +0100 | |
commit | d08b27fa9701fecfdb69e1b0d1ac2459efc2129b (patch) | |
tree | 5d50963026239ca5aebfb47ea5b8db7e814e57c8 /src/main/java/com/google/devtools/build/lib/runtime/CommandEvent.java |
Update from Google.
--
MOE_MIGRATED_REVID=85702957
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/runtime/CommandEvent.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/runtime/CommandEvent.java | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/runtime/CommandEvent.java b/src/main/java/com/google/devtools/build/lib/runtime/CommandEvent.java new file mode 100644 index 0000000000..3e59dce22f --- /dev/null +++ b/src/main/java/com/google/devtools/build/lib/runtime/CommandEvent.java @@ -0,0 +1,68 @@ +// Copyright 2014 Google Inc. All rights reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +package com.google.devtools.build.lib.runtime; + +import com.google.devtools.build.lib.util.BlazeClock; + +import java.lang.management.GarbageCollectorMXBean; +import java.lang.management.ManagementFactory; +import java.util.Date; + +/** + * Base class for Command events that includes some resource fields. + */ +public abstract class CommandEvent { + + private final long eventTimeInNanos; + private final long eventTimeInEpochTime; + private final long gcTimeInMillis; + + protected CommandEvent() { + eventTimeInNanos = BlazeClock.nanoTime(); + eventTimeInEpochTime = new Date().getTime(); + gcTimeInMillis = collectGcTimeInMillis(); + } + + /** + * Returns time spent in garbage collection since the start of the JVM process. + */ + private static long collectGcTimeInMillis() { + long gcTime = 0; + for (GarbageCollectorMXBean gcBean : ManagementFactory.getGarbageCollectorMXBeans()) { + gcTime += gcBean.getCollectionTime(); + } + return gcTime; + } + + /** + * Get the time-stamp in ns for the event. + */ + public long getEventTimeInNanos() { + return eventTimeInNanos; + } + + /** + * Get the time-stamp as epoch-time for the event. + */ + public long getEventTimeInEpochTime() { + return eventTimeInEpochTime; + } + + /** + * Get the cumulative GC time for the event. + */ + public long getGCTimeInMillis() { + return gcTimeInMillis; + } +} |