Scope.java :  » Code-Analyzer » pmd-4.2rc1 » net » sourceforge » pmd » symboltable » Java Open Source

Java Open Source » Code Analyzer » pmd 4.2rc1 
pmd 4.2rc1 » net » sourceforge » pmd » symboltable » Scope.java
/**
 * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
 */
package net.sourceforge.pmd.symboltable;

import java.util.List;
import java.util.Map;

/**
 * Provides methods which all scopes must implement
 * <p/>
 * See JLS 6.3 for a description of scopes
 */
public interface Scope {

    /**
     * Returns a Map (VariableNameDeclaration->List(NameOccurrence,NameOccurrence)) of declarations that
     * exist at this scope
     */
    Map<VariableNameDeclaration, List<NameOccurrence>> getVariableDeclarations();

    /**
     * Returns a Map (VariableNameDeclaration->List(NameOccurrence,NameOccurrence)) of declarations that
     * exist at this scope
     */
    Map<ClassNameDeclaration, List<NameOccurrence>> getClassDeclarations();

    /**
     * Add a class declaration to this scope
     */
    void addDeclaration(ClassNameDeclaration decl);

    /**
     * Add a variable declaration to this scope
     */
    void addDeclaration(VariableNameDeclaration decl);

    /**
     * Add a method declaration to this scope
     */
    void addDeclaration(MethodNameDeclaration decl);

    /**
     * Tests whether or not a NameOccurrence is directly contained in the scope
     * Note that this search is just for this scope - it doesn't go diving into any
     * child scopes.
     */
    boolean contains(NameOccurrence occ);

    /**
     * Adds a NameOccurrence to this scope - only call this after getting
     * a true back from contains()
     */
    NameDeclaration addVariableNameOccurrence(NameOccurrence occ);

    /**
     * Points this scope to its parent
     */
    void setParent(Scope parent);

    /**
     * Retrieves this scope's parent
     */
    Scope getParent();

    /**
     * Goes searching up the tree for this scope's enclosing ClassScope
     * This is handy if you're buried down in a LocalScope and need to
     * hop up to the ClassScope to find a method name.
     */
    ClassScope getEnclosingClassScope();

    /**
     * Goes searching up the tree for this scope's enclosing SourceFileScope
     * This is handy if you're buried down in a LocalScope and need to
     * hop up to the SourceFileScope to find a class name.
     */
    SourceFileScope getEnclosingSourceFileScope();

    /**
     * Goes searching up the tree for this scope's enclosing MethodScope
     * This is handy if you're buried down in a LocalScope and need to
     * hop up to the MethodScope to find a method parameter.
     */
    MethodScope getEnclosingMethodScope();
}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.