Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
  * JBoss, Home of Professional Open Source
  * Copyright 2009, Red Hat, Inc. and/or its affiliates, and individual contributors
  * by the @authors tag. See the copyright.txt in the distribution for a
  * full listing of individual contributors.
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
  * You may obtain a copy of the License at
 * http://www.apache.org/licenses/LICENSE-2.0
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
 package org.hibernate.validator.internal.engine.resolver;
 
 import java.util.Map;
Cache results of a delegated traversable resovler to optimize calls It works only for a single validate* call and should not be used if the TraversableResolver is accessed concurrently

Author(s):
Emmanuel Bernard
 
 
 		this. = delegate;
 	}
 
 	public boolean isReachable(Object traversableObjectPath.Node traversablePropertyClass<?> rootBeanTypePath pathToTraversableObjectElementType elementType) {
 		TraversableHolder currentLH = new TraversableHolder(
 				traversableObjecttraversablePropertyrootBeanTypepathToTraversableObjectelementType
 		);
 		TraversableHolder cachedLH = .getcurrentLH );
 		if ( cachedLH == null ) {
 			currentLH.isReachable = .isReachable(
 					traversableObject,
 					traversableProperty,
 					rootBeanType,
 					pathToTraversableObject,
 					elementType
 			);
 			.putcurrentLHcurrentLH );
 			cachedLH = currentLH;
 		}
 		else if ( cachedLH.isReachable == null ) {
 			cachedLH.isReachable = .isReachable(
 					traversableObject,
 					traversableProperty,
 					rootBeanType,
 					pathToTraversableObject,
 					elementType
 			);
 		}
 		return cachedLH.isReachable;
 	}
 
 	public boolean isCascadable(Object traversableObjectPath.Node traversablePropertyClass<?> rootBeanTypePath pathToTraversableObjectElementType elementType) {
 		TraversableHolder currentLH = new TraversableHolder(
 				traversableObjecttraversablePropertyrootBeanTypepathToTraversableObjectelementType
 		);
 		TraversableHolder cachedLH = .getcurrentLH );
 		if ( cachedLH == null ) {
 			currentLH.isCascadable = .isCascadable(
 					traversableObject,
 					traversableProperty,
 					rootBeanType,
 					pathToTraversableObject,
 					elementType
 			);
 			.putcurrentLHcurrentLH );
 			cachedLH = currentLH;
 		}
 		else if ( cachedLH.isCascadable == null ) {
 			cachedLH.isCascadable = .isCascadable(
 					traversableObject,
 					traversableProperty,
 					rootBeanType,
 					pathToTraversableObject,
 					elementType
 			);
 		}
 		return cachedLH.isCascadable;
 	}
 
 	private static final class TraversableHolder {
 		private final Object traversableObject;
 		private final Path.Node traversableProperty;
 		private final Class<?> rootBeanType;
		private final Path pathToTraversableObject;
		private final ElementType elementType;
		private final int hashCode;
		private TraversableHolder(Object traversableObjectPath.Node traversablePropertyClass<?> rootBeanTypePath pathToTraversableObjectElementType elementType) {
			this. = traversableObject;
			this. = traversableProperty;
			this. = rootBeanType;
			this. = pathToTraversableObject;
			this. = elementType;
		}
		public boolean equals(Object o) {
			if ( this == o ) {
				return true;
			}
			if ( o == null || getClass() != o.getClass() ) {
				return false;
			}
			if (  != that.elementType ) {
				return false;
			}
			if ( !.equalsthat.pathToTraversableObject ) ) {
				return false;
			}
			if ( !.equalsthat.rootBeanType ) ) {
				return false;
			}
			if (  != null ? !.equalsthat.traversableObject ) : that.traversableObject != null ) {
				return false;
			}
			if ( !.equalsthat.traversableProperty ) ) {
				return false;
			}
			return true;
		}
		public int hashCode() {
			return ;
		}
		public int buildHashCode() {
			int result =  != null ? .hashCode() : 0;
			result = 31 * result + .hashCode();
			result = 31 * result + .hashCode();
			result = 31 * result + .hashCode();
			result = 31 * result + .hashCode();
			return result;
		}
	}
New to GrepCode? Check out our FAQ X