blob: c228a6e8c66f2f62b329f33b2d1aa92fbb09a36d [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2010, 2011 Oracle. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0, which accompanies this distribution
* and is available at http://www.eclipse.org/legal/epl-v10.html.
*
* Contributors:
* Oracle - initial API and implementation
******************************************************************************/
package org.eclipse.jpt.common.core.resource.java;
import org.eclipse.jdt.core.IPackageFragment;
import org.eclipse.jdt.core.IPackageFragmentRoot;
import org.eclipse.jdt.core.dom.AbstractTypeDeclaration;
/**
* Java source code or binary type. This corresponds to a {@link AbstractTypeDeclaration}
* (which is why the name is somewhat wonky.)
* <p>
* Provisional API: This interface is part of an interim API that is still
* under development and expected to change significantly before reaching
* stability. It is available at this early stage to solicit feedback from
* pioneering adopters on the understanding that any code that uses this API
* will almost certainly be broken (repeatedly) as the API evolves.
*
* @version 3.0
* @since 3.0
*/
public interface JavaResourceAbstractType
extends JavaResourceMember {
/**
* Property change String for the unqualified (short) type name.
* @see JavaResourceMember#getName()
*/
String NAME_PROPERTY = "name"; //$NON-NLS-1$
/**
* Return the fully qualified type name.
*/
String getQualifiedName();
String QUALIFIED_NAME_PROPERTY = "qualifiedName"; //$NON-NLS-1$
/**
* Return the package name.
*/
String getPackageName();
String PACKAGE_NAME_PROPERTY = "packageName"; //$NON-NLS-1$
/**
* Return the name of the type's "declaring type".
* Return <code>null</code> if the type is a top-level type.
*/
String getDeclaringTypeName();
String DECLARING_TYPE_NAME_PROPERTY = "declaringTypeName"; //$NON-NLS-1$
/**
* Return whether the type is a member type.
*/
boolean isMemberType();
String MEMBER_TYPE_PROPERTY = "memberType"; //$NON-NLS-1$
boolean isIn(IPackageFragment packageFragment);
boolean isIn(IPackageFragmentRoot sourceFolder);
/**
* Return the immediately nested types (classes or interfaces, not enums or annotations) (children).
*/
Iterable<JavaResourceType> getTypes();
String TYPES_COLLECTION = "types"; //$NON-NLS-1$
/**
* Return all the types; the type itself, its children, its grandchildren,
* etc.
*/
Iterable<JavaResourceType> getAllTypes();
/**
* Return the immediately nested enums (children).
*/
Iterable<JavaResourceEnum> getEnums();
String ENUMS_COLLECTION = "enums"; //$NON-NLS-1$
/**
* Return all the enums; the enum itself, its children, its grandchildren,
* etc.
*/
Iterable<JavaResourceEnum> getAllEnums();
}