forked from JavaTX/JavaCompilerCore
merge mit sat
This commit is contained in:
commit
166aa5e506
8
pom.xml
8
pom.xml
@ -73,6 +73,14 @@
|
|||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<source>9</source>
|
||||||
|
<target>9</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
<properties>
|
<properties>
|
||||||
|
@ -40,9 +40,19 @@ public class CompilationEnvironment {
|
|||||||
* @param sourceFiles die zu kompilierenden Dateien
|
* @param sourceFiles die zu kompilierenden Dateien
|
||||||
*/
|
*/
|
||||||
public CompilationEnvironment(List<File> sourceFiles) {
|
public CompilationEnvironment(List<File> sourceFiles) {
|
||||||
String bootClassPath = System.getProperty("sun.boot.class.path");
|
/**
|
||||||
|
* Java 9 bringt einige Änderungen am Classloader
|
||||||
|
* So funktioniert der BootClassLoader nicht mehr.
|
||||||
|
* hier gibts ein paar Quellen zum nachlesen:
|
||||||
|
* http://java9.wtf/class-loading/
|
||||||
|
* https://stackoverflow.com/questions/46494112/classloaders-hierarchy-in-java-9
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
//String bootClassPath = System.getProperty("sun.boot.class.path");
|
||||||
|
// ClassLoader cl = ClassLoader.getPlatformClassLoader();
|
||||||
|
ClassLoader cl = ClassLoader.getSystemClassLoader();
|
||||||
|
String bootClassPath = System.getProperty("java.class.path");
|
||||||
librarys = new ArrayList<>();
|
librarys = new ArrayList<>();
|
||||||
if(bootClassPath != null){
|
|
||||||
for(String path : bootClassPath.split(File.pathSeparator)) {
|
for(String path : bootClassPath.split(File.pathSeparator)) {
|
||||||
try {
|
try {
|
||||||
librarys.add(new URL("file:"+path));
|
librarys.add(new URL("file:"+path));
|
||||||
@ -50,7 +60,9 @@ public class CompilationEnvironment {
|
|||||||
new DebugException("Fehler im Classpath auf diesem System");
|
new DebugException("Fehler im Classpath auf diesem System");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
//URLClassLoader loader = new URLClassLoader(new URL[0], cl);
|
||||||
|
//librarys = Arrays.asList(loader.getURLs());
|
||||||
|
|
||||||
this.sourceFiles = sourceFiles;
|
this.sourceFiles = sourceFiles;
|
||||||
this.packageCrawler = new PackageCrawler(librarys);
|
this.packageCrawler = new PackageCrawler(librarys);
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,8 @@ public enum ASPRule {
|
|||||||
ASP_PARAMLIST_NAME("param"),
|
ASP_PARAMLIST_NAME("param"),
|
||||||
ASP_PARAMLISTNUMERATION_NAME("paramNum"),
|
ASP_PARAMLISTNUMERATION_NAME("paramNum"),
|
||||||
ASP_PARAMLIST_END_POINTER("null"),
|
ASP_PARAMLIST_END_POINTER("null"),
|
||||||
ASP_TYPE("type")
|
ASP_TYPE("type"),
|
||||||
|
ASP_FCTYPE("type")
|
||||||
;
|
;
|
||||||
|
|
||||||
private final String text;
|
private final String text;
|
||||||
|
@ -36,8 +36,8 @@ public class ASPGenerator {
|
|||||||
private String toASP(List<Pair> constraintSet, Collection<ClassOrInterface> fcClasses){
|
private String toASP(List<Pair> constraintSet, Collection<ClassOrInterface> fcClasses){
|
||||||
TypeConverter converter = new TypeConverter();
|
TypeConverter converter = new TypeConverter();
|
||||||
for(ClassOrInterface cl : fcClasses){
|
for(ClassOrInterface cl : fcClasses){
|
||||||
ASPType superClass = cl.getSuperClass().acceptTV(converter);
|
ASPRefType superClass = (ASPRefType) cl.getSuperClass().acceptTV(converter);
|
||||||
ASPPairSmaller fcEntry = new ASPPairSmaller(convert(cl), superClass);
|
ASPPairSmaller fcEntry = new ASPPairSmaller(new ASPFCType(convert(cl)), new ASPFCType(superClass), writer);
|
||||||
writer.add(new ASPStatement(fcEntry.toASP()));
|
writer.add(new ASPStatement(fcEntry.toASP()));
|
||||||
}
|
}
|
||||||
for(Pair cons : constraintSet){
|
for(Pair cons : constraintSet){
|
||||||
@ -52,13 +52,13 @@ public class ASPGenerator {
|
|||||||
ASPType ls = pair.TA1.acceptTV(converter);
|
ASPType ls = pair.TA1.acceptTV(converter);
|
||||||
ASPType rs = pair.TA2.acceptTV(converter);
|
ASPType rs = pair.TA2.acceptTV(converter);
|
||||||
if(pair.OperatorEqual()){
|
if(pair.OperatorEqual()){
|
||||||
return new ASPPairEquals(ls, rs);
|
return new ASPPairEquals(ls, rs,writer);
|
||||||
}else if(pair.OperatorSmallerDot()){
|
}else if(pair.OperatorSmallerDot()){
|
||||||
return new ASPPairSmallerDot(ls, rs);
|
return new ASPPairSmallerDot(ls, rs, writer);
|
||||||
}else throw new NotImplementedException();
|
}else throw new NotImplementedException();
|
||||||
}
|
}
|
||||||
|
|
||||||
private ASPType convert(ClassOrInterface cl){
|
private ASPRefType convert(ClassOrInterface cl){
|
||||||
List<ASPType> paramList = new ArrayList<>();
|
List<ASPType> paramList = new ArrayList<>();
|
||||||
for(GenericTypeVar gtv : cl.getGenerics()){
|
for(GenericTypeVar gtv : cl.getGenerics()){
|
||||||
paramList.add(new ASPGenericType(toConstant(gtv.getName())));
|
paramList.add(new ASPGenericType(toConstant(gtv.getName())));
|
||||||
|
14
src/de/dhbwstuttgart/sat/asp/writer/model/ASPFCType.java
Normal file
14
src/de/dhbwstuttgart/sat/asp/writer/model/ASPFCType.java
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
package de.dhbwstuttgart.sat.asp.writer.model;
|
||||||
|
|
||||||
|
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
||||||
|
import de.dhbwstuttgart.sat.asp.writer.ASPWriter;
|
||||||
|
|
||||||
|
public class ASPFCType extends ASPRefType {
|
||||||
|
public ASPFCType(ASPRefType refType){
|
||||||
|
super(refType.name, refType.params);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString(){
|
||||||
|
return ASPRule.ASP_FCTYPE + "(" + name +"," + params.name + ")";
|
||||||
|
}
|
||||||
|
}
|
@ -12,4 +12,14 @@ public class ASPGenericType implements ASPType{
|
|||||||
public String toString(){
|
public String toString(){
|
||||||
return ASPRule.ASP_GENERIC_TYPE_NAME + "(" + name + ")";
|
return ASPRule.ASP_GENERIC_TYPE_NAME + "(" + name + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toASP() {
|
||||||
|
return toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPointer() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,16 +1,20 @@
|
|||||||
package de.dhbwstuttgart.sat.asp.writer.model;
|
package de.dhbwstuttgart.sat.asp.writer.model;
|
||||||
|
|
||||||
|
import de.dhbwstuttgart.sat.asp.writer.ASPWriter;
|
||||||
|
|
||||||
public abstract class ASPPair {
|
public abstract class ASPPair {
|
||||||
public final ASPType leftSide;
|
public final ASPType leftSide;
|
||||||
public final ASPType rightSide;
|
public final ASPType rightSide;
|
||||||
|
|
||||||
public ASPPair(ASPType ls, ASPType rs){
|
public ASPPair(ASPType ls, ASPType rs, ASPWriter writer){
|
||||||
this.leftSide = ls;
|
this.leftSide = ls;
|
||||||
this.rightSide = rs;
|
this.rightSide = rs;
|
||||||
|
writer.add(new ASPStatement(ls.toASP()));
|
||||||
|
writer.add(new ASPStatement(rs.toASP()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toASP(){
|
public String toASP(){
|
||||||
return this.getRuleName() + "(" + leftSide + ","+ rightSide + ")";
|
return this.getRuleName() + "(" + leftSide.getPointer() + ","+ rightSide.getPointer() + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString(){
|
public String toString(){
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
package de.dhbwstuttgart.sat.asp.writer.model;
|
package de.dhbwstuttgart.sat.asp.writer.model;
|
||||||
|
|
||||||
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
||||||
|
import de.dhbwstuttgart.sat.asp.writer.ASPWriter;
|
||||||
|
|
||||||
public class ASPPairEquals extends ASPPair{
|
public class ASPPairEquals extends ASPPair{
|
||||||
public ASPPairEquals(ASPType ls, ASPType rs){
|
public ASPPairEquals(ASPType ls, ASPType rs, ASPWriter writer){
|
||||||
super(ls, rs);
|
super(ls, rs, writer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
package de.dhbwstuttgart.sat.asp.writer.model;
|
package de.dhbwstuttgart.sat.asp.writer.model;
|
||||||
|
|
||||||
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
||||||
|
import de.dhbwstuttgart.sat.asp.writer.ASPWriter;
|
||||||
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
public class ASPPairSmaller extends ASPPair{
|
public class ASPPairSmaller extends ASPPair{
|
||||||
public ASPPairSmaller(ASPType ls, ASPType rs){
|
public ASPPairSmaller(ASPFCType ls, ASPFCType rs, ASPWriter writer){
|
||||||
super(ls, rs);
|
super(ls, rs, writer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
package de.dhbwstuttgart.sat.asp.writer.model;
|
package de.dhbwstuttgart.sat.asp.writer.model;
|
||||||
|
|
||||||
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
||||||
|
import de.dhbwstuttgart.sat.asp.writer.ASPWriter;
|
||||||
|
|
||||||
public class ASPPairSmallerDot extends ASPPair{
|
public class ASPPairSmallerDot extends ASPPair{
|
||||||
public ASPPairSmallerDot(ASPType ls, ASPType rs){
|
public ASPPairSmallerDot(ASPType ls, ASPType rs, ASPWriter writer){
|
||||||
super(ls, rs);
|
super(ls, rs, writer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -3,8 +3,8 @@ package de.dhbwstuttgart.sat.asp.writer.model;
|
|||||||
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
import de.dhbwstuttgart.sat.asp.model.ASPRule;
|
||||||
|
|
||||||
public class ASPRefType implements ASPType {
|
public class ASPRefType implements ASPType {
|
||||||
private final ASPParameterList params;
|
protected final ASPParameterList params;
|
||||||
private final String name;
|
protected final String name;
|
||||||
|
|
||||||
public ASPRefType(String name, ASPParameterList params){
|
public ASPRefType(String name, ASPParameterList params){
|
||||||
this.name = name;
|
this.name = name;
|
||||||
@ -18,4 +18,14 @@ public class ASPRefType implements ASPType {
|
|||||||
public String toString(){
|
public String toString(){
|
||||||
return ASPRule.ASP_TYPE + "(" + name +"," + params.name + ")";
|
return ASPRule.ASP_TYPE + "(" + name +"," + params.name + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toASP() {
|
||||||
|
return toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPointer() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,7 @@
|
|||||||
package de.dhbwstuttgart.sat.asp.writer.model;
|
package de.dhbwstuttgart.sat.asp.writer.model;
|
||||||
|
|
||||||
public interface ASPType {
|
public interface ASPType {
|
||||||
|
String toASP();
|
||||||
|
|
||||||
|
String getPointer();
|
||||||
}
|
}
|
||||||
|
@ -11,4 +11,14 @@ public class ASPTypeVar implements ASPType{
|
|||||||
public String toString() {
|
public String toString() {
|
||||||
return "typeVar("+ name +")";
|
return "typeVar("+ name +")";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toASP() {
|
||||||
|
return toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPointer() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
class Vector{
|
class Vector{
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user