public class nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver extends java.lang.Object implements nl.basjes.parse.useragent.utils.springframework.core.io.support.ResourcePatternResolver
{
private static final org.apache.logging.log4j.Logger LOGGER;
private static java.lang.reflect.Method equinoxResolveMethod;
private final nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader resourceLoader;
private final nl.basjes.parse.useragent.utils.springframework.util.PathMatcher pathMatcher;
public void <init>()
{
nl.basjes.parse.useragent.utils.springframework.util.AntPathMatcher v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
nl.basjes.parse.useragent.utils.springframework.core.io.DefaultResourceLoader v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new nl.basjes.parse.useragent.utils.springframework.util.AntPathMatcher;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.AntPathMatcher: void <init>()>();
v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher pathMatcher> = v;
v = new nl.basjes.parse.useragent.utils.springframework.core.io.DefaultResourceLoader;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.DefaultResourceLoader: void <init>()>();
v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader resourceLoader> = v;
return;
}
public void <init>(java.lang.ClassLoader)
{
nl.basjes.parse.useragent.utils.springframework.util.AntPathMatcher v;
java.lang.ClassLoader v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
nl.basjes.parse.useragent.utils.springframework.core.io.DefaultResourceLoader v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.ClassLoader;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new nl.basjes.parse.useragent.utils.springframework.util.AntPathMatcher;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.AntPathMatcher: void <init>()>();
v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher pathMatcher> = v;
v = new nl.basjes.parse.useragent.utils.springframework.core.io.DefaultResourceLoader;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.DefaultResourceLoader: void <init>(java.lang.ClassLoader)>(v);
v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader resourceLoader> = v;
return;
}
public nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader getResourceLoader()
{
nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v = v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader resourceLoader>;
return v;
}
public java.lang.ClassLoader getClassLoader()
{
java.lang.ClassLoader v;
nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader getResourceLoader()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader: java.lang.ClassLoader getClassLoader()>();
return v;
}
public nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()
{
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
nl.basjes.parse.useragent.utils.springframework.util.PathMatcher v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v = v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher pathMatcher>;
return v;
}
public nl.basjes.parse.useragent.utils.springframework.core.io.Resource getResource(java.lang.String)
{
java.lang.String v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v;
nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader getResourceLoader()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader: nl.basjes.parse.useragent.utils.springframework.core.io.Resource getResource(java.lang.String)>(v);
return v;
}
public nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] getResources(java.lang.String) throws java.io.IOException
{
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v;
nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v, v;
nl.basjes.parse.useragent.utils.springframework.util.PathMatcher v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] v, v, v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Location pattern must not be null");
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("classpath*:");
if v == 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
v = "classpath*:";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.PathMatcher: boolean isPattern(java.lang.String)>(v);
if v == 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] findPathMatchingResources(java.lang.String)>(v);
return v;
label:
v = "classpath*:";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] findAllClassPathResources(java.lang.String)>(v);
return v;
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("war:");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int indexOf(java.lang.String)>("*/");
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.String: int indexOf(int)>(58);
v = v + 1;
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.PathMatcher: boolean isPattern(java.lang.String)>(v);
if v == 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] findPathMatchingResources(java.lang.String)>(v);
return v;
label:
v = newarray (nl.basjes.parse.useragent.utils.springframework.core.io.Resource)[1];
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader getResourceLoader()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.ResourceLoader: nl.basjes.parse.useragent.utils.springframework.core.io.Resource getResource(java.lang.String)>(v);
v[0] = v;
return v;
}
protected nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] findAllClassPathResources(java.lang.String) throws java.io.IOException
{
java.lang.Object[] v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
org.apache.logging.log4j.Logger v, v;
java.lang.String v, v;
boolean v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v = v;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("/");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(1);
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.util.Set doFindAllClassPathResources(java.lang.String)>(v);
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Resolved classpath location [{}] to resources {}", v, v);
label:
v = newarray (nl.basjes.parse.useragent.utils.springframework.core.io.Resource)[0];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
protected java.util.Set doFindAllClassPathResources(java.lang.String) throws java.io.IOException
{
java.util.Enumeration v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.lang.Object v;
java.lang.ClassLoader v;
java.lang.String v;
java.util.LinkedHashSet v;
boolean v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>(int)>(16);
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.lang.ClassLoader getClassLoader()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.ClassLoader: java.util.Enumeration getResources(java.lang.String)>(v);
goto label;
label:
v = staticinvoke <java.lang.ClassLoader: java.util.Enumeration getSystemResources(java.lang.String)>(v);
label:
v = v;
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.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.Resource convertClassLoaderURL(java.net.URL)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: boolean hasLength(java.lang.String)>(v);
if v != 0 goto label;
virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: void addAllClassLoaderJarRoots(java.lang.ClassLoader,java.util.Set)>(v, v);
label:
return v;
}
protected nl.basjes.parse.useragent.utils.springframework.core.io.Resource convertClassLoaderURL(java.net.URL)
{
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.net.URL v;
nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.net.URL;
v = new nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: void <init>(java.net.URL)>(v);
return v;
}
protected void addAllClassLoaderJarRoots(java.lang.ClassLoader, java.util.Set)
{
java.net.URL v;
java.net.URL[] v;
int v, v;
java.lang.String v, v, v, v;
boolean v, v, v, v, v, v;
java.net.MalformedURLException v;
nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.lang.Exception v, v;
org.apache.logging.log4j.Logger v, v, v, v, v, v;
java.lang.ClassLoader v, v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.ClassLoader;
v := @parameter: java.util.Set;
v = v instanceof java.net.URLClassLoader;
if v == 0 goto label;
label:
v = virtualinvoke v.<java.net.URLClassLoader: java.net.URL[] getURLs()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
v = "jar";
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: void <init>(java.net.URL)>(v);
goto label;
label:
v = new nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.net.URL)>(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:\u0001!/");
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: void <init>(java.lang.String)>(v);
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: boolean exists()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.net.MalformedURLException: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Cannot search for matching files underneath [{}] because it cannot be converted to a valid \'jar:\' URL: {}", v, v);
label:
v = v + 1;
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Cannot introspect jar files since ClassLoader [{}] does not support \'getURLs()\': {}", v, v);
label:
v = staticinvoke <java.lang.ClassLoader: java.lang.ClassLoader getSystemClassLoader()>();
if v != v goto label;
virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: void addClassPathManifestEntries(java.util.Set)>(v);
label:
if v == null goto label;
label:
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.ClassLoader getParent()>();
virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: void addAllClassLoaderJarRoots(java.lang.ClassLoader,java.util.Set)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Cannot introspect jar files in parent ClassLoader since [{}] does not support \'getParent()\': {}", v, v);
label:
return;
catch java.net.MalformedURLException from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
protected void addClassPathManifestEntries(java.util.Set)
{
java.lang.String[] v;
int v, v, v;
java.lang.String v, v, v, v, v, v, v, v;
boolean v, v, v, v, v;
java.net.MalformedURLException v;
nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.io.File v;
java.lang.Exception v;
org.apache.logging.log4j.Logger v, v, v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.util.Set;
label:
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("java.class.path");
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("path.separator");
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: java.lang.String[] delimitedListToStringArray(java.lang.String,java.lang.String)>(v, v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.lang.String)>(v);
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = virtualinvoke v.<java.lang.String: int indexOf(int)>(58);
if v != 1 goto label;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: java.lang.String capitalize(java.lang.String)>(v);
label:
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: java.lang.String replace(java.lang.String,java.lang.String,java.lang.String)>(v, "#", "%23");
v = new nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource;
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:file:\u0001!/");
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: void <init>(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v != 0 goto label;
v = specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: boolean hasDuplicate(java.lang.String,java.util.Set)>(v, v);
if v != 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: boolean exists()>();
if v == 0 goto label;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.net.MalformedURLException: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Cannot search for matching files underneath [{}] because it cannot be converted to a valid \'jar:\' URL: {}", v, v);
label:
v = v + 1;
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Failed to evaluate \'java.class.path\' manifest entries: {}", v);
label:
return;
catch java.net.MalformedURLException from label to label with label;
catch java.lang.Exception from label to label with label;
}
private boolean hasDuplicate(java.lang.String, java.util.Set)
{
java.net.MalformedURLException v;
nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.lang.String v, v, v;
boolean v, v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v := @parameter: java.util.Set;
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v == 0 goto label;
return 0;
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("/");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(1);
goto label;
label:
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[])>("/\u0001");
label:
v = new nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource;
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:file:\u0001!/");
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: void <init>(java.lang.String)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
label:
return v;
label:
v := @caughtexception;
return 0;
catch java.net.MalformedURLException from label to label with label;
}
protected nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] findPathMatchingResources(java.lang.String) throws java.io.IOException
{
java.lang.Object[] v, v;
java.net.URL v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v, v;
int v, v, v;
java.lang.String v, v, v, v, v;
java.lang.reflect.Method v, v;
java.util.LinkedHashSet v;
boolean v, v, v, v;
nl.basjes.parse.useragent.utils.springframework.util.PathMatcher v;
nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource v;
java.util.Set v, v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
org.apache.logging.log4j.Logger v, v;
java.lang.Object v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.lang.String determineRootDir(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.Resource[] getResources(java.lang.String)>(v);
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>(int)>(16);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.core.io.Resource resolveRootDirResource(nl.basjes.parse.useragent.utils.springframework.core.io.Resource)>(v);
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.Resource: java.net.URL getURL()>();
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.lang.reflect.Method equinoxResolveMethod>;
if v == null goto label;
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("bundle");
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.lang.reflect.Method equinoxResolveMethod>;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.Object invokeMethod(java.lang.reflect.Method,java.lang.Object,java.lang.Object[])>(v, null, v);
if v == null goto label;
v = v;
label:
v = new nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.UrlResource: void <init>(java.net.URL)>(v);
v = v;
label:
v = virtualinvoke v.<java.net.URL: java.lang.String getProtocol()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("vfs");
if v == 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver$VfsResourceMatchingDelegate: java.util.Set findMatchingResources(java.net.URL,java.lang.String,nl.basjes.parse.useragent.utils.springframework.util.PathMatcher)>(v, v, v);
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
goto label;
label:
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ResourceUtils: boolean isJarURL(java.net.URL)>(v);
if v == 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.util.Set doFindPathMatchingJarResources(nl.basjes.parse.useragent.utils.springframework.core.io.Resource,java.net.URL,java.lang.String)>(v, v, v);
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
goto label;
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.util.Set doFindPathMatchingFileResources(nl.basjes.parse.useragent.utils.springframework.core.io.Resource,java.lang.String)>(v, v);
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
label:
v = v + 1;
goto label;
label:
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Resolved location pattern [{}] to resources {}", v, v);
label:
v = newarray (nl.basjes.parse.useragent.utils.springframework.core.io.Resource)[0];
v = interfaceinvoke v.<java.util.Set: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
protected java.lang.String determineRootDir(java.lang.String)
{
nl.basjes.parse.useragent.utils.springframework.util.PathMatcher v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
int v, v, v, v, v;
java.lang.String v, v, v;
boolean v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: int indexOf(int)>(58);
v = v + 1;
v = virtualinvoke v.<java.lang.String: int length()>();
label:
if v <= v goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(v, v);
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.PathMatcher: boolean isPattern(java.lang.String)>(v);
if v == 0 goto label;
v = v - 2;
v = virtualinvoke v.<java.lang.String: int lastIndexOf(int,int)>(47, v);
v = v + 1;
goto label;
label:
if v != 0 goto label;
v = v;
label:
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
return v;
}
protected nl.basjes.parse.useragent.utils.springframework.core.io.Resource resolveRootDirResource(nl.basjes.parse.useragent.utils.springframework.core.io.Resource) throws java.io.IOException
{
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: nl.basjes.parse.useragent.utils.springframework.core.io.Resource;
return v;
}
protected java.util.Set doFindPathMatchingJarResources(nl.basjes.parse.useragent.utils.springframework.core.io.Resource, java.net.URL, java.lang.String) throws java.io.IOException
{
java.util.Enumeration v;
java.net.URL v, v;
java.util.jar.JarFile v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v, v;
boolean v, v, v, v, v, v, v, v, v, v, v;
java.util.zip.ZipException v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
org.apache.logging.log4j.Logger v, v, v, v;
java.lang.Throwable v;
java.util.jar.JarEntry v;
java.net.URLConnection v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v;
java.util.LinkedHashSet v;
nl.basjes.parse.useragent.utils.springframework.util.PathMatcher v;
java.lang.Object v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: nl.basjes.parse.useragent.utils.springframework.core.io.Resource;
v := @parameter: java.net.URL;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.net.URL: java.net.URLConnection openConnection()>();
v = v instanceof java.net.JarURLConnection;
if v == 0 goto label;
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ResourceUtils: void useCachesIfNecessary(java.net.URLConnection)>(v);
v = virtualinvoke v.<java.net.JarURLConnection: java.util.jar.JarFile getJarFile()>();
v = virtualinvoke v.<java.net.JarURLConnection: java.net.URL getJarFileURL()>();
v = virtualinvoke v.<java.net.URL: java.lang.String toExternalForm()>();
v = virtualinvoke v.<java.net.JarURLConnection: java.util.jar.JarEntry getJarEntry()>();
if v == null goto label;
v = virtualinvoke v.<java.util.jar.JarEntry: java.lang.String getName()>();
goto label;
label:
v = "";
label:
v = v;
v = virtualinvoke v.<java.net.JarURLConnection: boolean getUseCaches()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
goto label;
label:
v = virtualinvoke v.<java.net.URL: java.lang.String getFile()>();
label:
v = virtualinvoke v.<java.lang.String: int indexOf(java.lang.String)>("*/");
v = (int) -1;
if v != v goto label;
v = virtualinvoke v.<java.lang.String: int indexOf(java.lang.String)>("!/");
label:
v = (int) -1;
if v == v goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int,int)>(0, v);
v = v + 2;
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.util.jar.JarFile getJarFile(java.lang.String)>(v);
goto label;
label:
v = new java.util.jar.JarFile;
specialinvoke v.<java.util.jar.JarFile: void <init>(java.lang.String)>(v);
v = v;
v = v;
v = "";
label:
v = 1;
label:
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Skipping invalid jar classpath entry [{}]", v);
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
return v;
label:
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("Looking for matching resources in jar file [{}]", v);
label:
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: boolean hasLength(java.lang.String)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>("/");
if v != 0 goto label;
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[])>("\u0001/");
label:
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>(int)>(8);
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: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.PathMatcher: boolean match(java.lang.String,java.lang.String)>(v, v);
if v == 0 goto label;
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.Resource: nl.basjes.parse.useragent.utils.springframework.core.io.Resource createRelative(java.lang.String)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
if v == 0 goto label;
virtualinvoke v.<java.util.jar.JarFile: void close()>();
label:
return v;
label:
v := @caughtexception;
if v == 0 goto label;
virtualinvoke v.<java.util.jar.JarFile: void close()>();
label:
throw v;
catch java.util.zip.ZipException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
protected java.util.jar.JarFile getJarFile(java.lang.String) throws java.io.IOException
{
java.net.URISyntaxException v;
java.util.jar.JarFile v, v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
int v;
java.lang.String v, v, v, v;
java.net.URI v;
boolean v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("file:");
if v == 0 goto label;
label:
v = new java.util.jar.JarFile;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ResourceUtils: java.net.URI toURI(java.lang.String)>(v);
v = virtualinvoke v.<java.net.URI: java.lang.String getSchemeSpecificPart()>();
specialinvoke v.<java.util.jar.JarFile: void <init>(java.lang.String)>(v);
label:
return v;
label:
v := @caughtexception;
v = new java.util.jar.JarFile;
v = "file:";
v = virtualinvoke v.<java.lang.String: int length()>();
v = virtualinvoke v.<java.lang.String: java.lang.String substring(int)>(v);
specialinvoke v.<java.util.jar.JarFile: void <init>(java.lang.String)>(v);
return v;
label:
v = new java.util.jar.JarFile;
specialinvoke v.<java.util.jar.JarFile: void <init>(java.lang.String)>(v);
return v;
catch java.net.URISyntaxException from label to label with label;
}
protected java.util.Set doFindPathMatchingFileResources(nl.basjes.parse.useragent.utils.springframework.core.io.Resource, java.lang.String) throws java.io.IOException
{
nl.basjes.parse.useragent.utils.springframework.core.io.Resource v;
java.lang.String v, v;
boolean v, v;
java.util.Set v, v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.io.File v, v;
java.io.FileNotFoundException v;
java.lang.Exception v;
org.apache.logging.log4j.Logger v, v, v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: nl.basjes.parse.useragent.utils.springframework.core.io.Resource;
v := @parameter: java.lang.String;
label:
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.Resource: java.io.File getFile()>();
v = virtualinvoke v.<java.io.File: java.io.File getAbsoluteFile()>();
label:
goto label;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.FileNotFoundException: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Cannot search for matching files underneath {} in the file system: {}", v, v);
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
return v;
label:
v := @caughtexception;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Failed to resolve {} in the file system: {}", v, v);
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
return v;
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.util.Set doFindMatchingFileSystemResources(java.io.File,java.lang.String)>(v, v);
return v;
catch java.io.FileNotFoundException from label to label with label;
catch java.lang.Exception from label to label with label;
}
protected java.util.Set doFindMatchingFileSystemResources(java.io.File, java.lang.String) throws java.io.IOException
{
java.util.Iterator v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.io.File v;
org.apache.logging.log4j.Logger v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.FileSystemResource v;
int v;
java.lang.Object v;
java.lang.String v, v;
java.util.LinkedHashSet v;
boolean v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("Looking for matching resources in directory tree [{}]", v);
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.util.Set retrieveMatchingFiles(java.io.File,java.lang.String)>(v, v);
v = new java.util.LinkedHashSet;
v = interfaceinvoke v.<java.util.Set: int size()>();
specialinvoke v.<java.util.LinkedHashSet: void <init>(int)>(v);
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 = new nl.basjes.parse.useragent.utils.springframework.core.io.FileSystemResource;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.FileSystemResource: void <init>(java.io.File)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
return v;
}
protected java.util.Set retrieveMatchingFiles(java.io.File, java.lang.String) throws java.io.IOException
{
java.lang.String v, v, v, v, v, v, v, v, v, v;
java.util.LinkedHashSet v;
boolean v, v, v, v, v, v, v;
java.util.Set v, v, v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.io.File v;
org.apache.logging.log4j.Logger v, v, v, v, v, v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.io.File;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Skipping [{}] because it does not exist", v);
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
return v;
label:
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v != 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object)>("Skipping [{}] because it does not denote a directory", v);
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
return v;
label:
v = virtualinvoke v.<java.io.File: boolean canRead()>();
if v != 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object)>("Skipping search for matching files underneath directory [{}] because the application is not allowed to read the directory", v);
label:
v = staticinvoke <java.util.Collections: java.util.Set emptySet()>();
return v;
label:
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = <java.io.File: java.lang.String separator>;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: java.lang.String replace(java.lang.String,java.lang.String,java.lang.String)>(v, v, "/");
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("/");
if v != 0 goto label;
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[])>("\u0001/");
label:
v = <java.io.File: java.lang.String separator>;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: java.lang.String replace(java.lang.String,java.lang.String,java.lang.String)>(v, v, "/");
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 = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>(int)>(8);
virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: void doRetrieveMatchingFiles(java.lang.String,java.io.File,java.util.Set)>(v, v, v);
return v;
}
protected void doRetrieveMatchingFiles(java.lang.String, java.io.File, java.util.Set) throws java.io.IOException
{
int v, v;
java.lang.String v, v, v, v, v, v, v;
boolean v, v, v, v, v, v;
nl.basjes.parse.useragent.utils.springframework.util.PathMatcher v, v;
java.util.Set v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.io.File v, v;
org.apache.logging.log4j.Logger v, v, v, v;
java.io.File[] v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.lang.String;
v := @parameter: java.io.File;
v := @parameter: java.util.Set;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Searching directory [{}] for files matching pattern [{}]", v, v);
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.io.File[] listDirectory(java.io.File)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
v = <java.io.File: java.lang.String separator>;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.StringUtils: java.lang.String replace(java.lang.String,java.lang.String,java.lang.String)>(v, v, "/");
v = virtualinvoke v.<java.io.File: boolean isDirectory()>();
if v == 0 goto label;
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
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[])>("\u0001/");
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.PathMatcher: boolean matchStart(java.lang.String,java.lang.String)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<java.io.File: boolean canRead()>();
if v != 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Skipping subdirectory [{}] because the application is not allowed to read the directory", v);
goto label;
label:
virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: void doRetrieveMatchingFiles(java.lang.String,java.io.File,java.util.Set)>(v, v, v);
label:
v = virtualinvoke v.<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: nl.basjes.parse.useragent.utils.springframework.util.PathMatcher getPathMatcher()>();
v = interfaceinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.PathMatcher: boolean match(java.lang.String,java.lang.String)>(v, v);
if v == 0 goto label;
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = v + 1;
goto label;
label:
return;
}
protected java.io.File[] listDirectory(java.io.File)
{
java.util.function.Function v;
nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver v;
java.io.File v;
org.apache.logging.log4j.Logger v, v;
java.lang.String v;
java.util.Comparator v;
java.io.File[] v, v;
boolean v;
v := @this: nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver;
v := @parameter: java.io.File;
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles()>();
if v != null goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = interfaceinvoke v.<org.apache.logging.log4j.Logger: boolean isInfoEnabled()>();
if v == 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void info(java.lang.String,java.lang.Object)>("Could not retrieve contents of directory [{}]", v);
label:
v = newarray (java.io.File)[0];
return v;
label:
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver$getName__622: java.util.function.Function bootstrap$()>();
v = staticinvoke <java.util.Comparator: java.util.Comparator comparing(java.util.function.Function)>(v);
staticinvoke <java.util.Arrays: void sort(java.lang.Object[],java.util.Comparator)>(v, v);
return v;
}
static void <clinit>()
{
java.lang.Throwable v;
java.lang.Class[] v;
org.apache.logging.log4j.Logger v, v;
java.lang.Class v, v;
java.lang.ClassLoader v;
java.lang.reflect.Method v;
v = staticinvoke <org.apache.logging.log4j.LogManager: org.apache.logging.log4j.Logger getLogger(java.lang.Class)>(class "Lnl/basjes/parse/useragent/utils/springframework/core/io/support/PathMatchingResourcePatternResolver;");
<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER> = v;
label:
v = class "Lnl/basjes/parse/useragent/utils/springframework/core/io/support/PathMatchingResourcePatternResolver;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ClassUtils: java.lang.Class forName(java.lang.String,java.lang.ClassLoader)>("org.eclipse.core.runtime.FileLocator", v);
v = newarray (java.lang.Class)[1];
v[0] = class "Ljava/net/URL;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("resolve", v);
<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.lang.reflect.Method equinoxResolveMethod> = v;
v = <nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String)>("Found Equinox FileLocator for OSGi bundle URL resolution");
label:
goto label;
label:
v := @caughtexception;
<nl.basjes.parse.useragent.utils.springframework.core.io.support.PathMatchingResourcePatternResolver: java.lang.reflect.Method equinoxResolveMethod> = null;
label:
return;
catch java.lang.Throwable from label to label with label;
}
}