All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.core.type.ClassMetadata Maven / Gradle / Ivy

There is a newer version: 6.1.6
Show newest version
/*
 * Copyright 2002-2017 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
 *
 *      https://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.springframework.core.type;

import org.springframework.lang.Nullable;

/**
 * Interface that defines abstract metadata of a specific class,
 * in a form that does not require that class to be loaded yet.
 *
 * @author Juergen Hoeller
 * @since 2.5
 * @see StandardClassMetadata
 * @see org.springframework.core.type.classreading.MetadataReader#getClassMetadata()
 * @see AnnotationMetadata
 */
public interface ClassMetadata {

	/**
	 * Return the name of the underlying class.
	 */
	String getClassName();

	/**
	 * Return whether the underlying class represents an interface.
	 */
	boolean isInterface();

	/**
	 * Return whether the underlying class represents an annotation.
	 * @since 4.1
	 */
	boolean isAnnotation();

	/**
	 * Return whether the underlying class is marked as abstract.
	 */
	boolean isAbstract();

	/**
	 * Return whether the underlying class represents a concrete class,
	 * i.e. neither an interface nor an abstract class.
	 */
	default boolean isConcrete() {
		return !(isInterface() || isAbstract());
	}

	/**
	 * Return whether the underlying class is marked as 'final'.
	 */
	boolean isFinal();

	/**
	 * Determine whether the underlying class is independent, i.e. whether
	 * it is a top-level class or a nested class (static inner class) that
	 * can be constructed independently from an enclosing class.
	 */
	boolean isIndependent();

	/**
	 * Return whether the underlying class is declared within an enclosing
	 * class (i.e. the underlying class is an inner/nested class or a
	 * local class within a method).
	 * 

If this method returns {@code false}, then the underlying * class is a top-level class. */ default boolean hasEnclosingClass() { return (getEnclosingClassName() != null); } /** * Return the name of the enclosing class of the underlying class, * or {@code null} if the underlying class is a top-level class. */ @Nullable String getEnclosingClassName(); /** * Return whether the underlying class has a super class. */ default boolean hasSuperClass() { return (getSuperClassName() != null); } /** * Return the name of the super class of the underlying class, * or {@code null} if there is no super class defined. */ @Nullable String getSuperClassName(); /** * Return the names of all interfaces that the underlying class * implements, or an empty array if there are none. */ String[] getInterfaceNames(); /** * Return the names of all classes declared as members of the class represented by * this ClassMetadata object. This includes public, protected, default (package) * access, and private classes and interfaces declared by the class, but excludes * inherited classes and interfaces. An empty array is returned if no member classes * or interfaces exist. * @since 3.1 */ String[] getMemberClassNames(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy