Java Code Examples for org.springframework.util.ClassUtils#matchesTypeName()

The following examples show how to use org.springframework.util.ClassUtils#matchesTypeName() . You can vote up the ones you like or vote down the ones you don't like, and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: ConstructorArgumentValues.java    From spring-analysis-note with MIT License 6 votes vote down vote up
/**
 * Look for the next generic argument value that matches the given type,
 * ignoring argument values that have already been used in the current
 * resolution process.
 * @param requiredType the type to match (can be {@code null} to find
 * an arbitrary next generic argument value)
 * @param requiredName the name to match (can be {@code null} to not
 * match argument values by name, or empty String to match any name)
 * @param usedValueHolders a Set of ValueHolder objects that have already been used
 * in the current resolution process and should therefore not be returned again
 * @return the ValueHolder for the argument, or {@code null} if none found
 */
@Nullable
public ValueHolder getGenericArgumentValue(@Nullable Class<?> requiredType, @Nullable String requiredName, @Nullable Set<ValueHolder> usedValueHolders) {
	for (ValueHolder valueHolder : this.genericArgumentValues) {
		if (usedValueHolders != null && usedValueHolders.contains(valueHolder)) {
			continue;
		}
		if (valueHolder.getName() != null && !"".equals(requiredName) &&
				(requiredName == null || !valueHolder.getName().equals(requiredName))) {
			continue;
		}
		if (valueHolder.getType() != null &&
				(requiredType == null || !ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) {
			continue;
		}
		if (requiredType != null && valueHolder.getType() == null && valueHolder.getName() == null &&
				!ClassUtils.isAssignableValue(requiredType, valueHolder.getValue())) {
			continue;
		}
		return valueHolder;
	}
	return null;
}
 
Example 2
Source File: ConstructorArgumentValues.java    From java-technology-stack with MIT License 6 votes vote down vote up
/**
 * Look for the next generic argument value that matches the given type,
 * ignoring argument values that have already been used in the current
 * resolution process.
 * @param requiredType the type to match (can be {@code null} to find
 * an arbitrary next generic argument value)
 * @param requiredName the name to match (can be {@code null} to not
 * match argument values by name, or empty String to match any name)
 * @param usedValueHolders a Set of ValueHolder objects that have already been used
 * in the current resolution process and should therefore not be returned again
 * @return the ValueHolder for the argument, or {@code null} if none found
 */
@Nullable
public ValueHolder getGenericArgumentValue(@Nullable Class<?> requiredType, @Nullable String requiredName, @Nullable Set<ValueHolder> usedValueHolders) {
	for (ValueHolder valueHolder : this.genericArgumentValues) {
		if (usedValueHolders != null && usedValueHolders.contains(valueHolder)) {
			continue;
		}
		if (valueHolder.getName() != null && !"".equals(requiredName) &&
				(requiredName == null || !valueHolder.getName().equals(requiredName))) {
			continue;
		}
		if (valueHolder.getType() != null &&
				(requiredType == null || !ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) {
			continue;
		}
		if (requiredType != null && valueHolder.getType() == null && valueHolder.getName() == null &&
				!ClassUtils.isAssignableValue(requiredType, valueHolder.getValue())) {
			continue;
		}
		return valueHolder;
	}
	return null;
}
 
Example 3
Source File: ConstructorArgumentValues.java    From lams with GNU General Public License v2.0 6 votes vote down vote up
/**
 * Look for the next generic argument value that matches the given type,
 * ignoring argument values that have already been used in the current
 * resolution process.
 * @param requiredType the type to match (can be {@code null} to find
 * an arbitrary next generic argument value)
 * @param requiredName the name to match (can be {@code null} to not
 * match argument values by name, or empty String to match any name)
 * @param usedValueHolders a Set of ValueHolder objects that have already been used
 * in the current resolution process and should therefore not be returned again
 * @return the ValueHolder for the argument, or {@code null} if none found
 */
public ValueHolder getGenericArgumentValue(Class<?> requiredType, String requiredName, Set<ValueHolder> usedValueHolders) {
	for (ValueHolder valueHolder : this.genericArgumentValues) {
		if (usedValueHolders != null && usedValueHolders.contains(valueHolder)) {
			continue;
		}
		if (valueHolder.getName() != null && !"".equals(requiredName) &&
				(requiredName == null || !valueHolder.getName().equals(requiredName))) {
			continue;
		}
		if (valueHolder.getType() != null &&
				(requiredType == null || !ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) {
			continue;
		}
		if (requiredType != null && valueHolder.getType() == null && valueHolder.getName() == null &&
				!ClassUtils.isAssignableValue(requiredType, valueHolder.getValue())) {
			continue;
		}
		return valueHolder;
	}
	return null;
}
 
Example 4
Source File: ConstructorArgumentValues.java    From blog_demos with Apache License 2.0 6 votes vote down vote up
/**
 * Look for the next generic argument value that matches the given type,
 * ignoring argument values that have already been used in the current
 * resolution process.
 * @param requiredType the type to match (can be {@code null} to find
 * an arbitrary next generic argument value)
 * @param requiredName the name to match (can be {@code null} to not
 * match argument values by name)
 * @param usedValueHolders a Set of ValueHolder objects that have already been used
 * in the current resolution process and should therefore not be returned again
 * @return the ValueHolder for the argument, or {@code null} if none found
 */
public ValueHolder getGenericArgumentValue(Class<?> requiredType, String requiredName, Set<ValueHolder> usedValueHolders) {
	for (ValueHolder valueHolder : this.genericArgumentValues) {
		if (usedValueHolders != null && usedValueHolders.contains(valueHolder)) {
			continue;
		}
		if (valueHolder.getName() != null &&
				(requiredName == null || !valueHolder.getName().equals(requiredName))) {
			continue;
		}
		if (valueHolder.getType() != null &&
				(requiredType == null || !ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) {
			continue;
		}
		if (requiredType != null && valueHolder.getType() == null && valueHolder.getName() == null &&
				!ClassUtils.isAssignableValue(requiredType, valueHolder.getValue())) {
			continue;
		}
		return valueHolder;
	}
	return null;
}
 
Example 5
Source File: ConstructorArgumentValues.java    From spring4-understanding with Apache License 2.0 6 votes vote down vote up
/**
 * Look for the next generic argument value that matches the given type,
 * ignoring argument values that have already been used in the current
 * resolution process.
 * @param requiredType the type to match (can be {@code null} to find
 * an arbitrary next generic argument value)
 * @param requiredName the name to match (can be {@code null} to not
 * match argument values by name)
 * @param usedValueHolders a Set of ValueHolder objects that have already been used
 * in the current resolution process and should therefore not be returned again
 * @return the ValueHolder for the argument, or {@code null} if none found
 */
public ValueHolder getGenericArgumentValue(Class<?> requiredType, String requiredName, Set<ValueHolder> usedValueHolders) {
	for (ValueHolder valueHolder : this.genericArgumentValues) {
		if (usedValueHolders != null && usedValueHolders.contains(valueHolder)) {
			continue;
		}
		if (valueHolder.getName() != null &&
				(requiredName == null || !valueHolder.getName().equals(requiredName))) {
			continue;
		}
		if (valueHolder.getType() != null &&
				(requiredType == null || !ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) {
			continue;
		}
		if (requiredType != null && valueHolder.getType() == null && valueHolder.getName() == null &&
				!ClassUtils.isAssignableValue(requiredType, valueHolder.getValue())) {
			continue;
		}
		return valueHolder;
	}
	return null;
}
 
Example 6
Source File: ConstructorArgumentValues.java    From spring-analysis-note with MIT License 5 votes vote down vote up
/**
 * Get argument value for the given index in the constructor argument list.
 * @param index the index in the constructor argument list
 * @param requiredType the type to match (can be {@code null} to match
 * untyped values only)
 * @param requiredName the type to match (can be {@code null} to match
 * unnamed values only, or empty String to match any name)
 * @return the ValueHolder for the argument, or {@code null} if none set
 */
@Nullable
public ValueHolder getIndexedArgumentValue(int index, @Nullable Class<?> requiredType, @Nullable String requiredName) {
	Assert.isTrue(index >= 0, "Index must not be negative");
	ValueHolder valueHolder = this.indexedArgumentValues.get(index);
	if (valueHolder != null &&
			(valueHolder.getType() == null ||
					(requiredType != null && ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) &&
			(valueHolder.getName() == null || "".equals(requiredName) ||
					(requiredName != null && requiredName.equals(valueHolder.getName())))) {
		return valueHolder;
	}
	return null;
}
 
Example 7
Source File: ConstructorArgumentValues.java    From java-technology-stack with MIT License 5 votes vote down vote up
/**
 * Get argument value for the given index in the constructor argument list.
 * @param index the index in the constructor argument list
 * @param requiredType the type to match (can be {@code null} to match
 * untyped values only)
 * @param requiredName the type to match (can be {@code null} to match
 * unnamed values only, or empty String to match any name)
 * @return the ValueHolder for the argument, or {@code null} if none set
 */
@Nullable
public ValueHolder getIndexedArgumentValue(int index, @Nullable Class<?> requiredType, @Nullable String requiredName) {
	Assert.isTrue(index >= 0, "Index must not be negative");
	ValueHolder valueHolder = this.indexedArgumentValues.get(index);
	if (valueHolder != null &&
			(valueHolder.getType() == null ||
					(requiredType != null && ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) &&
			(valueHolder.getName() == null || "".equals(requiredName) ||
					(requiredName != null && requiredName.equals(valueHolder.getName())))) {
		return valueHolder;
	}
	return null;
}
 
Example 8
Source File: ConstructorArgumentValues.java    From lams with GNU General Public License v2.0 5 votes vote down vote up
/**
 * Get argument value for the given index in the constructor argument list.
 * @param index the index in the constructor argument list
 * @param requiredType the type to match (can be {@code null} to match
 * untyped values only)
 * @param requiredName the type to match (can be {@code null} to match
 * unnamed values only, or empty String to match any name)
 * @return the ValueHolder for the argument, or {@code null} if none set
 */
public ValueHolder getIndexedArgumentValue(int index, Class<?> requiredType, String requiredName) {
	Assert.isTrue(index >= 0, "Index must not be negative");
	ValueHolder valueHolder = this.indexedArgumentValues.get(index);
	if (valueHolder != null &&
			(valueHolder.getType() == null ||
					(requiredType != null && ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) &&
			(valueHolder.getName() == null || "".equals(requiredName) ||
					(requiredName != null && requiredName.equals(valueHolder.getName())))) {
		return valueHolder;
	}
	return null;
}
 
Example 9
Source File: ConstructorArgumentValues.java    From blog_demos with Apache License 2.0 5 votes vote down vote up
/**
 * Get argument value for the given index in the constructor argument list.
 * @param index the index in the constructor argument list
 * @param requiredType the type to match (can be {@code null} to match
 * untyped values only)
 * @param requiredName the type to match (can be {@code null} to match
 * unnamed values only)
 * @return the ValueHolder for the argument, or {@code null} if none set
 */
public ValueHolder getIndexedArgumentValue(int index, Class<?> requiredType, String requiredName) {
	Assert.isTrue(index >= 0, "Index must not be negative");
	ValueHolder valueHolder = this.indexedArgumentValues.get(index);
	if (valueHolder != null &&
			(valueHolder.getType() == null ||
					(requiredType != null && ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) &&
			(valueHolder.getName() == null ||
					(requiredName != null && requiredName.equals(valueHolder.getName())))) {
		return valueHolder;
	}
	return null;
}
 
Example 10
Source File: ConstructorArgumentValues.java    From spring4-understanding with Apache License 2.0 5 votes vote down vote up
/**
 * Get argument value for the given index in the constructor argument list.
 * @param index the index in the constructor argument list
 * @param requiredType the type to match (can be {@code null} to match
 * untyped values only)
 * @param requiredName the type to match (can be {@code null} to match
 * unnamed values only)
 * @return the ValueHolder for the argument, or {@code null} if none set
 */
public ValueHolder getIndexedArgumentValue(int index, Class<?> requiredType, String requiredName) {
	Assert.isTrue(index >= 0, "Index must not be negative");
	ValueHolder valueHolder = this.indexedArgumentValues.get(index);
	if (valueHolder != null &&
			(valueHolder.getType() == null ||
					(requiredType != null && ClassUtils.matchesTypeName(requiredType, valueHolder.getType()))) &&
			(valueHolder.getName() == null ||
					(requiredName != null && requiredName.equals(valueHolder.getName())))) {
		return valueHolder;
	}
	return null;
}