Skip to content

Commit

Permalink
Refactor allowed syntax checks for attributes
Browse files Browse the repository at this point in the history
  • Loading branch information
Scott-Guest committed Feb 20, 2024
1 parent 845bca1 commit aad6013
Show file tree
Hide file tree
Showing 2 changed files with 199 additions and 126 deletions.
15 changes: 8 additions & 7 deletions kernel/src/main/java/org/kframework/compile/checks/CheckAtt.java
Original file line number Diff line number Diff line change
Expand Up @@ -84,15 +84,16 @@ private <T extends HasAtt & HasLocation> void checkUnrecognizedAtts(T term) {
}

private <T extends HasAtt & HasLocation> void checkRestrictedAtts(T term) {
Class<?> cls = term.getClass();
Att att = term.att();
Set<Key> keys = stream(att.att().keySet()).map(Tuple2::_1).collect(Collectors.toSet());
keys.removeIf(k -> k.allowedSentences().exists(c -> c.isAssignableFrom(cls)));
if (!keys.isEmpty()) {
List<String> sortedKeys = keys.stream().map(Key::toString).sorted().toList();
Set<Key> badKeys =
stream(term.att().att().keySet())
.map(Tuple2::_1)
.filter(k -> k.visibility().isPermitted(term))
.collect(Collectors.toSet());
if (!badKeys.isEmpty()) {
List<String> sortedKeys = badKeys.stream().map(Key::toString).sorted().toList();
errors.add(
KEMException.compilerError(
cls.getSimpleName() + " cannot have the following attributes: " + sortedKeys, term));
"The following attributes are not permitted here: " + sortedKeys, term));
}
}

Expand Down
Loading

0 comments on commit aad6013

Please sign in to comment.