Example usage for org.eclipse.jdt.internal.compiler.lookup Scope COMPILATION_UNIT_SCOPE

List of usage examples for org.eclipse.jdt.internal.compiler.lookup Scope COMPILATION_UNIT_SCOPE

Introduction

In this page you can find the example usage for org.eclipse.jdt.internal.compiler.lookup Scope COMPILATION_UNIT_SCOPE.

Prototype

int COMPILATION_UNIT_SCOPE

To view the source code for org.eclipse.jdt.internal.compiler.lookup Scope COMPILATION_UNIT_SCOPE.

Click Source Link

Usage

From source file:com.codenvy.ide.ext.java.server.internal.core.util.HandleFactory.java

License:Open Source License

/**
 * Create handle by adding child to parent obtained by recursing into parent scopes.
 *//*from ww  w.j  a v a2  s . c o  m*/
private IJavaElement createElement(Scope scope, int elementPosition, ICompilationUnit unit,
        HashSet existingElements, HashMap knownScopes) {
    IJavaElement newElement = (IJavaElement) knownScopes.get(scope);
    if (newElement != null)
        return newElement;

    switch (scope.kind) {
    case Scope.COMPILATION_UNIT_SCOPE:
        newElement = unit;
        break;
    case Scope.CLASS_SCOPE:
        IJavaElement parentElement = createElement(scope.parent, elementPosition, unit, existingElements,
                knownScopes);
        switch (parentElement.getElementType()) {
        case IJavaElement.COMPILATION_UNIT:
            newElement = ((ICompilationUnit) parentElement)
                    .getType(new String(scope.enclosingSourceType().sourceName));
            break;
        case IJavaElement.TYPE:
            newElement = ((IType) parentElement).getType(new String(scope.enclosingSourceType().sourceName));
            break;
        case IJavaElement.FIELD:
        case IJavaElement.INITIALIZER:
        case IJavaElement.METHOD:
            IMember member = (IMember) parentElement;
            if (member.isBinary()) {
                return null;
            } else {
                newElement = member.getType(new String(scope.enclosingSourceType().sourceName), 1);
                // increment occurrence count if collision is detected
                if (newElement != null) {
                    while (!existingElements.add(newElement))
                        ((SourceRefElement) newElement).occurrenceCount++;
                }
            }
            break;
        }
        if (newElement != null) {
            knownScopes.put(scope, newElement);
        }
        break;
    case Scope.METHOD_SCOPE:
        IType parentType = (IType) createElement(scope.parent, elementPosition, unit, existingElements,
                knownScopes);
        MethodScope methodScope = (MethodScope) scope;
        if (methodScope.isInsideInitializer()) {
            // inside field or initializer, must find proper one
            TypeDeclaration type = methodScope.referenceType();
            int occurenceCount = 1;
            int length = type.fields == null ? 0 : type.fields.length;
            for (int i = 0; i < length; i++) {
                FieldDeclaration field = type.fields[i];
                if (field.declarationSourceStart <= elementPosition
                        && elementPosition <= field.declarationSourceEnd) {
                    switch (field.getKind()) {
                    case AbstractVariableDeclaration.FIELD:
                    case AbstractVariableDeclaration.ENUM_CONSTANT:
                        newElement = parentType.getField(new String(field.name));
                        break;
                    case AbstractVariableDeclaration.INITIALIZER:
                        newElement = parentType.getInitializer(occurenceCount);
                        break;
                    }
                    break;
                } else if (field.getKind() == AbstractVariableDeclaration.INITIALIZER) {
                    occurenceCount++;
                }
            }
        } else {
            // method element
            AbstractMethodDeclaration method = methodScope.referenceMethod();
            newElement = parentType.getMethod(new String(method.selector),
                    Util.typeParameterSignatures(method));
            if (newElement != null) {
                knownScopes.put(scope, newElement);
            }
        }
        break;
    case Scope.BLOCK_SCOPE:
        // standard block, no element per se
        newElement = createElement(scope.parent, elementPosition, unit, existingElements, knownScopes);
        break;
    }
    return newElement;
}

From source file:org.eclipse.che.jdt.internal.core.util.HandleFactory.java

License:Open Source License

/**
 * Create handle by adding child to parent obtained by recursing into parent scopes.
 *//*from   w  w  w  .  j a v a2 s .  co m*/
public IJavaElement createElement(Scope scope, int elementPosition, ICompilationUnit unit,
        HashSet existingElements, HashMap knownScopes) {
    IJavaElement newElement = (IJavaElement) knownScopes.get(scope);
    if (newElement != null)
        return newElement;

    switch (scope.kind) {
    case Scope.COMPILATION_UNIT_SCOPE:
        newElement = unit;
        break;
    case Scope.CLASS_SCOPE:
        IJavaElement parentElement = createElement(scope.parent, elementPosition, unit, existingElements,
                knownScopes);
        switch (parentElement.getElementType()) {
        case IJavaElement.COMPILATION_UNIT:
            newElement = ((ICompilationUnit) parentElement)
                    .getType(new String(scope.enclosingSourceType().sourceName));
            break;
        case IJavaElement.TYPE:
            newElement = ((IType) parentElement).getType(new String(scope.enclosingSourceType().sourceName));
            break;
        case IJavaElement.FIELD:
        case IJavaElement.INITIALIZER:
        case IJavaElement.METHOD:
            IMember member = (IMember) parentElement;
            if (member.isBinary()) {
                return null;
            } else {
                newElement = member.getType(new String(scope.enclosingSourceType().sourceName), 1);
                // increment occurrence count if collision is detected
                if (newElement != null) {
                    while (!existingElements.add(newElement))
                        ((SourceRefElement) newElement).occurrenceCount++;
                }
            }
            break;
        }
        if (newElement != null) {
            knownScopes.put(scope, newElement);
        }
        break;
    case Scope.METHOD_SCOPE:
        if (scope.isLambdaScope()) {
            parentElement = createElement(scope.parent, elementPosition, unit, existingElements, knownScopes);
            LambdaExpression expression = (LambdaExpression) scope.originalReferenceContext();
            if (expression.resolvedType != null && expression.resolvedType.isValidBinding()
                    && !(expression.descriptor instanceof ProblemMethodBinding)) { // chain in lambda element only if resolved properly.
                //newElement = new org.eclipse.jdt.internal.core.SourceLambdaExpression((JavaElement) parentElement, expression)
                // .getMethod();

                newElement = LambdaFactory.createLambdaExpression((JavaElement) parentElement, expression)
                        .getMethod();
                knownScopes.put(scope, newElement);
                return newElement;
            }
            return parentElement;
        }
        IType parentType = (IType) createElement(scope.parent, elementPosition, unit, existingElements,
                knownScopes);
        MethodScope methodScope = (MethodScope) scope;
        if (methodScope.isInsideInitializer()) {
            // inside field or initializer, must find proper one
            TypeDeclaration type = methodScope.referenceType();
            int occurenceCount = 1;
            int length = type.fields == null ? 0 : type.fields.length;
            for (int i = 0; i < length; i++) {
                FieldDeclaration field = type.fields[i];
                if (field.declarationSourceStart <= elementPosition
                        && elementPosition <= field.declarationSourceEnd) {
                    switch (field.getKind()) {
                    case AbstractVariableDeclaration.FIELD:
                    case AbstractVariableDeclaration.ENUM_CONSTANT:
                        newElement = parentType.getField(new String(field.name));
                        break;
                    case AbstractVariableDeclaration.INITIALIZER:
                        newElement = parentType.getInitializer(occurenceCount);
                        break;
                    }
                    break;
                } else if (field.getKind() == AbstractVariableDeclaration.INITIALIZER) {
                    occurenceCount++;
                }
            }
        } else {
            // method element
            AbstractMethodDeclaration method = methodScope.referenceMethod();
            newElement = parentType.getMethod(new String(method.selector),
                    Util.typeParameterSignatures(method));
            if (newElement != null) {
                knownScopes.put(scope, newElement);
            }
        }
        break;
    case Scope.BLOCK_SCOPE:
        // standard block, no element per se
        newElement = createElement(scope.parent, elementPosition, unit, existingElements, knownScopes);
        break;
    }
    return newElement;
}

From source file:org.eclipse.jdt.internal.compiler.lookup.Scope.java

License:Open Source License

public boolean isInsideDeprecatedCode() {
    switch (this.kind) {
    case Scope.BLOCK_SCOPE:
    case Scope.METHOD_SCOPE:
        MethodScope methodScope = methodScope();
        if (!methodScope.isInsideInitializer()) {
            // check method modifiers to see if deprecated
            MethodBinding context = ((AbstractMethodDeclaration) methodScope.referenceContext).binding;
            if (context != null && context.isViewedAsDeprecated())
                return true;
        } else if (methodScope.initializedField != null
                && methodScope.initializedField.isViewedAsDeprecated()) {
            // inside field declaration ? check field modifier to see if deprecated
            return true;
        }//from  www. j  a v a 2  s  .c o  m
        SourceTypeBinding declaringType = ((BlockScope) this).referenceType().binding;
        if (declaringType != null) {
            declaringType.initializeDeprecatedAnnotationTagBits(); // may not have been resolved until then
            if (declaringType.isViewedAsDeprecated())
                return true;
        }
        break;
    case Scope.CLASS_SCOPE:
        ReferenceBinding context = ((ClassScope) this).referenceType().binding;
        if (context != null) {
            context.initializeDeprecatedAnnotationTagBits(); // may not have been resolved until then
            if (context.isViewedAsDeprecated())
                return true;
        }
        break;
    case Scope.COMPILATION_UNIT_SCOPE:
        // consider import as being deprecated if first type is itself deprecated (123522)
        CompilationUnitDeclaration unit = referenceCompilationUnit();
        if (unit.types != null && unit.types.length > 0) {
            SourceTypeBinding type = unit.types[0].binding;
            if (type != null) {
                type.initializeDeprecatedAnnotationTagBits(); // may not have been resolved until then
                if (type.isViewedAsDeprecated())
                    return true;
            }
        }
    }
    return false;
}

From source file:org.eclipse.objectteams.otdt.internal.core.compiler.lookup.AnchorMapping.java

License:Open Source License

@SuppressWarnings("nls")
private String computeScopeKind(Scope scope) {
    String result;/*w  w  w.j a v  a  2s  .co m*/
    if (scope == null) {
        return "scope is null";
    }
    switch (scope.kind) {
    case Scope.BLOCK_SCOPE:
        result = "BlockScope";
        break;
    case Scope.METHOD_SCOPE:
        result = "MethodScope";
        break;
    case Scope.CLASS_SCOPE:
        result = "ClassScope";
        break;
    case Scope.COMPILATION_UNIT_SCOPE:
        result = "CompilationUnitScope";
        break;
    case Scope.BINDING_SCOPE:
        result = "BindingScope";
        break;
    default:
        result = "unknown scope type";
    }
    return result;
}

From source file:org.eclipse.objectteams.otdt.internal.core.compiler.util.RoleTypeCreator.java

License:Open Source License

/**
 * Find a variable by name in scope, possibly resolving a field for this purpose.
 * @param scope/* ww  w .ja  v a  2  s  . com*/
 * @param name
 * @return valid or null binding.
 */
public static VariableBinding findResolvedVariable(Scope scope, char[] name) {
    if (scope.kind == Scope.COMPILATION_UNIT_SCOPE)
        return null; // no single name variables in compilation unit scopes

    // first try immediate scope:
    VariableBinding anchor = scope.findVariable(name);
    if (anchor != null)
        return anchor;

    // get class-part scope:
    Scope classPartScope = scope;
    TypeDeclaration type = scope.referenceType();
    if (type.isRole() && type.isInterface()) {
        TypeDeclaration classPartAst = type.getRoleModel().getClassPartAst();
        if (classPartAst != null)
            classPartScope = classPartAst.scope;
    }

    // find anchor-field in the class-part, if different from direct scope:
    if (classPartScope != scope)
        anchor = classPartScope.findVariable(name);
    if (anchor != null)
        return anchor;

    // travel out through enclosing scopes:
    anchor = findResolvedVariable(scope.parent, name);
    if (anchor != null)
        return anchor;

    // other fields of the enclosing type may not yet be resolved:
    return resolveField(classPartScope, name);
}