use of ast.ExpCore.ClassB in project L42 by ElvisResearchGroup.
the class UsedPaths method collectPaths.
Void collectPaths(List<Path> ps, MethodImplemented mi) {
ps.addAll(CollectPaths0.of(mi.getInner()));
List<ClassB> cbs = CollectClassBs0.of(mi.getInner());
for (ClassB cb : cbs) {
ps.addAll(Functions.remove1OuterAndPrimitives(of(cb)));
}
return null;
}
use of ast.ExpCore.ClassB in project L42 by ElvisResearchGroup.
the class UsedPathsPlus method collectPaths.
Void collectPaths(List<Path> ps, NestedClass nc) {
if (!(nc.getInner() instanceof ClassB)) {
return null;
}
ClassB cb = (ClassB) nc.getInner();
assert IsCompiled.of(cb);
//assert Configuration.typeExtraction.isCt(cb);
ps.addAll(nc.getDoc().getPaths());
ps.addAll(Functions.remove1OuterAndPrimitives(of(cb)));
return null;
}
use of ast.ExpCore.ClassB in project L42 by ElvisResearchGroup.
the class TsLibrary method libraryWellTyped.
default default TOut libraryWellTyped(TIn in) {
// (library well typed)
// Phase |- p ~> L' //In implementation, if p.top().Phase>=Phase, L'=p.Top()
ClassB top = in.p.top();
assert // Phase in {Typed,Coherent}
in.phase.subtypeEq(Phase.Typed) : "";
if (top.getPhase().subtypeEq(in.phase)) {
return new TOk(in, top, Path.Library().toImmNT());
}
// L0={interface? implements Ps M1..Mn Phase'}=norm(p)
// L'={interface? implements Ps M1'..Mn' max(Phase',Phase)}
ClassB L0 = normTopL(in);
List<MethodWithType> mwts = L0.mwts();
List<NestedClass> ns = L0.ns();
List<NestedClass> newNs = new ArrayList<>();
// forall i in 1..n
// Phase| p| Ps |- Mi ~> Mi'
TIn inNested = in.withP(in.p.updateTop(L0));
List<MethodWithType> newMwts;
if (in.phase == Phase.Coherent && top.getPhase() == Phase.Typed) {
newMwts = new ArrayList<>(mwts);
} else {
newMwts = new ArrayList<>();
for (MethodWithType mwt : mwts) {
TOutM out = memberMethod(inNested, L0.getSupertypes(), mwt);
if (!out.isOk()) {
return out.toError();
}
newMwts.add((MethodWithType) out.toOkM().inner);
}
}
for (NestedClass nt : ns) {
TOutM out = memberNested(inNested, nt);
if (!out.isOk()) {
return out.toError();
}
newNs.add((NestedClass) out.toOkM().inner);
}
Phase maxPhase = L0.getPhase();
if (in.phase.subtypeEq(maxPhase)) {
maxPhase = in.phase;
}
ClassB L1 = new ClassB(L0.getDoc1(), L0.isInterface(), L0.getSupertypes(), newMwts, newNs, L0.getP(), maxPhase, L0.getUniqueId());
if (in.phase == Phase.Coherent) {
boolean isCoh = coherent(in.p.updateTop(L1), true);
if (!isCoh) {
return new TErr(in, "", Path.Library().toImmNT(), ErrorKind.LibraryNotCoherent);
}
}
// //or error not coherent set of abstr. methods:list
return new TOk(in, L1, Path.Library().toImmNT());
}
use of ast.ExpCore.ClassB in project L42 by ElvisResearchGroup.
the class ErrorFormatter method reportPlaceOfMetaError.
private static String reportPlaceOfMetaError(Program p, ErrorMessage msg) {
ErrorMessage.MalformedFinalResult _msg = (ErrorMessage.MalformedFinalResult) msg;
ClassB cb = _msg.getFinalRes();
//String path=_msg.getReason();
String path = reportPlaceOfMetaError(p, cb);
return path + "\n-----\n" + _msg.getReason();
}
use of ast.ExpCore.ClassB in project L42 by ElvisResearchGroup.
the class ErrorFormatter method whyIsNotExecutable.
private static String whyIsNotExecutable(ClassB cb) {
/*if(cb.getH() instanceof Ast.TraitHeader){
return "\n The requested path is a trait";
}*/
for (Member m : cb.getMs()) {
if (!(m instanceof MethodWithType)) {
continue;
}
/*MethodWithType mt=(MethodWithType)m;
if (!mt.getInner().isPresent() && !mt.isFieldGenerated()){
return "\n The method "+mt.getMs()+" of the requested path is abstract";
}*/
}
for (Member m : cb.getMs()) {
if (!(m instanceof NestedClass)) {
continue;
}
NestedClass nc = (NestedClass) m;
if (!(nc.getInner() instanceof ClassB)) {
return "\n The nested class " + nc.getName() + " of the requested path is not compiled yet";
}
String nestedRes = whyIsNotExecutable((ClassB) nc.getInner());
if (nestedRes != null) {
return "." + nc.getName() + nestedRes;
}
}
return null;
}
Aggregations