org.aspectj.org.eclipse.jdt.core.provisional.JavaModelAccess Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2017, 2019 GK Software SE, and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Stephan Herrmann - initial API and implementation
*******************************************************************************/
package org.aspectj.org.eclipse.jdt.core.provisional;
import org.aspectj.org.eclipse.jdt.core.IJavaElement;
import org.aspectj.org.eclipse.jdt.core.IModuleDescription;
import org.aspectj.org.eclipse.jdt.core.IPackageFragmentRoot;
import org.aspectj.org.eclipse.jdt.core.JavaModelException;
import org.aspectj.org.eclipse.jdt.internal.core.JavaProject;
import org.aspectj.org.eclipse.jdt.internal.core.JrtPackageFragmentRoot;
import org.aspectj.org.eclipse.jdt.internal.core.PackageFragmentRoot;
/**
* Provisional API for use by JDT/UI or JDT/Debug, which may possibly be removed in a future version.
* See Bug 522391.
*/
public class JavaModelAccess {
/**
* Answer the names of all modules directly required from the given module.
* @param module the module whose "requires" directives are queried
* @return a non-null array of module names
* @deprecated this provisional API has been promoted to {@link IModuleDescription#getRequiredModuleNames()}
*/
@Deprecated
public static String[] getRequiredModules(IModuleDescription module) throws JavaModelException {
return module.getRequiredModuleNames();
}
/**
* Returns the IModuleDescription
that the given java element contains
* when regarded as an automatic module. The element must be an IPackageFragmentRoot
* or an IJavaProject
.
*
* The returned module descriptor has a name (getElementName()
) following
* the specification of java.lang.module.ModuleFinder.of(Path...)
, but it
* contains no other useful information.
*
* @return the IModuleDescription
representing this java element as an automatic module,
* never null
.
* @throws IllegalArgumentException if the provided element is neither IPackageFragmentRoot
* nor IJavaProject
* @since 3.14
*/
public static IModuleDescription getAutomaticModuleDescription(IJavaElement element) throws JavaModelException, IllegalArgumentException {
switch (element.getElementType()) {
case IJavaElement.JAVA_PROJECT:
return ((JavaProject) element).getAutomaticModuleDescription();
case IJavaElement.PACKAGE_FRAGMENT_ROOT:
return ((PackageFragmentRoot) element).getAutomaticModuleDescription();
default:
throw new IllegalArgumentException("Illegal kind of java element: "+element.getElementType()); //$NON-NLS-1$
}
}
/**
* Answer whether the given module is a system module.
* This provisional API may likely be changed into a direct method {@code IModuleDescription.isSystemModule()}.
*
* @param module the module being queried about
* @return {@code true} iff the module is defined in the system library (also known as JRE).
* @since 3.18
* @deprecated please use {@link IModuleDescription#isSystemModule()}
*/
@Deprecated
public static boolean isSystemModule(IModuleDescription module) {
IPackageFragmentRoot pfr = (IPackageFragmentRoot) module.getAncestor(IJavaElement.PACKAGE_FRAGMENT_ROOT);
return pfr instanceof JrtPackageFragmentRoot;
}
}