public final class org.apache.htrace.core.TracerId extends java.lang.Object
{
private static final org.apache.htrace.shaded.commons.logging.Log LOG;
public static final java.lang.String TRACER_ID_KEY;
private static final java.lang.String DEFAULT_TRACER_ID;
private final java.lang.String tracerName;
private final java.lang.String tracerId;
public void <init>(org.apache.htrace.core.HTraceConfiguration, java.lang.String)
{
org.apache.htrace.core.TracerId v;
org.apache.htrace.core.HTraceConfiguration v;
int v, v, v;
java.lang.String v, v, v, v, v, v, v, v;
boolean v, v;
char v;
org.apache.htrace.shaded.commons.logging.Log v, v, v;
java.lang.StringBuilder v, v, v, v;
v := @this: org.apache.htrace.core.TracerId;
v := @parameter: org.apache.htrace.core.HTraceConfiguration;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.htrace.core.TracerId: java.lang.String tracerName> = v;
v = virtualinvoke v.<org.apache.htrace.core.HTraceConfiguration: java.lang.String get(java.lang.String,java.lang.String)>("tracer.id", "%{tname}/%{ip}");
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = null;
v = 0;
v = 0;
v = 0;
v = virtualinvoke v.<java.lang.String: int length()>();
label:
if v >= v goto label;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
if v != 92 goto label;
if v != 0 goto label;
v = 1;
goto label;
label:
lookupswitch(v)
{
case 0: goto label;
case 1: goto label;
default: goto label;
};
label:
if v != 37 goto label;
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
v = 0;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(v);
goto label;
label:
if v != 123 goto label;
if v != 0 goto label;
v = 2;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = v;
goto label;
label:
v = 0;
v = 0;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("%");
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(v);
goto label;
label:
if v != 125 goto label;
if v != 0 goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = specialinvoke v.<org.apache.htrace.core.TracerId: java.lang.String processShellVar(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = null;
v = 0;
goto label;
label:
v = 0;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(v);
v = v + 1;
label:
v = v + 1;
goto label;
label:
if v <= 0 goto label;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
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[])>("Unterminated process ID substitution variable at the end of format string \u0001");
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void warn(java.lang.Object)>(v);
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v.<org.apache.htrace.core.TracerId: java.lang.String tracerId> = v;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
v = interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
v = v.<org.apache.htrace.core.TracerId: java.lang.String tracerId>;
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[])>("ProcessID(fmt=\u): computed process ID of \"\u0001\"");
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void trace(java.lang.Object)>(v);
label:
return;
}
private java.lang.String processShellVar(java.lang.String)
{
org.apache.htrace.core.TracerId v;
long v;
org.apache.htrace.shaded.commons.logging.Log v;
java.lang.Long v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v, v;
v := @this: org.apache.htrace.core.TracerId;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("tname");
if v == 0 goto label;
v = v.<org.apache.htrace.core.TracerId: java.lang.String tracerName>;
return v;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("pname");
if v == 0 goto label;
v = staticinvoke <org.apache.htrace.core.TracerId: java.lang.String getProcessName()>();
return v;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("ip");
if v == 0 goto label;
v = staticinvoke <org.apache.htrace.core.TracerId: java.lang.String getBestIpString()>();
return v;
label:
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("pid");
if v == 0 goto label;
v = staticinvoke <org.apache.htrace.core.TracerId: long getOsPid()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<java.lang.Long: java.lang.String toString()>();
return v;
label:
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
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[])>("unknown ProcessID variable \u0001");
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void warn(java.lang.Object)>(v);
return "";
}
static java.lang.String getProcessName()
{
java.lang.String[] v, v;
int v, v;
java.lang.String v, v, v;
boolean v, v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("sun.java.command");
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>("\\s+");
v = v[0];
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>("\\.");
v = lengthof v;
v = v - 1;
v = v[v];
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v == 0 goto label;
label:
v = "Unknown";
goto label;
label:
v = v;
label:
return v;
}
static java.lang.String getBestIpString()
{
java.util.Enumeration v, v;
java.util.TreeSet v, v;
java.net.SocketException v;
java.lang.String v, v;
boolean v, v, v, v, v, v;
org.apache.htrace.shaded.commons.logging.Log v;
java.lang.Object v, v, v, v;
label:
v = staticinvoke <java.net.NetworkInterface: java.util.Enumeration getNetworkInterfaces()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void error(java.lang.Object,java.lang.Throwable)>("Error getting network interfaces", v);
return "127.0.0.1";
label:
v = new java.util.TreeSet;
specialinvoke v.<java.util.TreeSet: void <init>()>();
v = new java.util.TreeSet;
specialinvoke v.<java.util.TreeSet: void <init>()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
v = virtualinvoke v.<java.net.NetworkInterface: java.util.Enumeration getInetAddresses()>();
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
v = virtualinvoke v.<java.net.InetAddress: boolean isLoopbackAddress()>();
if v != 0 goto label;
v = virtualinvoke v.<java.net.InetAddress: boolean isSiteLocalAddress()>();
if v == 0 goto label;
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostAddress()>();
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
goto label;
label:
v = virtualinvoke v.<java.net.InetAddress: java.lang.String getHostAddress()>();
virtualinvoke v.<java.util.TreeSet: boolean add(java.lang.Object)>(v);
goto label;
label:
v = virtualinvoke v.<java.util.TreeSet: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object first()>();
return v;
label:
v = virtualinvoke v.<java.util.TreeSet: boolean isEmpty()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.TreeSet: java.lang.Object first()>();
return v;
label:
return "127.0.0.1";
catch java.net.SocketException from label to label with label;
}
static long getOsPid()
{
java.util.Locale v;
long v, v;
java.lang.String v, v;
boolean v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String,java.lang.String)>("os.name", "generic");
v = <java.util.Locale: java.util.Locale ENGLISH>;
v = virtualinvoke v.<java.lang.String: java.lang.String toLowerCase(java.util.Locale)>(v);
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("windows");
if v == 0 goto label;
v = staticinvoke <org.apache.htrace.core.TracerId: long getOsPidFromManagementFactory()>();
return v;
label:
v = staticinvoke <org.apache.htrace.core.TracerId: long getOsPidFromShellPpid()>();
return v;
}
private static long getOsPidFromShellPpid()
{
java.lang.Throwable v;
java.lang.String[] v;
long v;
java.lang.Integer v;
int v;
java.lang.ProcessBuilder v, v;
java.lang.String v, v, v, v, v;
java.lang.Process v;
java.io.IOException v, v;
java.lang.NumberFormatException v;
java.io.InputStreamReader v;
org.apache.htrace.shaded.commons.logging.Log v, v, v;
java.lang.InterruptedException v;
java.lang.StringBuilder v;
java.io.BufferedReader v;
java.io.InputStream v;
v = null;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
label:
v = new java.lang.ProcessBuilder;
v = newarray (java.lang.String)[4];
v[0] = "/usr/bin/env";
v[1] = "sh";
v[2] = "-c";
v[3] = "echo $PPID";
specialinvoke v.<java.lang.ProcessBuilder: void <init>(java.lang.String[])>(v);
v = virtualinvoke v.<java.lang.ProcessBuilder: java.lang.ProcessBuilder redirectErrorStream(boolean)>(1);
v = virtualinvoke v.<java.lang.ProcessBuilder: java.lang.Process start()>();
v = new java.io.BufferedReader;
v = new java.io.InputStreamReader;
v = virtualinvoke v.<java.lang.Process: java.io.InputStream getInputStream()>();
specialinvoke v.<java.io.InputStreamReader: void <init>(java.io.InputStream)>(v);
specialinvoke v.<java.io.BufferedReader: void <init>(java.io.Reader)>(v);
label:
v = virtualinvoke v.<java.io.BufferedReader: java.lang.String readLine()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.Process: int waitFor()>();
if v == 0 goto label;
v = new java.io.IOException;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<java.lang.Integer: java.lang.String toString()>();
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[])>("Process exited with error code \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
virtualinvoke v.<java.lang.Process: void destroy()>();
goto label;
label:
v := @caughtexception;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void error(java.lang.Object,java.lang.Throwable)>("Interrupted while getting operating system pid from the shell.", v);
label:
if v == null goto label;
virtualinvoke v.<java.lang.Process: void destroy()>();
label:
return 0L;
label:
v := @caughtexception;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void error(java.lang.Object,java.lang.Throwable)>("Error getting operating system pid from the shell.", v);
label:
if v == null goto label;
virtualinvoke v.<java.lang.Process: void destroy()>();
label:
return 0L;
label:
v := @caughtexception;
if v == null goto label;
virtualinvoke v.<java.lang.Process: void destroy()>();
label:
throw v;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = staticinvoke <java.lang.Long: long parseLong(java.lang.String)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void error(java.lang.Object,java.lang.Throwable)>("Error parsing operating system pid from the shell.", v);
return 0L;
catch java.lang.InterruptedException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.NumberFormatException from label to label with label;
}
private static long getOsPidFromManagementFactory()
{
java.lang.management.RuntimeMXBean v;
java.lang.NumberFormatException v;
java.lang.String[] v;
long v;
java.lang.String v, v;
org.apache.htrace.shaded.commons.logging.Log v;
label:
v = staticinvoke <java.lang.management.ManagementFactory: java.lang.management.RuntimeMXBean getRuntimeMXBean()>();
v = interfaceinvoke v.<java.lang.management.RuntimeMXBean: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: java.lang.String[] split(java.lang.String)>("@");
v = v[0];
v = staticinvoke <java.lang.Long: long parseLong(java.lang.String)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG>;
interfaceinvoke v.<org.apache.htrace.shaded.commons.logging.Log: void error(java.lang.Object,java.lang.Throwable)>("Failed to get the operating system process ID from the name of the managed bean for the JVM.", v);
return 0L;
catch java.lang.NumberFormatException from label to label with label;
}
public java.lang.String get()
{
org.apache.htrace.core.TracerId v;
java.lang.String v;
v := @this: org.apache.htrace.core.TracerId;
v = v.<org.apache.htrace.core.TracerId: java.lang.String tracerId>;
return v;
}
static void <clinit>()
{
org.apache.htrace.shaded.commons.logging.Log v;
v = staticinvoke <org.apache.htrace.shaded.commons.logging.LogFactory: org.apache.htrace.shaded.commons.logging.Log getLog(java.lang.Class)>(class "Lorg/apache/htrace/core/TracerId;");
<org.apache.htrace.core.TracerId: org.apache.htrace.shaded.commons.logging.Log LOG> = v;
return;
}
}