Merge pull request #532 from hapifhir/gg-202106-r2b-exists

Lloyd's changes to R2B import
This commit is contained in:
Grahame Grieve 2021-06-05 09:07:19 +10:00 committed by GitHub
commit 9cf9b27bbd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 56 additions and 4 deletions

View File

@ -1,5 +1,6 @@
package org.hl7.fhir.convertors; package org.hl7.fhir.convertors;
import org.apache.commons.lang3.StringUtils;
import org.hl7.fhir.convertors.advisors.impl.BaseAdvisor_14_40; import org.hl7.fhir.convertors.advisors.impl.BaseAdvisor_14_40;
import org.hl7.fhir.convertors.conv14_40.*; import org.hl7.fhir.convertors.conv14_40.*;
import org.hl7.fhir.dstu2016may.model.CodeableConcept; import org.hl7.fhir.dstu2016may.model.CodeableConcept;
@ -1366,6 +1367,22 @@ public class VersionConvertor_14_40 extends VersionConvertor_Base {
return tgt; return tgt;
} }
/*
* This process deals with the fact that 'exists' slicing didn't have a mechanism to flag it in 2016May.
* (Pattern and profile both had '@' flags in the discriminator to distinguish this, but exists did not.)
* 'Exists' can thus only be determined by looking at the available slices - and checking to see that there
* are exactly two slices, one which is mandatory and one which is prohibited. We need to do that check
* at the level where the slices are defined, rather than only inside the 'slicing' element where we don't
* have access to the slices themselves.
*
* This process checks to see if we have a 'value' discriminator (i.e. no '@') and if so, checks for all
* matching slices. If there are exactly two and one's required and one's prohibited, then it sets a flag
* so that the converter will declare a discriminator.type of 'exists'.
*
* Note that we only need complex processing on the R2B -> newer release, not on the reverse. On the reverse,
* we just strip the discriminator type. What slices exist is still the same. In theory, that means that the
* exists type is unnecessary, but it's far more efficient (and clear) to have it.
*/
public static org.hl7.fhir.r4.model.ElementDefinition.ElementDefinitionSlicingComponent convertElementDefinitionSlicingComponent(org.hl7.fhir.dstu2016may.model.ElementDefinition.ElementDefinitionSlicingComponent src, List<org.hl7.fhir.dstu2016may.model.ElementDefinition> context, int pos) throws FHIRException { public static org.hl7.fhir.r4.model.ElementDefinition.ElementDefinitionSlicingComponent convertElementDefinitionSlicingComponent(org.hl7.fhir.dstu2016may.model.ElementDefinition.ElementDefinitionSlicingComponent src, List<org.hl7.fhir.dstu2016may.model.ElementDefinition> context, int pos) throws FHIRException {
if (src == null || src.isEmpty()) return null; if (src == null || src.isEmpty()) return null;
org.hl7.fhir.r4.model.ElementDefinition.ElementDefinitionSlicingComponent tgt = new org.hl7.fhir.r4.model.ElementDefinition.ElementDefinitionSlicingComponent(); org.hl7.fhir.r4.model.ElementDefinition.ElementDefinitionSlicingComponent tgt = new org.hl7.fhir.r4.model.ElementDefinition.ElementDefinitionSlicingComponent();
@ -1377,14 +1394,23 @@ public class VersionConvertor_14_40 extends VersionConvertor_Base {
int slices = 0; int slices = 0;
boolean existsSlicePresent = false; boolean existsSlicePresent = false;
boolean notExistsSlicePresent = false; boolean notExistsSlicePresent = false;
String url = null;
String existsPath = slicingElement.getPath() + "." + t.asStringValue(); String existsPath = slicingElement.getPath() + "." + t.asStringValue();
if (existsPath.contains(".extension(")) {
String suffix = StringUtils.substringAfter(existsPath,"(").substring(1);
existsPath = StringUtils.substringBefore(existsPath,"(");
suffix = StringUtils.substringBefore(suffix, ")");
url = suffix.substring(0,suffix.length()-1);
}
for (int i = pos + 1; i < context.size(); i++) { for (int i = pos + 1; i < context.size(); i++) {
org.hl7.fhir.dstu2016may.model.ElementDefinition e = context.get(i); org.hl7.fhir.dstu2016may.model.ElementDefinition e = context.get(i);
if (e.getPath().equals(slicingElement.getPath())) slices++; if (e.getPath().equals(slicingElement.getPath())) slices++;
else if (!e.getPath().startsWith(slicingElement.getPath() + ".")) break; else if (!e.getPath().startsWith(slicingElement.getPath() + ".")) break;
else if (e.getPath().equals(existsPath)) { else if (e.getPath().equals(existsPath)) {
if (e.hasMin() && e.getMin() > 0 && !e.hasFixed()) existsSlicePresent = true; if (url==null || (e.getType().get(0).hasProfile() && e.getType().get(0).getProfile().get(0).equals(url))) {
else if (e.hasMax() && e.getMax().equals("0")) notExistsSlicePresent = true; if (e.hasMin() && e.getMin() > 0 && !e.hasFixed()) existsSlicePresent = true;
else if (e.hasMax() && e.getMax().equals("0")) notExistsSlicePresent = true;
}
} }
} }
isExists = (slices == 2 && existsSlicePresent && notExistsSlicePresent) || (slices == 1 && existsSlicePresent != notExistsSlicePresent); isExists = (slices == 2 && existsSlicePresent && notExistsSlicePresent) || (slices == 1 && existsSlicePresent != notExistsSlicePresent);

View File

@ -1,5 +1,6 @@
package org.hl7.fhir.convertors; package org.hl7.fhir.convertors;
import org.apache.commons.lang3.StringUtils;
import org.hl7.fhir.convertors.advisors.impl.BaseAdvisor_14_50; import org.hl7.fhir.convertors.advisors.impl.BaseAdvisor_14_50;
import org.hl7.fhir.convertors.conv14_50.*; import org.hl7.fhir.convertors.conv14_50.*;
import org.hl7.fhir.dstu2016may.model.CodeableConcept; import org.hl7.fhir.dstu2016may.model.CodeableConcept;
@ -1394,6 +1395,22 @@ public class VersionConvertor_14_50 extends VersionConvertor_Base {
return tgt; return tgt;
} }
/*
* This process deals with the fact that 'exists' slicing didn't have a mechanism to flag it in 2016May.
* (Pattern and profile both had '@' flags in the discriminator to distinguish this, but exists did not.)
* 'Exists' can thus only be determined by looking at the available slices - and checking to see that there
* are exactly two slices, one which is mandatory and one which is prohibited. We need to do that check
* at the level where the slices are defined, rather than only inside the 'slicing' element where we don't
* have access to the slices themselves.
*
* This process checks to see if we have a 'value' discriminator (i.e. no '@') and if so, checks for all
* matching slices. If there are exactly two and one's required and one's prohibited, then it sets a flag
* so that the converter will declare a discriminator.type of 'exists'.
*
* Note that we only need complex processing on the R2B -> newer release, not on the reverse. On the reverse,
* we just strip the discriminator type. What slices exist is still the same. In theory, that means that the
* exists type is unnecessary, but it's far more efficient (and clear) to have it.
*/
public static org.hl7.fhir.r5.model.ElementDefinition.ElementDefinitionSlicingComponent convertElementDefinitionSlicingComponent(org.hl7.fhir.dstu2016may.model.ElementDefinition.ElementDefinitionSlicingComponent src, List<org.hl7.fhir.dstu2016may.model.ElementDefinition> context, int pos) throws FHIRException { public static org.hl7.fhir.r5.model.ElementDefinition.ElementDefinitionSlicingComponent convertElementDefinitionSlicingComponent(org.hl7.fhir.dstu2016may.model.ElementDefinition.ElementDefinitionSlicingComponent src, List<org.hl7.fhir.dstu2016may.model.ElementDefinition> context, int pos) throws FHIRException {
if (src == null || src.isEmpty()) return null; if (src == null || src.isEmpty()) return null;
org.hl7.fhir.r5.model.ElementDefinition.ElementDefinitionSlicingComponent tgt = new org.hl7.fhir.r5.model.ElementDefinition.ElementDefinitionSlicingComponent(); org.hl7.fhir.r5.model.ElementDefinition.ElementDefinitionSlicingComponent tgt = new org.hl7.fhir.r5.model.ElementDefinition.ElementDefinitionSlicingComponent();
@ -1405,14 +1422,23 @@ public class VersionConvertor_14_50 extends VersionConvertor_Base {
int slices = 0; int slices = 0;
boolean existsSlicePresent = false; boolean existsSlicePresent = false;
boolean notExistsSlicePresent = false; boolean notExistsSlicePresent = false;
String url = null;
String existsPath = slicingElement.getPath() + "." + t.asStringValue(); String existsPath = slicingElement.getPath() + "." + t.asStringValue();
if (existsPath.contains(".extension(")) {
String suffix = StringUtils.substringAfter(existsPath,"(").substring(1);
existsPath = StringUtils.substringBefore(existsPath,"(");
suffix = StringUtils.substringBefore(suffix, ")");
url = suffix.substring(0,suffix.length()-1);
}
for (int i = pos + 1; i < context.size(); i++) { for (int i = pos + 1; i < context.size(); i++) {
org.hl7.fhir.dstu2016may.model.ElementDefinition e = context.get(i); org.hl7.fhir.dstu2016may.model.ElementDefinition e = context.get(i);
if (e.getPath().equals(slicingElement.getPath())) slices++; if (e.getPath().equals(slicingElement.getPath())) slices++;
else if (!e.getPath().startsWith(slicingElement.getPath() + ".")) break; else if (!e.getPath().startsWith(slicingElement.getPath() + ".")) break;
else if (e.getPath().equals(existsPath)) { else if (e.getPath().equals(existsPath)) {
if (e.hasMin() && e.getMin() > 0 && !e.hasFixed()) existsSlicePresent = true; if (url==null || (e.getType().get(0).hasProfile() && e.getType().get(0).getProfile().get(0).equals(url))) {
else if (e.hasMax() && e.getMax().equals("0")) notExistsSlicePresent = true; if (e.hasMin() && e.getMin() > 0 && !e.hasFixed()) existsSlicePresent = true;
else if (e.hasMax() && e.getMax().equals("0")) notExistsSlicePresent = true;
}
} }
} }
isExists = (slices == 2 && existsSlicePresent && notExistsSlicePresent) || (slices == 1 && existsSlicePresent != notExistsSlicePresent); isExists = (slices == 2 && existsSlicePresent && notExistsSlicePresent) || (slices == 1 && existsSlicePresent != notExistsSlicePresent);