fix problems with logical models and type definitions on the root

This commit is contained in:
Grahame Grieve 2021-06-25 17:39:16 +10:00
parent 3e050853e4
commit 4ccefc41c2
1 changed files with 15 additions and 9 deletions

View File

@ -662,7 +662,7 @@ public class ProfileUtilities extends TranslatingUtilities {
} }
} }
if (!derived.getSnapshot().getElementFirstRep().getType().isEmpty()) if (derived.getKind() != StructureDefinitionKind.LOGICAL && !derived.getSnapshot().getElementFirstRep().getType().isEmpty())
throw new Error(context.formatMessage(I18nConstants.TYPE_ON_FIRST_SNAPSHOT_ELEMENT_FOR__IN__FROM_, derived.getSnapshot().getElementFirstRep().getPath(), derived.getUrl(), base.getUrl())); throw new Error(context.formatMessage(I18nConstants.TYPE_ON_FIRST_SNAPSHOT_ELEMENT_FOR__IN__FROM_, derived.getSnapshot().getElementFirstRep().getPath(), derived.getUrl(), base.getUrl()));
updateMaps(base, derived); updateMaps(base, derived);
@ -785,7 +785,7 @@ public class ProfileUtilities extends TranslatingUtilities {
if (derived.hasDifferential() && !derived.getDifferential().getElementFirstRep().getPath().contains(".") && !derived.getDifferential().getElementFirstRep().getType().isEmpty()) { if (derived.hasDifferential() && !derived.getDifferential().getElementFirstRep().getPath().contains(".") && !derived.getDifferential().getElementFirstRep().getType().isEmpty()) {
if (wantFixDifferentialFirstElementType && typeMatchesAncestor(derived.getDifferential().getElementFirstRep().getType(), derived.getBaseDefinition())) { if (wantFixDifferentialFirstElementType && typeMatchesAncestor(derived.getDifferential().getElementFirstRep().getType(), derived.getBaseDefinition())) {
derived.getDifferential().getElementFirstRep().getType().clear(); derived.getDifferential().getElementFirstRep().getType().clear();
} else { } else if (derived.getKind() != StructureDefinitionKind.LOGICAL) {
throw new Error(context.formatMessage(I18nConstants.TYPE_ON_FIRST_DIFFERENTIAL_ELEMENT)); throw new Error(context.formatMessage(I18nConstants.TYPE_ON_FIRST_DIFFERENTIAL_ELEMENT));
} }
} }
@ -3004,10 +3004,10 @@ public class ProfileUtilities extends TranslatingUtilities {
} }
} }
if (dest.hasFixed()) { if (dest.hasFixed()) {
checkTypeOk(dest, dest.getFixed().fhirType()); checkTypeOk(dest, dest.getFixed().fhirType(), srcSD);
} }
if (dest.hasPattern()) { if (dest.hasPattern()) {
checkTypeOk(dest, dest.getPattern().fhirType()); checkTypeOk(dest, dest.getPattern().fhirType(), srcSD);
} }
} }
@ -3072,14 +3072,20 @@ public class ProfileUtilities extends TranslatingUtilities {
} }
public void checkTypeOk(ElementDefinition dest, String ft) { public void checkTypeOk(ElementDefinition dest, String ft, StructureDefinition sd) {
boolean ok = false; boolean ok = false;
Set<String> types = new HashSet<>(); Set<String> types = new HashSet<>();
for (TypeRefComponent t : dest.getType()) { if (dest.getPath().contains(".")) {
if (t.hasCode()) { for (TypeRefComponent t : dest.getType()) {
types.add(t.getWorkingCode()); if (t.hasCode()) {
types.add(t.getWorkingCode());
}
ok = ft.equals(t.getWorkingCode());
} }
ok = ft.equals(t.getWorkingCode()); } else {
types.add(sd.getType());
ok = ft.equals(sd.getType());
} }
if (!ok) { if (!ok) {
messages.add(new ValidationMessage(Source.InstanceValidator, IssueType.CONFLICT, dest.getId(), "The fixed value has type '"+ft+"' which is not valid (valid "+Utilities.pluralize("type", dest.getType().size())+": "+types.toString()+")", IssueSeverity.ERROR)); messages.add(new ValidationMessage(Source.InstanceValidator, IssueType.CONFLICT, dest.getId(), "The fixed value has type '"+ft+"' which is not valid (valid "+Utilities.pluralize("type", dest.getType().size())+": "+types.toString()+")", IssueSeverity.ERROR));