/******************************************************************************* * Copyright (c) 2000, 2008 IBM Corporation and others. * 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: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.jdt.core.jdom; /** * Represents a Java compilation unit (source file with one of the * {@link org.eclipse.jdt.core.JavaCore#getJavaLikeExtensions() Java-like extensions}). The * corresponding syntactic unit is CompilationUnit (JLS2 7.3). Allowable child types for a * compilation unit are <code>IDOMPackage</code>, <code>IDOMImport</code>, and <code>IDOMType</code> * . * * @deprecated The JDOM was made obsolete by the addition in 2.0 of the more powerful, fine-grained * DOM/AST API found in the org.eclipse.jdt.core.dom package. * @noimplement This interface is not intended to be implemented by clients. */ public interface IDOMCompilationUnit extends IDOMNode { /** * Returns the header comment for this compilation unit. The header comment appears before the * first declaration in a compilation unit. The syntax for a comment corresponds to Comments * (JLS2 3.7), <b>including</b> comment delimiters. * * @return the header comment for this compilation unit, or <code>null</code> if no header * comment is present */ public String getHeader(); /** * The <code>IDOMCompilationNode</code> refinement of this <code>IDOMNode</code> method returns * the name of this compilation unit. * * <p> * The name of a compilation unit is the name of the first top-level public type defined in the * compilation unit, suffixed with one of the * {@link org.eclipse.jdt.core.JavaCore#getJavaLikeExtensions() Java-like extensions}. For * example, if the first top-level public type defined in this compilation unit has the name * "Hanoi", then name of this compilation unit is "Hanoi.java". * </p> * * <p> * In the absence of a public top-level type, the name of the first top-level type is used. In * the absence of any type, the name of the compilation unit is <code>null</code>. * </p> * * @return the name of this compilation unit, or <code>null</code> if none */ public String getName(); /** * Sets the header comment for this compilation unit. The header comment appears before the * first declaration in a compilation unit. The syntax for a comment corresponds to Comments * (JLS2 3.7), <b>including</b> comment delimiters. * * @param comment the header comment for this compilation unit, or <code>null</code> if * indicating no header comment */ public void setHeader(String comment); /** * The <code>IDOMCompilationNode</code> refinement of this <code>IDOMNode</code> method has no * effect (the name is computed from the types declared within it). * * @param name the given name */ public void setName(String name); }