/******************************************************************************* * Copyright (c) 2007, 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.jaxb.core.resource.java; import org.eclipse.jdt.core.dom.CompilationUnit; /** * Java source code or binary persistent member. *

* 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 2.0 */ public interface JavaResourceMember extends JavaResourceAnnotatedElement { String getName(); // ********** annotations ********** /** * Sets the specified primary annotation as the first annotation, and removes all known * annotations (i.e. does not remove non-persistence annotations) which are not included * in the supporting annotations. */ Annotation setPrimaryAnnotation(String primaryAnnotationName, Iterable supportingAnnotationNames); // ********** modifiers ********** /** * Return whether the member is final. */ boolean isFinal(); String FINAL_PROPERTY = "final"; //$NON-NLS-1$ boolean isTransient(); String TRANSIENT_PROPERTY = "transient"; //$NON-NLS-1$ boolean isPublic(); String PUBLIC_PROPERTY = "public"; //$NON-NLS-1$ boolean isStatic(); String STATIC_PROPERTY = "static"; //$NON-NLS-1$ // ********** queries ********** /** * Return whether the Java resource member is for the specified * member. */ boolean isFor(String memberName, int occurrence); // ********** behavior ********** /** * Resolve type information that could be dependent on changes elsewhere * in the workspace. */ void resolveTypes(CompilationUnit astRoot); }