2013-10-18 11:33:46 +00:00
// ino.module.ClassBody.8554.package
2014-09-02 08:33:54 +00:00
package de.dhbwstuttgart.syntaxtree ;
2013-10-18 11:33:46 +00:00
// ino.end
// ino.module.ClassBody.8554.import
import java.util.Enumeration ;
import java.util.Hashtable ;
2015-04-22 19:40:22 +00:00
import de.dhbwstuttgart.typeinference.Menge ;
2014-09-02 08:33:54 +00:00
2014-10-09 10:01:16 +00:00
import de.dhbwstuttgart.logger.Logger ;
2013-10-18 11:33:46 +00:00
// ino.end
2014-09-02 08:33:54 +00:00
2014-09-04 14:35:44 +00:00
import de.dhbwstuttgart.bytecode.ClassFile ;
import de.dhbwstuttgart.myexception.JVMCodeException ;
import de.dhbwstuttgart.myexception.SCClassBodyException ;
import de.dhbwstuttgart.myexception.SCExcept ;
import de.dhbwstuttgart.myexception.SCMethodException ;
2014-09-02 08:33:54 +00:00
import de.dhbwstuttgart.syntaxtree.type.RefType ;
import de.dhbwstuttgart.syntaxtree.type.Type ;
import de.dhbwstuttgart.typeinference.JavaCodeResult ;
import de.dhbwstuttgart.typeinference.ResultSet ;
2013-10-18 11:33:46 +00:00
// ino.class.ClassBody.23143.declaration
public class ClassBody
{
// ino.attribute.fielddecl.23146.declaration
2015-04-22 19:40:22 +00:00
private Menge < Field > fielddecl = new Menge < Field > ( ) ;
2013-10-18 11:33:46 +00:00
// ino.end
// ino.attribute.kill.23155.declaration
public Hashtable < Type , Type > kill = new Hashtable < Type , Type > ( ) ;
// ino.end
// ino.attribute.parserlog.23158.declaration
protected static Logger parserlog = Logger . getLogger ( " parser " ) ;
// ino.end
// ino.method.complete_parahashtable.23173.defdescription type=block
2015-04-22 19:40:22 +00:00
/ * public void set_paratype ( Menge classlist , UsedId superclass , Menge
2013-10-18 11:33:46 +00:00
pl , Hashtable ph , boolean ext ) { DeclId decl ;
FieldDecl field ;
System . out . println ( " ++ ParaCheck: Fielddecl's: " + fielddecl . toString ( ) ) ;
for ( Enumeration e = fielddecl . elements ( ) ; e . hasMoreElements ( ) ; ) {
field = ( FieldDecl ) e . nextElement ( ) ;
for ( Enumeration e1 = field . get_Name ( ) . elements ( ) ; e1 . hasMoreElements ( ) ; ) {
decl = ( DeclId ) e1 . nextElement ( ) ;
if ( superclass ! = null ) {
System . out . println ( " superclass.get_ParaList: "
+ superclass . get_ParaList ( ) . toString ( ) ) ;
for ( Enumeration e2 =
superclass . get_ParaList ( ) . elements ( ) ; e2 . hasMoreElements ( ) ; ) {
System . out . println ( " paralist.elements:: " + ( ( Type ) e2 . nextElement ( ) ) . get_Type ( ) ) ;
}
}
if ( decl . get_Paratyp ( ) ! = null ) {
System . out . println ( " ++ ParaCheck: Name:
" +decl.get_Name()+ " \ tParatyp : " +decl.get_Paratyp()); }
else System . out . println ( " ++ ParaCheck: Name: " + decl . get_Name ( ) + " \ tkein
Paratyp gesetzt . " ); }
}
}
* /
// ino.end
// ino.method.codegen.23176.definition
2015-04-22 19:40:22 +00:00
public void codegen ( ClassFile classfile , Menge paralist )
2013-10-18 11:33:46 +00:00
throws JVMCodeException
// ino.end
// ino.method.codegen.23176.body
{
for ( int i = 0 ; i < fielddecl . size ( ) ; i + + )
{
2014-02-11 01:47:39 +00:00
/ *
* if ( this . fielddecl . elementAt ( i ) instanceof InstVarDecl )
2013-10-18 11:33:46 +00:00
{
( ( InstVarDecl ) this . fielddecl . elementAt ( i ) ) . codegen ( classfile , paralist ) ;
}
else
2014-02-11 01:47:39 +00:00
* /
2013-10-18 11:33:46 +00:00
{
this . fielddecl . elementAt ( i ) . codegen ( classfile , paralist ) ;
}
}
}
// ino.end
2015-04-22 19:40:22 +00:00
public Menge < Field > getFields ( )
2013-10-18 11:33:46 +00:00
{
return fielddecl ;
}
2014-02-12 01:12:12 +00:00
/ * *
* @author Andreas Stadelmeier , a10023
2015-05-12 12:57:12 +00:00
* Fügt der Klasse eine Feld hinzu .
2014-02-12 01:12:12 +00:00
* @param feld
* /
public void addField ( Field i )
2013-10-18 11:33:46 +00:00
{
fielddecl . addElement ( i ) ;
}
2014-02-12 01:12:12 +00:00
2013-10-18 11:33:46 +00:00
// ino.method.is_declared.23188.defdescription type=line
//
// ********************************************************************************************
//
// ino.end
// ino.method.is_declared.23188.definition
2015-04-22 19:40:22 +00:00
public boolean is_declared ( Type t , Menge < Class > classlist )
2013-10-18 11:33:46 +00:00
throws SCClassBodyException
// ino.end
// ino.method.is_declared.23188.body
{
boolean flag = false ;
for ( Enumeration < Class > e = classlist . elements ( ) ; e . hasMoreElements ( ) ; )
{
flag = false ;
Class c = e . nextElement ( ) ;
// System.out.println("is_init: vergleiche "+t.get_Type_()+" mit "+c.getName());
if ( c . getName ( ) . equals ( t . getName ( ) ) ) {
2015-04-22 19:40:22 +00:00
// System.out.println("Klasse "+t.get_Type()+"im Menge classlist gefunden.");
2013-10-18 11:33:46 +00:00
flag = true ;
break ;
}
}
if ( t instanceof RefType & & ( ( RefType ) t ) . get_ParaList ( ) ! = null )
{
if ( ( ( RefType ) t ) . get_ParaList ( ) . size ( ) > 0 )
{
for ( Enumeration e1 = ( ( RefType ) t ) . get_ParaList ( ) . elements ( ) ; e1 . hasMoreElements ( ) ; )
{
try
{
is_declared ( ( Type ) e1 . nextElement ( ) , classlist ) ;
}
catch ( SCClassBodyException ex )
{
throw ex ;
}
}
}
}
if ( flag )
return true ;
else
{
SCClassBodyException ex = new SCClassBodyException ( ) ;
SCExcept e = new SCExcept ( ) ;
e . set_error ( " unbekannte Klasse " + t . getName ( ) + " . " ) ;
e . set_function ( " complete_parahashtable() --> is_declared() " ) ;
2014-09-02 16:49:19 +00:00
e . set_statement ( t . getName ( ) . toString ( ) ) ;
2013-10-18 11:33:46 +00:00
ex . addException ( e ) ;
throw ex ;
}
}
// ino.end
// ino.method.string_rec.23191.definition
static String string_rec ( Hashtable ht )
// ino.end
// ino.method.string_rec.23191.body
{
String record = ( " [ " ) ;
for ( Enumeration e = ht . elements ( ) , k = ht . keys ( ) ; e . hasMoreElements ( ) ; ) {
String s = ( String ) k . nextElement ( ) ;
Object o = e . nextElement ( ) ;
record = record . concat ( " " + s ) ;
if ( o instanceof Type ) {
record = record . concat ( " = " + ( ( Type ) o ) . getName ( ) ) ;
}
else if ( o instanceof Hashtable ) {
record = record . concat ( " = " ) ;
record = record . concat ( string_rec ( ( Hashtable ) o ) ) ;
if ( e . hasMoreElements ( ) )
record = record . concat ( " , " ) ;
}
else if ( o instanceof String ) {
record = record . concat ( " = " + o ) ;
if ( e . hasMoreElements ( ) )
record = record . concat ( " , " ) ;
}
else {
record = ( " [ FEHLER : string_rec : unbekannter Typ ! ! ! ! ! ! " );
}
}
record = record . concat ( " ] " ) ;
return ( record ) ;
}
// ino.end
// ino.method.string_rec.23194.defdescription type=block
2015-04-22 19:40:22 +00:00
/ * static void string_rec ( Menge v ) {
2013-10-18 11:33:46 +00:00
String record = ( " { " ) ;
for ( Enumeration e = v . elements ( ) ; e . hasMoreElements ( ) ; ) {
Type t = ( Type ) e . nextElement ( ) ;
record = record . concat ( " " + t . getName ( ) ) ;
if ( e . hasMoreElements ( ) )
record = record . concat ( " , " ) ;
}
record = record . concat ( " } " ) ;
parserlog . debug ( record ) ;
} * /
// ino.end
// ino.method.string_rec.23194.definition
static String string_rec ( String st , Hashtable ht )
// ino.end
// ino.method.string_rec.23194.body
{
String record = ( st ) ;
record = record . concat ( " [ " ) ;
for ( Enumeration e = ht . elements ( ) , k = ht . keys ( ) ; e . hasMoreElements ( ) ; ) {
String s = ( String ) k . nextElement ( ) ;
Object o = e . nextElement ( ) ;
record = record . concat ( " " + s ) ;
if ( o instanceof Type ) {
record = record . concat ( " = " + ( ( Type ) o ) . getName ( ) ) ;
}
else if ( o instanceof Hashtable ) {
record = record . concat ( " = " ) ;
record = record . concat ( string_rec ( ( Hashtable ) o ) ) ;
if ( e . hasMoreElements ( ) )
record = record . concat ( " , " ) ;
}
else if ( o instanceof String ) {
record = record . concat ( " = " + o ) ;
if ( e . hasMoreElements ( ) )
record = record . concat ( " , " ) ;
}
else {
record = ( " FEHLER : string_rec : unbekannter Typ ! ! ! ! ! ! " +o);
}
}
record = record . concat ( " ] " ) ;
return ( record ) ;
}
// ino.end
// ino.method.string_rec.23197.definition
2015-04-22 19:40:22 +00:00
static String string_rec ( String st , Menge v )
2013-10-18 11:33:46 +00:00
// ino.end
// ino.method.string_rec.23197.body
{
String record = ( st ) ;
record = record . concat ( " { " ) ;
for ( Enumeration e = v . elements ( ) ; e . hasMoreElements ( ) ; ) {
Type t = ( Type ) e . nextElement ( ) ;
record = record . concat ( " " + t . getName ( ) ) ;
if ( e . hasMoreElements ( ) )
record = record . concat ( " , " ) ;
}
record = record . concat ( " } " ) ;
return ( record ) ;
}
// ino.end
// ino.method.istParameterOK.23200.defdescription type=line
//
// ********************************************************************************************
//
// ino.end
2014-11-04 12:47:05 +00:00
/ *
2013-10-18 11:33:46 +00:00
// ino.method.istParameterOK.23200.definition
2015-04-22 19:40:22 +00:00
public void istParameterOK ( Menge Parameter , Menge < Class > KlassenVektor )
2013-10-18 11:33:46 +00:00
// ino.end
// ino.method.istParameterOK.23200.body
{
// otth: prueft rekursiv, ob Parameter im Klassenvektor vorkommt, falls RefType, oder ob TypePlaceholder nicht vorkommt
for ( int i = 0 ; i < Parameter . size ( ) ; i + + )
{
Type TempParameter = ( Type ) ( Parameter . elementAt ( i ) ) ;
// an dieser Stelle: Parametername
if ( TempParameter instanceof RefType )
{
// t im Klassenvektor suchen --> muss deklariert sein
boolean bGefunden = false ;
for ( int k = 0 ; k < KlassenVektor . size ( ) ; k + + )
{
if ( KlassenVektor . elementAt ( k ) . getName ( ) . equals ( ( ( RefType ) TempParameter ) . getTypeName ( ) ) )
{
// Namen gleich --> Parameterliste rekursiv pruefen
if ( ( ( RefType ) TempParameter ) . get_ParaList ( ) ! = null )
{
if ( ( ( RefType ) TempParameter ) . get_ParaList ( ) . size ( ) ! = KlassenVektor . elementAt ( k ) . get_ParaList ( ) . size ( ) )
{
2015-05-12 12:57:12 +00:00
parserlog . error ( " SEMANTIK-CHECK-FEHLER: Parameteranzahl von \ n " + TempParameter . getName ( ) + " stimmt mit der Klassendefinition \ n " + KlassenVektor . elementAt ( k ) . getName ( ) + " nicht �berein. " , Section . OLD ) ;
2013-10-18 11:33:46 +00:00
System . exit ( 1 ) ;
}
else
{
istParameterOK ( ( ( RefType ) TempParameter ) . get_ParaList ( ) , KlassenVektor ) ;
bGefunden = true ;
break ;
}
}
else
{
// OK ...
bGefunden = true ;
break ;
}
}
}
// Parameter wurde nicht gefunden:
if ( ! bGefunden )
{
parserlog . error ( " SEMANTIK-CHECK-FEHLER: Parameter " + TempParameter . getName ( ) + " ist noch nicht als Klasse definiert. " ) ;
System . exit ( 1 ) ;
}
}
else
{
2015-05-12 12:57:12 +00:00
// Tylose Variablen d�rfen nicht deklariert sein
2013-10-18 11:33:46 +00:00
for ( int k = 0 ; k < KlassenVektor . size ( ) ; k + + )
{
if ( KlassenVektor . elementAt ( k ) . getName ( ) . equals ( TempParameter . getName ( ) ) )
{
parserlog . error ( " SEMANTIK-CHECK-FEHLER: Parameter " + TempParameter . getName ( ) + " ist bereits als Klasse definiert. " ) ;
System . exit ( 1 ) ;
}
}
// nicht gefunden
}
} // end otth; end if: t = RefType
}
// ino.end
2014-11-04 12:47:05 +00:00
* /
2013-10-18 11:33:46 +00:00
// ino.method.toString.23203.defdescription type=javadoc
/ * *
2015-05-12 12:57:12 +00:00
* < br / > Author : Martin Plï ¿ ½ micke
2013-10-18 11:33:46 +00:00
* @return
* /
// ino.end
// ino.method.toString.23203.definition
public String toString ( )
// ino.end
// ino.method.toString.23203.body
{
return fielddecl . toString ( ) ;
}
// ino.end
public JavaCodeResult printJavaCode ( ResultSet resultSet ) {
JavaCodeResult ret = new JavaCodeResult ( " { \ n " ) ;
2014-02-11 01:47:39 +00:00
for ( Field field : this . fielddecl ) ret . attach ( field . printJavaCode ( resultSet ) ) . attach ( " \ n " ) ;
2013-10-18 11:33:46 +00:00
return ret . attach ( " } \ n " ) ;
}
2014-02-12 01:12:12 +00:00
2013-10-18 11:33:46 +00:00
}
// ino.end