public class org.apache.kafkaesque.common.metrics.Metrics extends java.lang.Object implements java.io.Closeable
{
private final org.apache.kafkaesque.common.metrics.MetricConfig config;
private final java.util.concurrent.ConcurrentMap metrics;
private final java.util.concurrent.ConcurrentMap sensors;
private final java.util.concurrent.ConcurrentMap childrenSensors;
private final java.util.List reporters;
private final org.apache.kafkaesque.common.utils.Time time;
private final java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler;
private static final org.slf4j.Logger log;
public void <init>()
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v = new org.apache.kafkaesque.common.metrics.MetricConfig;
specialinvoke v.<org.apache.kafkaesque.common.metrics.MetricConfig: void <init>()>();
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void <init>(org.apache.kafkaesque.common.metrics.MetricConfig)>(v);
return;
}
public void <init>(org.apache.kafkaesque.common.utils.Time)
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.utils.Time v;
java.util.ArrayList v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.utils.Time;
v = new org.apache.kafkaesque.common.metrics.MetricConfig;
specialinvoke v.<org.apache.kafkaesque.common.metrics.MetricConfig: void <init>()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(0);
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void <init>(org.apache.kafkaesque.common.metrics.MetricConfig,java.util.List,org.apache.kafkaesque.common.utils.Time)>(v, v, v);
return;
}
public void <init>(org.apache.kafkaesque.common.metrics.MetricConfig, org.apache.kafkaesque.common.utils.Time)
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.utils.Time v;
java.util.ArrayList v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: org.apache.kafkaesque.common.utils.Time;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(0);
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void <init>(org.apache.kafkaesque.common.metrics.MetricConfig,java.util.List,org.apache.kafkaesque.common.utils.Time)>(v, v, v);
return;
}
public void <init>(org.apache.kafkaesque.common.metrics.MetricConfig)
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.utils.Time v;
java.util.ArrayList v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(0);
v = <org.apache.kafkaesque.common.utils.Time: org.apache.kafkaesque.common.utils.Time SYSTEM>;
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void <init>(org.apache.kafkaesque.common.metrics.MetricConfig,java.util.List,org.apache.kafkaesque.common.utils.Time)>(v, v, v);
return;
}
public void <init>(org.apache.kafkaesque.common.metrics.MetricConfig, java.util.List, org.apache.kafkaesque.common.utils.Time)
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
java.util.List v;
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.utils.Time v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: java.util.List;
v := @parameter: org.apache.kafkaesque.common.utils.Time;
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void <init>(org.apache.kafkaesque.common.metrics.MetricConfig,java.util.List,org.apache.kafkaesque.common.utils.Time,boolean)>(v, v, v, 0);
return;
}
public void <init>(org.apache.kafkaesque.common.metrics.MetricConfig, java.util.List, org.apache.kafkaesque.common.utils.Time, boolean)
{
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.ArrayList v;
org.apache.kafkaesque.common.utils.Time v;
java.util.concurrent.ThreadFactory v;
boolean v, v;
org.apache.kafkaesque.common.metrics.Metrics$ExpireSensorTask v;
java.util.Iterator v;
java.util.concurrent.ConcurrentHashMap v, v, v;
java.util.concurrent.ScheduledThreadPoolExecutor v, v, v;
org.apache.kafkaesque.common.metrics.Measurable v;
java.util.concurrent.TimeUnit v;
org.apache.kafkaesque.common.metrics.MetricConfig v;
java.util.List v;
org.apache.kafkaesque.common.MetricName v;
java.lang.Object v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: java.util.List;
v := @parameter: org.apache.kafkaesque.common.utils.Time;
v := @parameter: boolean;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.MetricConfig config> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap sensors> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics> = v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap childrenSensors> = v;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters> = v;
v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.utils.Time time> = v;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
interfaceinvoke v.<org.apache.kafkaesque.common.metrics.MetricsReporter: void init(java.util.List)>(v);
goto label;
label:
if v == 0 goto label;
v = new java.util.concurrent.ScheduledThreadPoolExecutor;
specialinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void <init>(int)>(1);
v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler> = v;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler>;
v = staticinvoke <org.apache.kafkaesque.common.metrics.Metrics$lambda_new_0__243: java.util.concurrent.ThreadFactory bootstrap$()>();
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void setThreadFactory(java.util.concurrent.ThreadFactory)>(v);
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler>;
v = new org.apache.kafkaesque.common.metrics.Metrics$ExpireSensorTask;
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics$ExpireSensorTask: void <init>(org.apache.kafkaesque.common.metrics.Metrics)>(v);
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: java.util.concurrent.ScheduledFuture scheduleAtFixedRate(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, 30L, 30L, v);
goto label;
label:
v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler> = null;
label:
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String)>("count", "kafka-metrics-count", "total number of registered metrics");
v = staticinvoke <org.apache.kafkaesque.common.metrics.Metrics$lambda_new_1__242: org.apache.kafkaesque.common.metrics.Measurable bootstrap$(org.apache.kafkaesque.common.metrics.Metrics)>(v);
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void addMetric(org.apache.kafkaesque.common.MetricName,org.apache.kafkaesque.common.metrics.Measurable)>(v, v);
return;
}
public org.apache.kafkaesque.common.MetricName metricName(java.lang.String, java.lang.String, java.lang.String, java.util.Map)
{
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.LinkedHashMap v;
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.MetricName v;
java.util.Map v, v;
java.lang.String v, v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
v = new java.util.LinkedHashMap;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.MetricConfig config>;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.MetricConfig: java.util.Map tags()>();
specialinvoke v.<java.util.LinkedHashMap: void <init>(java.util.Map)>(v);
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = new org.apache.kafkaesque.common.MetricName;
specialinvoke v.<org.apache.kafkaesque.common.MetricName: void <init>(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, v, v);
return v;
}
public org.apache.kafkaesque.common.MetricName metricName(java.lang.String, java.lang.String, java.lang.String)
{
org.apache.kafkaesque.common.MetricName v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.HashMap v;
java.lang.String v, v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, v, v);
return v;
}
public org.apache.kafkaesque.common.MetricName metricName(java.lang.String, java.lang.String)
{
org.apache.kafkaesque.common.MetricName v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.HashMap v;
java.lang.String v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, "", v);
return v;
}
public transient org.apache.kafkaesque.common.MetricName metricName(java.lang.String, java.lang.String, java.lang.String, java.lang.String[])
{
org.apache.kafkaesque.common.MetricName v;
java.util.Map v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String[] v;
java.lang.String v, v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String[];
v = staticinvoke <org.apache.kafkaesque.common.metrics.Metrics: java.util.Map getTags(java.lang.String[])>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, v, v);
return v;
}
public org.apache.kafkaesque.common.MetricName metricName(java.lang.String, java.lang.String, java.util.Map)
{
org.apache.kafkaesque.common.MetricName v;
java.util.Map v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.Map;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, "", v);
return v;
}
private static transient java.util.Map getTags(java.lang.String[])
{
java.lang.String[] v;
java.lang.IllegalArgumentException v;
java.util.LinkedHashMap v;
int v, v, v, v, v;
java.lang.String v, v;
v := @parameter: java.lang.String[];
v = lengthof v;
v = v % 2;
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("keyValue needs to be specified in pairs");
throw v;
label:
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v = 0;
label:
v = lengthof v;
if v >= v goto label;
v = v[v];
v = v + 1;
v = v[v];
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v + 2;
goto label;
label:
return v;
}
public static java.lang.String toHtmlTable(java.lang.String, java.lang.Iterable)
{
boolean v, v, v, v, v, v;
java.util.Set v, v, v;
org.apache.kafkaesque.common.MetricName v;
java.lang.StringBuilder v;
java.lang.Throwable v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.Iterable v;
java.util.LinkedHashMap v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.Iterator v, v, v, v;
java.lang.IllegalArgumentException v;
java.util.TreeMap v, v;
java.lang.Object v, v, v, v, v, v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Iterable;
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
v = new org.apache.kafkaesque.common.metrics.Metrics;
specialinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void <init>()>();
label:
v = interfaceinvoke v.<java.lang.Iterable: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.util.Set tags()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Object)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("{\u0001}");
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String name()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String group()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String description()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, v, v);
v = staticinvoke <org.apache.kafkaesque.common.metrics.JmxReporter: java.lang.String getMBeanName(java.lang.String,org.apache.kafkaesque.common.MetricName)>(v, v);
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.util.TreeMap;
specialinvoke v.<java.util.TreeMap: void <init>()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String name()>();
v = interfaceinvoke v.<java.util.Map: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String name()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String description()>();
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = new java.lang.IllegalArgumentException;
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String name()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("mBean \'\u0001\' attribute \'\u0001\' is defined twice.");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<table class=\"data-table\"><tbody>\n");
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<tr>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<td colspan=3 class=\"mbeanName\" style=\"background-color:#ccc; font-weight: bold;\">");
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</td>");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</tr>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<tr>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<th style=\"width: 90px\"></th>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<th>Attribute name</th>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<th>Description</th>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</tr>\n");
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
v = interfaceinvoke v.<java.util.Map: java.util.Set entrySet()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<tr>\n");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<td></td>");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<td>");
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getKey()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</td>");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("<td>");
v = interfaceinvoke v.<java.util.Map$Entry: java.lang.Object getValue()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</td>");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</tr>\n");
goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("</tbody></table>");
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.kafkaesque.common.metrics.MetricConfig config()
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.MetricConfig config>;
return v;
}
public org.apache.kafkaesque.common.metrics.Sensor getSensor(java.lang.String)
{
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.Object v, v;
java.lang.String v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap sensors>;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
return v;
}
public org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String)
{
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v = <org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel INFO>;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel)>(v, v);
return v;
}
public org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel)
{
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel;
v = (org.apache.kafkaesque.common.metrics.Sensor[]) null;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel,org.apache.kafkaesque.common.metrics.Sensor[])>(v, null, v, v);
return v;
}
public transient org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.Sensor[])
{
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor[];
v = <org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel INFO>;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel,org.apache.kafkaesque.common.metrics.Sensor[])>(v, v, v);
return v;
}
public transient org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel, org.apache.kafkaesque.common.metrics.Sensor[])
{
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor[];
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel,org.apache.kafkaesque.common.metrics.Sensor[])>(v, null, v, v);
return v;
}
public synchronized transient org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.MetricConfig, org.apache.kafkaesque.common.metrics.Sensor[])
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor[];
v = <org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel INFO>;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel,org.apache.kafkaesque.common.metrics.Sensor[])>(v, v, v, v);
return v;
}
public synchronized transient org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.MetricConfig, org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel, org.apache.kafkaesque.common.metrics.Sensor[])
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor[];
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.MetricConfig,long,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel,org.apache.kafkaesque.common.metrics.Sensor[])>(v, v, 9223372036854775807L, v, v);
return v;
}
public synchronized transient org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.MetricConfig, long, org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel, org.apache.kafkaesque.common.metrics.Sensor[])
{
org.apache.kafkaesque.common.metrics.Sensor v, v, v;
org.apache.kafkaesque.common.metrics.Metrics v;
long v;
java.util.function.Function v;
java.util.concurrent.ConcurrentMap v, v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
int v, v;
org.apache.kafkaesque.common.utils.Time v;
java.lang.String v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.slf4j.Logger v;
org.apache.kafkaesque.common.metrics.MetricConfig v, v;
java.lang.Object v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: long;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor[];
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor getSensor(java.lang.String)>(v);
if v != null goto label;
v = new org.apache.kafkaesque.common.metrics.Sensor;
if v != null goto label;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.MetricConfig config>;
goto label;
label:
v = v;
label:
v = v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.utils.Time time>;
specialinvoke v.<org.apache.kafkaesque.common.metrics.Sensor: void <init>(org.apache.kafkaesque.common.metrics.Metrics,java.lang.String,org.apache.kafkaesque.common.metrics.Sensor[],org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.utils.Time,long,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel)>(v, v, v, v, v, v, v);
v = v;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap sensors>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
if v == null goto label;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap childrenSensors>;
v = staticinvoke <org.apache.kafkaesque.common.metrics.Metrics$lambda_sensor_2__244: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function)>(v, v);
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = <org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Added sensor with name {}", v);
label:
return v;
}
public synchronized transient org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String, org.apache.kafkaesque.common.metrics.MetricConfig, long, org.apache.kafkaesque.common.metrics.Sensor[])
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.metrics.Sensor v;
org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel v;
org.apache.kafkaesque.common.metrics.Sensor[] v;
org.apache.kafkaesque.common.metrics.Metrics v;
long v;
java.lang.String v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: long;
v := @parameter: org.apache.kafkaesque.common.metrics.Sensor[];
v = <org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel: org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel INFO>;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.Sensor sensor(java.lang.String,org.apache.kafkaesque.common.metrics.MetricConfig,long,org.apache.kafkaesque.common.metrics.Sensor$RecordingLevel,org.apache.kafkaesque.common.metrics.Sensor[])>(v, v, v, v, v);
return v;
}
public void removeSensor(java.lang.String)
{
java.lang.Throwable v, v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.concurrent.ConcurrentMap v, v, v, v;
java.lang.String v, v;
boolean v, v, v, v;
org.slf4j.Logger v;
java.util.Iterator v, v, v;
java.util.List v, v, v;
org.apache.kafkaesque.common.MetricName v;
java.lang.Object v, v, v, v, v, v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: java.lang.String;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap sensors>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
entermonitor v;
label:
entermonitor v;
label:
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap sensors>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean remove(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Sensor: java.util.List metrics()>();
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.KafkaMetric: org.apache.kafkaesque.common.MetricName metricName()>();
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.KafkaMetric removeMetric(org.apache.kafkaesque.common.MetricName)>(v);
goto label;
label:
v = <org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Removed sensor with name {}", v);
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap childrenSensors>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Sensor: java.util.List parents()>();
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap childrenSensors>;
v = staticinvoke <java.util.Collections: java.util.List emptyList()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object getOrDefault(java.lang.Object,java.lang.Object)>(v, v);
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v == null goto label;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Sensor: java.lang.String name()>();
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void removeSensor(java.lang.String)>(v);
goto label;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public void addMetric(org.apache.kafkaesque.common.MetricName, org.apache.kafkaesque.common.metrics.Measurable)
{
org.apache.kafkaesque.common.MetricName v;
org.apache.kafkaesque.common.metrics.Measurable v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v := @parameter: org.apache.kafkaesque.common.metrics.Measurable;
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void addMetric(org.apache.kafkaesque.common.MetricName,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.metrics.Measurable)>(v, null, v);
return;
}
public void addMetric(org.apache.kafkaesque.common.MetricName, org.apache.kafkaesque.common.metrics.MetricConfig, org.apache.kafkaesque.common.metrics.Measurable)
{
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.MetricName v;
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.metrics.Measurable v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: org.apache.kafkaesque.common.metrics.Measurable;
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void addMetric(org.apache.kafkaesque.common.MetricName,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.metrics.MetricValueProvider)>(v, v, v);
return;
}
public void addMetric(org.apache.kafkaesque.common.MetricName, org.apache.kafkaesque.common.metrics.MetricConfig, org.apache.kafkaesque.common.metrics.MetricValueProvider)
{
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.metrics.KafkaMetric v;
org.apache.kafkaesque.common.metrics.MetricConfig v, v;
org.apache.kafkaesque.common.MetricName v;
java.lang.Object v, v, v;
org.apache.kafkaesque.common.utils.Time v;
org.apache.kafkaesque.common.metrics.MetricValueProvider v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricConfig;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricValueProvider;
v = new org.apache.kafkaesque.common.metrics.KafkaMetric;
v = new java.lang.Object;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
if v != null goto label;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.MetricConfig config>;
goto label;
label:
v = v;
label:
v = v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.utils.Time time>;
specialinvoke v.<org.apache.kafkaesque.common.metrics.KafkaMetric: void <init>(java.lang.Object,org.apache.kafkaesque.common.MetricName,org.apache.kafkaesque.common.metrics.MetricValueProvider,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.utils.Time)>(v, v, v, v, v);
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void registerMetric(org.apache.kafkaesque.common.metrics.KafkaMetric)>(v);
return;
}
public void addMetric(org.apache.kafkaesque.common.MetricName, org.apache.kafkaesque.common.metrics.MetricValueProvider)
{
org.apache.kafkaesque.common.MetricName v;
org.apache.kafkaesque.common.metrics.MetricValueProvider v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricValueProvider;
virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: void addMetric(org.apache.kafkaesque.common.MetricName,org.apache.kafkaesque.common.metrics.MetricConfig,org.apache.kafkaesque.common.metrics.MetricValueProvider)>(v, null, v);
return;
}
public synchronized org.apache.kafkaesque.common.metrics.KafkaMetric removeMetric(org.apache.kafkaesque.common.MetricName)
{
org.slf4j.Logger v, v;
java.util.Iterator v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.Exception v;
java.util.concurrent.ConcurrentMap v;
java.util.List v;
org.apache.kafkaesque.common.MetricName v;
java.lang.Class v;
java.lang.Object v, v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
if v == null goto label;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
label:
interfaceinvoke v.<org.apache.kafkaesque.common.metrics.MetricsReporter: void metricRemoval(org.apache.kafkaesque.common.metrics.KafkaMetric)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Error when removing metric from \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v = <org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Removed metric named {}", v);
label:
return v;
catch java.lang.Exception from label to label with label;
}
public synchronized void addReporter(org.apache.kafkaesque.common.metrics.MetricsReporter)
{
java.util.List v;
org.apache.kafkaesque.common.metrics.MetricsReporter v;
java.util.Collection v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.Object v;
java.util.ArrayList v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricsReporter;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object)>(v);
v = new java.util.ArrayList;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.util.Collection values()>();
specialinvoke v.<java.util.ArrayList: void <init>(java.util.Collection)>(v);
interfaceinvoke v.<org.apache.kafkaesque.common.metrics.MetricsReporter: void init(java.util.List)>(v);
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
return;
}
public synchronized void removeReporter(org.apache.kafkaesque.common.metrics.MetricsReporter)
{
java.util.List v;
org.apache.kafkaesque.common.metrics.MetricsReporter v;
org.apache.kafkaesque.common.metrics.Metrics v;
boolean v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.MetricsReporter;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters>;
v = interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
if v == 0 goto label;
interfaceinvoke v.<org.apache.kafkaesque.common.metrics.MetricsReporter: void close()>();
label:
return;
}
synchronized void registerMetric(org.apache.kafkaesque.common.metrics.KafkaMetric)
{
org.apache.kafkaesque.common.metrics.Metrics v;
org.apache.kafkaesque.common.metrics.KafkaMetric v;
java.util.concurrent.ConcurrentMap v, v;
java.lang.String v, v, v;
boolean v, v;
org.slf4j.Logger v, v;
java.util.Iterator v;
java.lang.IllegalArgumentException v;
java.lang.Exception v;
java.util.List v;
org.apache.kafkaesque.common.MetricName v;
java.lang.Class v;
java.lang.Object v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.metrics.KafkaMetric;
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.KafkaMetric: org.apache.kafkaesque.common.MetricName metricName()>();
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: boolean containsKey(java.lang.Object)>(v);
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.kafkaesque.common.MetricName)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("A metric named \'\u0001\' already exists, can\'t register another one.");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
label:
interfaceinvoke v.<org.apache.kafkaesque.common.metrics.MetricsReporter: void metricChange(org.apache.kafkaesque.common.metrics.KafkaMetric)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log>;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Error when registering metric on \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
goto label;
label:
v = <org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String,java.lang.Object)>("Registered metric named {}", v);
return;
catch java.lang.Exception from label to label with label;
}
public java.util.Map metrics()
{
java.util.concurrent.ConcurrentMap v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics>;
return v;
}
public java.util.List reporters()
{
java.util.List v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters>;
return v;
}
public org.apache.kafkaesque.common.metrics.KafkaMetric metric(org.apache.kafkaesque.common.MetricName)
{
org.apache.kafkaesque.common.MetricName v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.Object v;
java.util.concurrent.ConcurrentMap v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricName;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap metrics>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
return v;
}
java.util.Map childrenSensors()
{
java.util.Map v;
java.util.concurrent.ConcurrentMap v;
org.apache.kafkaesque.common.metrics.Metrics v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ConcurrentMap childrenSensors>;
v = staticinvoke <java.util.Collections: java.util.Map unmodifiableMap(java.util.Map)>(v);
return v;
}
public transient org.apache.kafkaesque.common.MetricName metricInstance(org.apache.kafkaesque.common.MetricNameTemplate, java.lang.String[])
{
org.apache.kafkaesque.common.MetricName v;
java.util.Map v;
org.apache.kafkaesque.common.MetricNameTemplate v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.lang.String[] v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricNameTemplate;
v := @parameter: java.lang.String[];
v = staticinvoke <org.apache.kafkaesque.common.metrics.Metrics: java.util.Map getTags(java.lang.String[])>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricInstance(org.apache.kafkaesque.common.MetricNameTemplate,java.util.Map)>(v, v);
return v;
}
public org.apache.kafkaesque.common.MetricName metricInstance(org.apache.kafkaesque.common.MetricNameTemplate, java.util.Map)
{
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.HashSet v;
java.util.Map v, v;
org.apache.kafkaesque.common.MetricNameTemplate v;
java.lang.String v, v, v, v, v, v, v;
boolean v;
java.util.Set v, v, v;
java.lang.IllegalArgumentException v;
org.apache.kafkaesque.common.metrics.MetricConfig v;
org.apache.kafkaesque.common.MetricName v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v := @parameter: org.apache.kafkaesque.common.MetricNameTemplate;
v := @parameter: java.util.Map;
v = new java.util.HashSet;
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
specialinvoke v.<java.util.HashSet: void <init>(java.util.Collection)>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.metrics.MetricConfig config()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.MetricConfig: java.util.Map tags()>();
v = interfaceinvoke v.<java.util.Map: java.util.Set keySet()>();
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.util.Set tags()>();
v = interfaceinvoke v.<java.util.Set: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String name()>();
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.Object: java.lang.String toString()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.String)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("For \'\u0001\', runtime-defined metric tags do not match the tags in the template. Runtime = \u Template = \u0001");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String name()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String group()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.MetricNameTemplate: java.lang.String description()>();
v = virtualinvoke v.<org.apache.kafkaesque.common.metrics.Metrics: org.apache.kafkaesque.common.MetricName metricName(java.lang.String,java.lang.String,java.lang.String,java.util.Map)>(v, v, v, v);
return v;
}
public void close()
{
java.util.Iterator v;
org.apache.kafkaesque.common.metrics.Metrics v;
java.util.concurrent.ScheduledThreadPoolExecutor v, v, v;
java.util.concurrent.TimeUnit v;
java.util.List v;
java.lang.InterruptedException v;
java.lang.Thread v;
java.lang.Object v;
boolean v;
v := @this: org.apache.kafkaesque.common.metrics.Metrics;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler>;
if v == null goto label;
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler>;
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: void shutdown()>();
label:
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.concurrent.ScheduledThreadPoolExecutor metricsScheduler>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
virtualinvoke v.<java.util.concurrent.ScheduledThreadPoolExecutor: boolean awaitTermination(long,java.util.concurrent.TimeUnit)>(30L, v);
label:
goto label;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
v = v.<org.apache.kafkaesque.common.metrics.Metrics: java.util.List reporters>;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
goto label;
label:
return;
catch java.lang.InterruptedException from label to label with label;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/kafkaesque/common/metrics/Metrics;");
<org.apache.kafkaesque.common.metrics.Metrics: org.slf4j.Logger log> = v;
return;
}
}