org.gradle.internal.reflect.MutableClassDetails Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-tooling-api Show documentation
Show all versions of gradle-tooling-api Show documentation
Gradle Tooling API - the programmatic API to invoke Gradle
The newest version!
/*
* Copyright 2015 the original author or authors.
*
* 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.gradle.internal.reflect;
import com.google.common.collect.ImmutableSet;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.Collection;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
class MutableClassDetails implements ClassDetails {
private final Class> type;
private final MethodSet instanceMethods = new MethodSet();
private final Map properties = new TreeMap();
private final List methods = new ArrayList();
private final List instanceFields = new ArrayList<>();
private final Set> superTypes = new LinkedHashSet>();
MutableClassDetails(Class> type) {
this.type = type;
}
@Override
public List getAllMethods() {
return methods;
}
@Override
public Collection getInstanceMethods() {
return instanceMethods.getValues();
}
@Override
public Collection getInstanceFields() {
return instanceFields;
}
public Set> getSuperTypes() {
return superTypes;
}
/*
* Does a defensive copy to avoid leaking class references through the MutablePropertyDetails
* contained in the maps values. The keyset would keep a strong reference back to the map
* and all its entries.
*/
@Override
public Set getPropertyNames() {
return ImmutableSet.copyOf(properties.keySet());
}
@Override
public Collection extends PropertyDetails> getProperties() {
return properties.values();
}
@Override
public PropertyDetails getProperty(String name) throws NoSuchPropertyException {
MutablePropertyDetails property = properties.get(name);
if (property == null) {
throw new NoSuchPropertyException(String.format("No property '%s' found on %s.", name, type));
}
return property;
}
void superType(Class> type) {
superTypes.add(type);
}
void method(Method method) {
methods.add(method);
}
void instanceMethod(Method method) {
instanceMethods.add(method);
}
MutablePropertyDetails property(String propertyName) {
MutablePropertyDetails property = properties.get(propertyName);
if (property == null) {
property = new MutablePropertyDetails(propertyName);
properties.put(propertyName, property);
}
return property;
}
public void field(Field field) {
if (Modifier.isStatic(field.getModifiers())) {
return;
}
MutablePropertyDetails property = properties.get(field.getName());
if (property != null) {
property.field(field);
}
instanceFields.add(field);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy