fix bug evaluating implicit type + fix primitive type pattern implementation

This commit is contained in:
Grahame Grieve 2020-07-14 08:21:37 +10:00
parent 64d6f24d08
commit 0adc1ae698
1 changed files with 19 additions and 1 deletions

View File

@ -109,6 +109,7 @@ import org.hl7.fhir.r5.model.ImplementationGuide.ImplementationGuideGlobalCompon
import org.hl7.fhir.r5.model.InstantType; import org.hl7.fhir.r5.model.InstantType;
import org.hl7.fhir.r5.model.IntegerType; import org.hl7.fhir.r5.model.IntegerType;
import org.hl7.fhir.r5.model.Period; import org.hl7.fhir.r5.model.Period;
import org.hl7.fhir.r5.model.PrimitiveType;
import org.hl7.fhir.r5.model.Quantity; import org.hl7.fhir.r5.model.Quantity;
import org.hl7.fhir.r5.model.Range; import org.hl7.fhir.r5.model.Range;
import org.hl7.fhir.r5.model.Ratio; import org.hl7.fhir.r5.model.Ratio;
@ -2473,7 +2474,7 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
} }
StructureDefinition sdF = sdFT; StructureDefinition sdF = sdFT;
while (sdF != null) { while (sdF != null) {
if (sdF == sd) { if (sdF.getType().equals(sd.getType())) {
ok = true; ok = true;
break; break;
} }
@ -3242,6 +3243,12 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
Coding c = (Coding) pattern; Coding c = (Coding) pattern;
expression.append(" and "); expression.append(" and ");
buildCodingExpression(ed, expression, discriminator, c); buildCodingExpression(ed, expression, discriminator, c);
} else if (pattern instanceof BooleanType || pattern instanceof IntegerType || pattern instanceof DecimalType) {
expression.append(" and ");
buildPrimitiveExpression(ed, expression, discriminator, pattern, false);
} else if (pattern instanceof PrimitiveType) {
expression.append(" and ");
buildPrimitiveExpression(ed, expression, discriminator, pattern, true);
} else if (pattern instanceof Identifier) { } else if (pattern instanceof Identifier) {
Identifier ii = (Identifier) pattern; Identifier ii = (Identifier) pattern;
expression.append(" and "); expression.append(" and ");
@ -3352,6 +3359,17 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
expression.append(").exists()"); expression.append(").exists()");
} }
private void buildPrimitiveExpression(ElementDefinition ed, StringBuilder expression, String discriminator, DataType p, boolean quotes) throws DefinitionException {
if (p.hasExtension())
throw new DefinitionException(context.formatMessage(I18nConstants.UNSUPPORTED_CODEABLECONCEPT_PATTERN__EXTENSIONS_ARE_NOT_ALLOWED__FOR_DISCRIMINATOR_FOR_SLICE_, discriminator, ed.getId()));
if (quotes) {
expression.append(discriminator + ".where(value = '" + p.primitiveValue() + "'");
} else {
expression.append(discriminator + ".where(value = " + p.primitiveValue() + "");
}
expression.append(").exists()");
}
private void buildFixedExpression(ElementDefinition ed, StringBuilder expression, String discriminator, ElementDefinition criteriaElement) throws DefinitionException { private void buildFixedExpression(ElementDefinition ed, StringBuilder expression, String discriminator, ElementDefinition criteriaElement) throws DefinitionException {
DataType fixed = criteriaElement.getFixed(); DataType fixed = criteriaElement.getFixed();
if (fixed instanceof CodeableConcept) { if (fixed instanceof CodeableConcept) {