| /******************************************************************************* |
| * Copyright (c) 2000, 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.eval; |
| |
| import org.eclipse.jdt.internal.compiler.ClassFile; |
| import org.eclipse.jdt.internal.compiler.CompilationResult; |
| import org.eclipse.jdt.internal.compiler.ast.ASTNode; |
| import org.eclipse.jdt.internal.compiler.ast.TypeDeclaration; |
| import org.eclipse.jdt.internal.compiler.lookup.TagBits; |
| import org.eclipse.jdt.internal.compiler.lookup.TypeVariableBinding; |
| import org.eclipse.jdt.internal.compiler.problem.AbortType; |
| import org.eclipse.jdt.internal.compiler.util.Util; |
| |
| public class CodeSnippetTypeDeclaration extends TypeDeclaration { |
| |
| public CodeSnippetTypeDeclaration(CompilationResult compilationResult){ |
| super(compilationResult); |
| } |
| |
| /** |
| * Generic bytecode generation for type |
| */ |
| public void generateCode(ClassFile enclosingClassFile) { |
| if ((this.bits & ASTNode.HasBeenGenerated) != 0) return; |
| this.bits |= ASTNode.HasBeenGenerated; |
| |
| if (this.ignoreFurtherInvestigation) { |
| if (this.binding == null) |
| return; |
| CodeSnippetClassFile.createProblemType(this, this.scope.referenceCompilationUnit().compilationResult); |
| return; |
| } |
| try { |
| // create the result for a compiled type |
| ClassFile classFile = new CodeSnippetClassFile(this.binding, enclosingClassFile, false); |
| // generate all fiels |
| classFile.addFieldInfos(); |
| if (this.binding.isMemberType()) { |
| classFile.recordInnerClasses(this.binding); |
| } else if (this.binding.isLocalType()) { |
| enclosingClassFile.recordInnerClasses(this.binding); |
| classFile.recordInnerClasses(this.binding); |
| } |
| TypeVariableBinding[] typeVariables = this.binding.typeVariables(); |
| for (int i = 0, max = typeVariables.length; i < max; i++) { |
| TypeVariableBinding typeVariableBinding = typeVariables[i]; |
| if ((typeVariableBinding.tagBits & TagBits.ContainsNestedTypeReferences) != 0) { |
| Util.recordNestedType(classFile, typeVariableBinding); |
| } |
| } |
| if (this.memberTypes != null) { |
| for (int i = 0, max = this.memberTypes.length; i < max; i++) { |
| TypeDeclaration memberType = this.memberTypes[i]; |
| classFile.recordInnerClasses(memberType.binding); |
| memberType.generateCode(this.scope, classFile); |
| } |
| } |
| // generate all methods |
| classFile.setForMethodInfos(); |
| if (this.methods != null) { |
| for (int i = 0, max = this.methods.length; i < max; i++) { |
| this.methods[i].generateCode(this.scope, classFile); |
| } |
| } |
| |
| // generate all methods |
| classFile.addSpecialMethods(); |
| |
| if (this.ignoreFurtherInvestigation){ // trigger problem type generation for code gen errors |
| throw new AbortType(this.scope.referenceCompilationUnit().compilationResult, null); |
| } |
| |
| // finalize the compiled type result |
| classFile.addAttributes(); |
| this.scope.referenceCompilationUnit().compilationResult.record(this.binding.constantPoolName(), classFile); |
| } catch (AbortType e) { |
| if (this.binding == null) |
| return; |
| CodeSnippetClassFile.createProblemType(this, this.scope.referenceCompilationUnit().compilationResult); |
| } |
| } |
| } |