/*
* This file is part of the X10 project (http://x10-lang.org).
*
* This file is licensed to You under the Eclipse Public License (EPL);
* You may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.opensource.org/licenses/eclipse-1.0.php
*
* This file was originally derived from the Polyglot extensible compiler framework.
*
* (C) Copyright 2000-2007 Polyglot project group, Cornell University
* (C) Copyright IBM Corporation 2007-2012.
*/
package polyglot.ast;
import polyglot.types.QName;
/**
* An <code>Import</code> is an immutable representation of a Java
* <code>import</code> statement. It consists of the string representing the
* item being imported and the kind which is either indicating that a class
* is being imported, or that an entire package is being imported.
*/
public interface Import extends Node
{
/** Import kinds: class (e.g., import java.util.Set) or package (e.g.,
* import java.util.*).
*
* PACKAGE is a bit of a misnomer, since we can import p.C.*, where p.C
* is a class. This puts the nested classes of p.C in scope.
*/
public static enum Kind {
CLASS("class"),PACKAGE("package");
public final String name;
private Kind(String name) {
this.name = name;
}
@Override public String toString() {
return name;
}
}
public static final Kind CLASS = Kind.CLASS;
public static final Kind PACKAGE = Kind.PACKAGE;
/** Get the name of the class or package to import. */
QName name();
/** Set the name of the class or package to import. */
Import name(QName name);
/** Get the kind of import. */
Kind kind();
/** Set the kind of import. */
Import kind(Kind kind);
}