/*******************************************************************************
* Copyright (c) 2009 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.internal.compiler;
import org.eclipse.jdt.core.IType;
import org.eclipse.jdt.core.JavaModelException;
import org.eclipse.jdt.internal.compiler.ast.TypeDeclaration;
import org.eclipse.jdt.internal.compiler.classfmt.ClassFileConstants;
import org.eclipse.jdt.internal.compiler.classfmt.ClassFileReader;
import org.eclipse.jdt.internal.compiler.env.IBinaryNestedType;
public final class ExtraFlags {
public final static int HasNonPrivateStaticMemberTypes= 0x0001;
public final static int IsMemberType= 0x0002;
public final static int IsLocalType= 0x0004;
//internal flags
public final static int ParameterTypesStoredAsSignature= 0x0010;
public static int getExtraFlags(ClassFileReader reader) {
int extraFlags= 0;
if (reader.isNestedType()) {
extraFlags|= ExtraFlags.IsMemberType;
}
if (reader.isLocal()) {
extraFlags|= ExtraFlags.IsLocalType;
}
IBinaryNestedType[] memberTypes= reader.getMemberTypes();
int memberTypeCounter= memberTypes == null ? 0 : memberTypes.length;
if (memberTypeCounter > 0) {
done: for (int i= 0; i < memberTypeCounter; i++) {
int modifiers= memberTypes[i].getModifiers();
// if the member type is static and not private
if ((modifiers & ClassFileConstants.AccStatic) != 0 && (modifiers & ClassFileConstants.AccPrivate) == 0) {
extraFlags|= ExtraFlags.HasNonPrivateStaticMemberTypes;
break done;
}
}
}
return extraFlags;
}
public static int getExtraFlags(IType type) throws JavaModelException {
int extraFlags= 0;
if (type.isMember()) {
extraFlags|= ExtraFlags.IsMemberType;
}
if (type.isLocal()) {
extraFlags|= ExtraFlags.IsLocalType;
}
IType[] memberTypes= type.getTypes();
int memberTypeCounter= memberTypes == null ? 0 : memberTypes.length;
if (memberTypeCounter > 0) {
done: for (int i= 0; i < memberTypeCounter; i++) {
int flags= memberTypes[i].getFlags();
// if the member type is static and not private
if ((flags & ClassFileConstants.AccStatic) != 0 && (flags & ClassFileConstants.AccPrivate) == 0) {
extraFlags|= ExtraFlags.HasNonPrivateStaticMemberTypes;
break done;
}
}
}
return extraFlags;
}
public static int getExtraFlags(TypeDeclaration typeDeclaration) {
int extraFlags= 0;
if (typeDeclaration.enclosingType != null) {
extraFlags|= ExtraFlags.IsMemberType;
}
TypeDeclaration[] memberTypes= typeDeclaration.memberTypes;
int memberTypeCounter= memberTypes == null ? 0 : memberTypes.length;
if (memberTypeCounter > 0) {
done: for (int i= 0; i < memberTypeCounter; i++) {
int modifiers= memberTypes[i].modifiers;
// if the member type is static and not private
if ((modifiers & ClassFileConstants.AccStatic) != 0 && (modifiers & ClassFileConstants.AccPrivate) == 0) {
extraFlags|= ExtraFlags.HasNonPrivateStaticMemberTypes;
break done;
}
}
}
return extraFlags;
}
}