public class oadd.org.apache.hadoop.util.RunJar extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
public static final java.util.regex.Pattern MATCH_ANY;
public static final int SHUTDOWN_HOOK_PRIORITY;
public static final java.lang.String HADOOP_USE_CLIENT_CLASSLOADER;
public static final java.lang.String HADOOP_CLASSPATH;
public static final java.lang.String HADOOP_CLIENT_CLASSLOADER_SYSTEM_CLASSES;
public static final java.lang.String HADOOP_CLIENT_SKIP_UNJAR;
private static final int BUFFER_SIZE;
public void <init>()
{
oadd.org.apache.hadoop.util.RunJar v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public void unJar(java.io.File, java.io.File) throws java.io.IOException
{
oadd.org.apache.hadoop.util.RunJar v;
java.util.regex.Pattern v;
java.io.File v, v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
v = <oadd.org.apache.hadoop.util.RunJar: java.util.regex.Pattern MATCH_ANY>;
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void unJar(java.io.File,java.io.File,java.util.regex.Pattern)>(v, v, v);
return;
}
public static void unJar(java.io.InputStream, java.io.File, java.util.regex.Pattern) throws java.io.IOException
{
java.lang.Throwable v, v;
long v;
java.lang.Integer v;
java.util.jar.JarEntry v;
java.util.regex.Matcher v;
oadd.org.apache.hadoop.io.IOUtils$NullOutputStream v;
int v;
java.util.jar.JarInputStream v;
java.lang.String v, v, v, v, v, v, v, v;
boolean v, v, v, v;
org.slf4j.Logger v;
java.io.FileOutputStream v;
java.io.IOException v;
java.io.File v, v, v;
java.util.regex.Pattern v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
v := @parameter: java.io.File;
v := @parameter: java.util.regex.Pattern;
v = new java.util.jar.JarInputStream;
specialinvoke v.<java.util.jar.JarInputStream: void <init>(java.io.InputStream)>(v);
label:
v = 0;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = <java.io.File: java.lang.String separator>;
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[])>("\u0001\u0001");
v = virtualinvoke v.<java.util.jar.JarInputStream: java.util.jar.JarEntry getNextJarEntry()>();
label:
if v == null goto label;
v = virtualinvoke v.<java.util.jar.JarEntry: boolean isDirectory()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean matches()>();
if v == 0 goto label;
v = new java.io.File;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v != 0 goto label;
v = new java.io.IOException;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.io.File)>(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[])>("expanding \u would create file outside of \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void ensureDirectory(java.io.File)>(v);
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
staticinvoke <oadd.org.apache.hadoop.io.IOUtils: void copyBytes(java.io.InputStream,java.io.OutputStream,int)>(v, v, 8192);
label:
virtualinvoke v.<java.io.OutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = virtualinvoke v.<java.util.jar.JarEntry: long getTime()>();
v = virtualinvoke v.<java.io.File: boolean setLastModified(long)>(v);
if v != 0 goto label;
v = v + 1;
label:
v = virtualinvoke v.<java.util.jar.JarInputStream: java.util.jar.JarEntry getNextJarEntry()>();
goto label;
label:
if v <= 0 goto label;
v = <oadd.org.apache.hadoop.util.RunJar: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("Could not set last modfied time for {} file(s)", v);
label:
v = new oadd.org.apache.hadoop.io.IOUtils$NullOutputStream;
specialinvoke v.<oadd.org.apache.hadoop.io.IOUtils$NullOutputStream: void <init>()>();
staticinvoke <oadd.org.apache.hadoop.io.IOUtils: void copyBytes(java.io.InputStream,java.io.OutputStream,int)>(v, v, 8192);
label:
virtualinvoke v.<java.util.jar.JarInputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static void unJarAndSave(java.io.InputStream, java.io.File, java.lang.String, java.util.regex.Pattern) throws java.io.IOException
{
java.lang.Throwable v, v;
java.io.FileOutputStream v;
oadd.org.apache.commons.io.input.TeeInputStream v;
java.io.File v, v;
java.lang.String v;
java.util.regex.Pattern v;
java.io.InputStream v;
v := @parameter: java.io.InputStream;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v := @parameter: java.util.regex.Pattern;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void ensureDirectory(java.io.File)>(v);
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
v = new oadd.org.apache.commons.io.input.TeeInputStream;
specialinvoke v.<oadd.org.apache.commons.io.input.TeeInputStream: void <init>(java.io.InputStream,java.io.OutputStream)>(v, v);
label:
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void unJar(java.io.InputStream,java.io.File,java.util.regex.Pattern)>(v, v, v);
label:
virtualinvoke v.<oadd.org.apache.commons.io.input.TeeInputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
virtualinvoke v.<java.io.OutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static void unJar(java.io.File, java.io.File, java.util.regex.Pattern) throws java.io.IOException
{
java.util.Enumeration v;
java.util.jar.JarFile v;
java.lang.Integer v;
java.util.regex.Matcher v;
boolean v, v, v, v, v;
java.util.regex.Pattern v;
java.lang.Throwable v, v, v;
long v;
int v;
java.lang.String v, v, v, v, v, v, v, v;
org.slf4j.Logger v;
java.io.FileOutputStream v;
java.io.IOException v;
java.io.File v, v, v, v;
java.lang.Object v;
java.io.InputStream v;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
v := @parameter: java.util.regex.Pattern;
v = new java.util.jar.JarFile;
specialinvoke v.<java.util.jar.JarFile: void <init>(java.io.File)>(v);
label:
v = 0;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = <java.io.File: java.lang.String separator>;
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[])>("\u0001\u0001");
v = virtualinvoke v.<java.util.jar.JarFile: java.util.Enumeration entries()>();
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.util.jar.JarEntry: boolean isDirectory()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean matches()>();
if v == 0 goto label;
v = virtualinvoke v.<java.util.jar.JarFile: java.io.InputStream getInputStream(java.util.zip.ZipEntry)>(v);
label:
v = new java.io.File;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v != 0 goto label;
v = new java.io.IOException;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.io.File)>(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[])>("expanding \u would create file outside of \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.io.File: java.io.File getParentFile()>();
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void ensureDirectory(java.io.File)>(v);
v = new java.io.FileOutputStream;
specialinvoke v.<java.io.FileOutputStream: void <init>(java.io.File)>(v);
label:
staticinvoke <oadd.org.apache.hadoop.io.IOUtils: void copyBytes(java.io.InputStream,java.io.OutputStream,int)>(v, v, 8192);
label:
virtualinvoke v.<java.io.OutputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = virtualinvoke v.<java.util.jar.JarEntry: long getTime()>();
v = virtualinvoke v.<java.io.File: boolean setLastModified(long)>(v);
if v != 0 goto label;
v = v + 1;
label:
if v == null goto label;
virtualinvoke v.<java.io.InputStream: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
if v <= 0 goto label;
v = <oadd.org.apache.hadoop.util.RunJar: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("Could not set last modfied time for {} file(s)", v);
label:
virtualinvoke v.<java.util.jar.JarFile: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return;
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;
}
private static void ensureDirectory(java.io.File) throws java.io.IOException
{
java.io.IOException v;
java.lang.String v, v;
java.io.File v;
boolean v, v;
v := @parameter: java.io.File;
v = virtualinvoke v.<java.io.File: boolean mkdirs()>();
if v != 0 goto label;
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v != 0 goto label;
v = new java.io.IOException;
v = virtualinvoke v.<java.io.File: 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[])>("Mkdirs failed to create \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
public static void main(java.lang.String[]) throws java.lang.Throwable
{
oadd.org.apache.hadoop.util.RunJar v;
java.lang.String[] v;
v := @parameter: java.lang.String[];
v = new oadd.org.apache.hadoop.util.RunJar;
specialinvoke v.<oadd.org.apache.hadoop.util.RunJar: void <init>()>();
virtualinvoke v.<oadd.org.apache.hadoop.util.RunJar: void run(java.lang.String[])>(v);
return;
}
public void run(java.lang.String[]) throws java.lang.Throwable
{
java.util.jar.Manifest v;
oadd.org.apache.hadoop.util.RunJar v;
java.util.jar.JarFile v;
java.lang.Thread v;
java.lang.reflect.Method v;
boolean v, v, v, v;
java.util.jar.Attributes v;
java.lang.reflect.InvocationTargetException v;
java.util.List v, v;
java.lang.ClassLoader v;
java.lang.Throwable v, v;
java.lang.Object[] v, v;
java.lang.String[] v, v;
oadd.org.apache.hadoop.util.RunJar$1 v;
oadd.org.apache.hadoop.util.ShutdownHookManager v;
int v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.io.PrintStream v, v, v, v, v;
java.lang.Class[] v;
java.io.IOException v, v, v;
java.io.File v, v, v;
java.lang.Class v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v := @parameter: java.lang.String[];
v = lengthof v;
if v >= 1 goto label;
v = <java.lang.System: java.io.PrintStream err>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>("RunJar jarFile [mainClass] args...");
v = (int) -1;
staticinvoke <java.lang.System: void exit(int)>(v);
label:
v = 1;
v = v[0];
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: boolean isFile()>();
if v != 0 goto label;
label:
v = <java.lang.System: java.io.PrintStream err>;
v = virtualinvoke v.<java.io.File: java.lang.String getCanonicalPath()>();
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[])>("JAR does not exist or is not a normal file: \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = (int) -1;
staticinvoke <java.lang.System: void exit(int)>(v);
label:
v = null;
label:
v = new java.util.jar.JarFile;
specialinvoke v.<java.util.jar.JarFile: void <init>(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
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 opening job jar: \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.IOException: java.lang.Throwable initCause(java.lang.Throwable)>(v);
throw v;
label:
v = virtualinvoke v.<java.util.jar.JarFile: java.util.jar.Manifest getManifest()>();
if v == null goto label;
v = virtualinvoke v.<java.util.jar.Manifest: java.util.jar.Attributes getMainAttributes()>();
v = virtualinvoke v.<java.util.jar.Attributes: java.lang.String getValue(java.lang.String)>("Main-Class");
label:
virtualinvoke v.<java.util.jar.JarFile: void close()>();
if v != null goto label;
v = lengthof v;
if v >= 2 goto label;
v = <java.lang.System: java.io.PrintStream err>;
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>("RunJar jarFile [mainClass] args...");
v = (int) -1;
staticinvoke <java.lang.System: void exit(int)>(v);
label:
v = 2;
v = v[1];
label:
v = virtualinvoke v.<java.lang.String: java.lang.String replaceAll(java.lang.String,java.lang.String)>("/", ".");
v = new java.io.File;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("java.io.tmpdir");
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void ensureDirectory(java.io.File)>(v);
label:
v = staticinvoke <java.io.File: java.io.File createTempFile(java.lang.String,java.lang.String,java.io.File)>("hadoop-unjar", "", v);
label:
goto label;
label:
v := @caughtexception;
v = <java.lang.System: java.io.PrintStream err>;
v = virtualinvoke v.<java.io.IOException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File,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[])>("Error creating temp dir in java.io.tmpdir \u due to \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = (int) -1;
staticinvoke <java.lang.System: void exit(int)>(v);
return;
label:
v = virtualinvoke v.<java.io.File: boolean delete()>();
if v != 0 goto label;
v = <java.lang.System: java.io.PrintStream err>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Delete failed for \u0001");
virtualinvoke v.<java.io.PrintStream: void println(java.lang.String)>(v);
v = (int) -1;
staticinvoke <java.lang.System: void exit(int)>(v);
label:
staticinvoke <oadd.org.apache.hadoop.util.RunJar: void ensureDirectory(java.io.File)>(v);
v = staticinvoke <oadd.org.apache.hadoop.util.ShutdownHookManager: oadd.org.apache.hadoop.util.ShutdownHookManager get()>();
v = new oadd.org.apache.hadoop.util.RunJar$1;
specialinvoke v.<oadd.org.apache.hadoop.util.RunJar$1: void <init>(oadd.org.apache.hadoop.util.RunJar,java.io.File)>(v, v);
virtualinvoke v.<oadd.org.apache.hadoop.util.ShutdownHookManager: void addShutdownHook(java.lang.Runnable,int)>(v, 10);
v = virtualinvoke v.<oadd.org.apache.hadoop.util.RunJar: boolean skipUnjar()>();
if v != 0 goto label;
virtualinvoke v.<oadd.org.apache.hadoop.util.RunJar: void unJar(java.io.File,java.io.File)>(v, v);
label:
v = specialinvoke v.<oadd.org.apache.hadoop.util.RunJar: java.lang.ClassLoader createClassLoader(java.io.File,java.io.File)>(v, v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String,boolean,java.lang.ClassLoader)>(v, 1, v);
v = newarray (java.lang.Class)[1];
v[0] = class "[Ljava/lang/String;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("main", v);
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
v = lengthof v;
v = interfaceinvoke v.<java.util.List: java.util.List subList(int,int)>(v, v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.String)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
label:
v = newarray (java.lang.Object)[1];
v[0] = v;
virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(null, v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
throw v;
label:
return;
catch java.io.IOException from label to label with label;
catch java.io.IOException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
}
private java.lang.ClassLoader createClassLoader(java.io.File, java.io.File) throws java.net.MalformedURLException
{
java.net.URL v, v, v, v;
oadd.org.apache.hadoop.util.RunJar v;
java.net.URL[] v;
java.net.URLClassLoader v, v;
java.net.URI v, v, v, v;
boolean v, v;
java.util.List v;
java.lang.StringBuilder v, v, v, v, v, v, v, v, v, v, v;
java.lang.ClassLoader v;
java.lang.Object[] v;
java.lang.String[] v;
java.util.ArrayList v;
int v, v, v;
oadd.org.apache.hadoop.util.ApplicationClassLoader v;
java.lang.String v, v, v, v, v, v, v, v;
java.io.File v, v, v, v, v, v;
java.lang.Class v;
java.io.File[] v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
v = virtualinvoke v.<oadd.org.apache.hadoop.util.RunJar: boolean useClientClassLoader()>();
if v == 0 goto label;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.Object)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("/");
v = <java.io.File: java.lang.String pathSeparator>;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.Object)>(v);
v = <java.io.File: java.lang.String pathSeparator>;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.Object)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("/classes/");
v = <java.io.File: java.lang.String pathSeparator>;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.Object)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("/lib/*");
v = virtualinvoke v.<oadd.org.apache.hadoop.util.RunJar: java.lang.String getHadoopClasspath()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean isEmpty()>();
if v != 0 goto label;
v = <java.io.File: java.lang.String pathSeparator>;
v = 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)>(v);
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = virtualinvoke v.<oadd.org.apache.hadoop.util.RunJar: java.lang.String getSystemClasses()>();
if v != null goto label;
v = null;
goto label;
label:
v = staticinvoke <oadd.org.apache.hadoop.util.StringUtils: java.lang.String[] getTrimmedStrings(java.lang.String)>(v);
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
label:
v = new oadd.org.apache.hadoop.util.ApplicationClassLoader;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
specialinvoke v.<oadd.org.apache.hadoop.util.ApplicationClassLoader: void <init>(java.lang.String,java.lang.ClassLoader,java.util.List)>(v, v, v);
v = v;
goto label;
label:
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = new java.io.File;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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/");
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
v = virtualinvoke v.<java.net.URI: java.net.URL toURL()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
v = virtualinvoke v.<java.net.URI: java.net.URL toURL()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, "classes/");
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
v = virtualinvoke v.<java.net.URI: java.net.URL toURL()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, "lib");
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles()>();
if v == null goto label;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.io.File: java.net.URI toURI()>();
v = virtualinvoke v.<java.net.URI: java.net.URL toURL()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
v = new java.net.URLClassLoader;
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.net.URL)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
specialinvoke v.<java.net.URLClassLoader: void <init>(java.net.URL[])>(v);
v = v;
label:
return v;
}
boolean useClientClassLoader()
{
oadd.org.apache.hadoop.util.RunJar v;
java.lang.String v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>("HADOOP_USE_CLIENT_CLASSLOADER");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
return v;
}
boolean skipUnjar()
{
oadd.org.apache.hadoop.util.RunJar v;
java.lang.String v;
boolean v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>("HADOOP_CLIENT_SKIP_UNJAR");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
return v;
}
java.lang.String getHadoopClasspath()
{
oadd.org.apache.hadoop.util.RunJar v;
java.lang.String v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>("HADOOP_CLASSPATH");
return v;
}
java.lang.String getSystemClasses()
{
oadd.org.apache.hadoop.util.RunJar v;
java.lang.String v;
v := @this: oadd.org.apache.hadoop.util.RunJar;
v = staticinvoke <java.lang.System: java.lang.String getenv(java.lang.String)>("HADOOP_CLIENT_CLASSLOADER_SYSTEM_CLASSES");
return v;
}
static void <clinit>()
{
java.util.regex.Pattern v;
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Loadd/org/apache/hadoop/util/RunJar;");
<oadd.org.apache.hadoop.util.RunJar: org.slf4j.Logger LOG> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>(".*");
<oadd.org.apache.hadoop.util.RunJar: java.util.regex.Pattern MATCH_ANY> = v;
return;
}
}