public class org.hibernate.validator.internal.engine.resolver.TraversableResolvers extends java.lang.Object
{
private static final org.hibernate.validator.internal.util.logging.Log LOG;
private static final java.lang.String PERSISTENCE_CLASS_NAME;
private static final java.lang.String PERSISTENCE_UTIL_METHOD;
private static final java.lang.String JPA_AWARE_TRAVERSABLE_RESOLVER_CLASS_NAME;
private void <init>()
{
org.hibernate.validator.internal.engine.resolver.TraversableResolvers v;
v := @this: org.hibernate.validator.internal.engine.resolver.TraversableResolvers;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static jakarta.validation.TraversableResolver getDefault()
{
java.lang.Throwable v, v;
jakarta.validation.TraversableResolver v, v, v, v;
org.hibernate.validator.internal.util.privilegedactions.GetMethod v;
org.hibernate.validator.internal.util.privilegedactions.LoadClass v, v;
java.lang.Exception v;
java.lang.Class v, v;
java.lang.Object v, v, v, v, v;
java.lang.ClassLoader v, v;
org.hibernate.validator.internal.util.privilegedactions.NewInstance v, v;
org.hibernate.validator.internal.util.logging.Log v, v, v, v, v, v;
label:
v = class "Lorg/hibernate/validator/internal/engine/resolver/TraversableResolvers;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = staticinvoke <org.hibernate.validator.internal.util.privilegedactions.LoadClass: org.hibernate.validator.internal.util.privilegedactions.LoadClass action(java.lang.String,java.lang.ClassLoader)>("jakarta.persistence.Persistence", v);
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: java.lang.Object run(java.security.PrivilegedAction)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG>;
interfaceinvoke v.<org.hibernate.validator.internal.util.logging.Log: void debugf(java.lang.String,java.lang.Object)>("Cannot find %s on classpath. Assuming non JPA 2 environment. All properties will per default be traversable.", "jakarta.persistence.Persistence");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: jakarta.validation.TraversableResolver getTraverseAllTraversableResolver()>();
return v;
label:
v = staticinvoke <org.hibernate.validator.internal.util.privilegedactions.GetMethod: org.hibernate.validator.internal.util.privilegedactions.GetMethod action(java.lang.Class,java.lang.String)>(v, "getPersistenceUtil");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: java.lang.Object run(java.security.PrivilegedAction)>(v);
if v != null goto label;
v = <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG>;
interfaceinvoke v.<org.hibernate.validator.internal.util.logging.Log: void debugf(java.lang.String,java.lang.Object,java.lang.Object)>("Found %s on classpath, but no method \'%s\'. Assuming JPA 1 environment. All properties will per default be traversable.", "jakarta.persistence.Persistence", "getPersistenceUtil");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: jakarta.validation.TraversableResolver getTraverseAllTraversableResolver()>();
return v;
label:
v = staticinvoke <org.hibernate.validator.internal.util.privilegedactions.NewInstance: org.hibernate.validator.internal.util.privilegedactions.NewInstance action(java.lang.Class,java.lang.String)>(v, "persistence provider");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: java.lang.Object run(java.security.PrivilegedAction)>(v);
staticinvoke <org.hibernate.validator.internal.util.ReflectionHelper: java.lang.Object getValue(java.lang.reflect.Method,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG>;
interfaceinvoke v.<org.hibernate.validator.internal.util.logging.Log: void debugf(java.lang.String,java.lang.Object,java.lang.Object)>("Unable to invoke %s.%s. Inconsistent JPA environment. All properties will per default be traversable.", "jakarta.persistence.Persistence", "getPersistenceUtil");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: jakarta.validation.TraversableResolver getTraverseAllTraversableResolver()>();
return v;
label:
v = <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG>;
interfaceinvoke v.<org.hibernate.validator.internal.util.logging.Log: void debugf(java.lang.String,java.lang.Object,java.lang.Object)>("Found %s on classpath containing \'%s\'. Assuming JPA 2 environment. Trying to instantiate JPA aware TraversableResolver", "jakarta.persistence.Persistence", "getPersistenceUtil");
label:
v = class "Lorg/hibernate/validator/internal/engine/resolver/TraversableResolvers;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = staticinvoke <org.hibernate.validator.internal.util.privilegedactions.LoadClass: org.hibernate.validator.internal.util.privilegedactions.LoadClass action(java.lang.String,java.lang.ClassLoader)>("org.hibernate.validator.internal.engine.resolver.JPATraversableResolver", v);
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: java.lang.Object run(java.security.PrivilegedAction)>(v);
v = <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG>;
interfaceinvoke v.<org.hibernate.validator.internal.util.logging.Log: void debugf(java.lang.String,java.lang.Object)>("Instantiated JPA aware TraversableResolver of type %s.", "org.hibernate.validator.internal.engine.resolver.JPATraversableResolver");
v = staticinvoke <org.hibernate.validator.internal.util.privilegedactions.NewInstance: org.hibernate.validator.internal.util.privilegedactions.NewInstance action(java.lang.Class,java.lang.String)>(v, "");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: java.lang.Object run(java.security.PrivilegedAction)>(v);
label:
return v;
label:
v := @caughtexception;
v = <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG>;
interfaceinvoke v.<org.hibernate.validator.internal.util.logging.Log: void logUnableToLoadOrInstantiateJPAAwareResolver(java.lang.String)>("org.hibernate.validator.internal.engine.resolver.JPATraversableResolver");
v = staticinvoke <org.hibernate.validator.internal.engine.resolver.TraversableResolvers: jakarta.validation.TraversableResolver getTraverseAllTraversableResolver()>();
return v;
catch jakarta.validation.ValidationException from label to label with label;
catch java.lang.Exception from label to label with label;
catch jakarta.validation.ValidationException from label to label with label;
}
public static jakarta.validation.TraversableResolver wrapWithCachingForSingleValidation(jakarta.validation.TraversableResolver, boolean)
{
org.hibernate.validator.internal.engine.resolver.CachingTraversableResolverForSingleValidation v;
jakarta.validation.TraversableResolver v;
org.hibernate.validator.internal.engine.resolver.CachingJPATraversableResolverForSingleValidation v;
java.lang.Class v, v, v;
java.lang.String v, v;
boolean v, v, v;
v := @parameter: jakarta.validation.TraversableResolver;
v := @parameter: boolean;
v = class "Lorg/hibernate/validator/internal/engine/resolver/TraverseAllTraversableResolver;";
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
if v != 0 goto label;
label:
return v;
label:
v = "org.hibernate.validator.internal.engine.resolver.JPATraversableResolver";
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = new org.hibernate.validator.internal.engine.resolver.CachingJPATraversableResolverForSingleValidation;
specialinvoke v.<org.hibernate.validator.internal.engine.resolver.CachingJPATraversableResolverForSingleValidation: void <init>(jakarta.validation.TraversableResolver)>(v);
return v;
label:
v = new org.hibernate.validator.internal.engine.resolver.CachingTraversableResolverForSingleValidation;
specialinvoke v.<org.hibernate.validator.internal.engine.resolver.CachingTraversableResolverForSingleValidation: void <init>(jakarta.validation.TraversableResolver)>(v);
return v;
}
private static jakarta.validation.TraversableResolver getTraverseAllTraversableResolver()
{
org.hibernate.validator.internal.engine.resolver.TraverseAllTraversableResolver v;
v = new org.hibernate.validator.internal.engine.resolver.TraverseAllTraversableResolver;
specialinvoke v.<org.hibernate.validator.internal.engine.resolver.TraverseAllTraversableResolver: void <init>()>();
return v;
}
private static java.lang.Object run(java.security.PrivilegedAction)
{
java.lang.Object v;
java.security.PrivilegedAction v;
java.lang.SecurityManager v;
v := @parameter: java.security.PrivilegedAction;
v = staticinvoke <java.lang.System: java.lang.SecurityManager getSecurityManager()>();
if v == null goto label;
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
goto label;
label:
v = interfaceinvoke v.<java.security.PrivilegedAction: java.lang.Object run()>();
label:
return v;
}
static void <clinit>()
{
java.lang.invoke.MethodHandles$Lookup v;
org.hibernate.validator.internal.util.logging.Log v;
v = staticinvoke <java.lang.invoke.MethodHandles: java.lang.invoke.MethodHandles$Lookup lookup()>();
v = staticinvoke <org.hibernate.validator.internal.util.logging.LoggerFactory: org.hibernate.validator.internal.util.logging.Log make(java.lang.invoke.MethodHandles$Lookup)>(v);
<org.hibernate.validator.internal.engine.resolver.TraversableResolvers: org.hibernate.validator.internal.util.logging.Log LOG> = v;
return;
}
}