This commit is contained in:
Grahame Grieve 2019-04-24 06:18:11 +10:00
commit 203de627f1
11 changed files with 52 additions and 41 deletions

View File

@ -218,7 +218,9 @@ public class InstantType extends BaseDateTimeType {
@Override @Override
public InstantType copy() { public InstantType copy() {
return new InstantType(getValue()); InstantType ret = new InstantType();
ret.setValueAsString(getValueAsString());
return ret;
} }
/** /**

View File

@ -218,7 +218,9 @@ public class InstantType extends BaseDateTimeType {
@Override @Override
public InstantType copy() { public InstantType copy() {
return new InstantType(getValueAsString()); InstantType ret = new InstantType();
ret.setValueAsString(getValueAsString());
return ret;
} }
/** /**

View File

@ -218,7 +218,8 @@ public class InstantType extends BaseDateTimeType {
@Override @Override
public InstantType copy() { public InstantType copy() {
InstantType ret = new InstantType(getValueAsString()); InstantType ret = new InstantType();
ret.setValueAsString(getValueAsString());
copyValues(ret); copyValues(ret);
return ret; return ret;
} }

View File

@ -686,8 +686,9 @@ public class ResourceFactory extends Factory {
case 116076: return new UriType(); case 116076: return new UriType();
case 116079: return new UrlType(); case 116079: return new UrlType();
case 3601339: return new UuidType(); case 3601339: return new UuidType();
case 114035747: return new XhtmlType();
default: default:
throw new FHIRException("Unknown Resource or Type Name '"+name+"'"); throw new FHIRException("Unknown Resource or Type Name '"+name+"': " + name.hashCode());
} }
} }

View File

@ -39,6 +39,7 @@ public class XhtmlType extends Element {
} }
public XhtmlType() { public XhtmlType() {
this(new Narrative());
// "<div xmlns=\""+FormatUtilities.XHTML_NS+"\"></div>" // "<div xmlns=\""+FormatUtilities.XHTML_NS+"\"></div>"
} }

View File

@ -218,7 +218,8 @@ public class InstantType extends BaseDateTimeType {
@Override @Override
public InstantType copy() { public InstantType copy() {
InstantType ret = new InstantType(getValueAsString()); InstantType ret = new InstantType();
ret.setValueAsString(getValueAsString());
copyValues(ret); copyValues(ret);
return ret; return ret;
} }

View File

@ -85,6 +85,13 @@
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-compress</artifactId>
<version>1.18</version>
<scope>test</scope>
</dependency>
</dependencies> </dependencies>
<build> <build>

View File

@ -149,16 +149,22 @@ public class DefaultEnableWhenEvaluator implements IEnableWhenEvaluator {
} }
/**
* Recursively look for answers to questions with the given link id
*/
private List<Element> findQuestionAnswers(Element questionnaireResponse, String question) { private List<Element> findQuestionAnswers(Element questionnaireResponse, String question) {
List<Element> matchingItems = questionnaireResponse.getChildren(ITEM_ELEMENT) List<Element> retVal = new ArrayList<>();
.stream()
.flatMap(i -> findSubItems(i).stream()) List<Element> items = questionnaireResponse.getChildren(ITEM_ELEMENT);
.filter(i -> hasLinkId(i, question)) for (Element next : items) {
.collect(Collectors.toList()); if (hasLinkId(next, question)) {
return matchingItems List<Element> answers = extractAnswer(next);
.stream() retVal.addAll(answers);
.flatMap(e -> extractAnswer(e).stream()) }
.collect(Collectors.toList()); retVal.addAll(findQuestionAnswers(next, question));
}
return retVal;
} }
private List<Element> extractAnswer(Element item) { private List<Element> extractAnswer(Element item) {
@ -197,14 +203,6 @@ public class DefaultEnableWhenEvaluator implements IEnableWhenEvaluator {
} }
return true; return true;
} }
private List<Element> findSubItems(Element item) {
List<Element> results = item.getChildren(LINKID_ELEMENT)
.stream()
.flatMap(i -> findSubItems(i).stream())
.collect(Collectors.toList());
results.add(item);
return results;
}
private boolean hasLinkId(Element item, String linkId) { private boolean hasLinkId(Element item, String linkId) {
Element linkIdChild = item.getNamedChild(LINKID_ELEMENT); Element linkIdChild = item.getNamedChild(LINKID_ELEMENT);

View File

@ -2162,7 +2162,7 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
long t = System.nanoTime(); long t = System.nanoTime();
StructureDefinition sd = context.fetchResource(StructureDefinition.class, url); StructureDefinition sd = context.fetchResource(StructureDefinition.class, url);
sdTime = sdTime + (System.nanoTime() - t); sdTime = sdTime + (System.nanoTime() - t);
if (sd != null && (sd.getType().equals(type) || sd.getUrl().equals(type)) && sd.hasSnapshot()) if (sd != null && (sd.getType().equals(type) || sd.getUrl().equals("http://hl7.org/fhir/StructureDefinition/" + type)) && sd.hasSnapshot())
return sd; return sd;
} }
return null; return null;

View File

@ -149,16 +149,22 @@ public class DefaultEnableWhenEvaluator implements IEnableWhenEvaluator {
} }
/**
* Recursively look for answers to questions with the given link id
*/
private List<Element> findQuestionAnswers(Element questionnaireResponse, String question) { private List<Element> findQuestionAnswers(Element questionnaireResponse, String question) {
List<Element> matchingItems = questionnaireResponse.getChildren(ITEM_ELEMENT) List<Element> retVal = new ArrayList<>();
.stream()
.flatMap(i -> findSubItems(i).stream()) List<Element> items = questionnaireResponse.getChildren(ITEM_ELEMENT);
.filter(i -> hasLinkId(i, question)) for (Element next : items) {
.collect(Collectors.toList()); if (hasLinkId(next, question)) {
return matchingItems List<Element> answers = extractAnswer(next);
.stream() retVal.addAll(answers);
.flatMap(e -> extractAnswer(e).stream()) }
.collect(Collectors.toList()); retVal.addAll(findQuestionAnswers(next, question));
}
return retVal;
} }
private List<Element> extractAnswer(Element item) { private List<Element> extractAnswer(Element item) {
@ -197,14 +203,6 @@ public class DefaultEnableWhenEvaluator implements IEnableWhenEvaluator {
} }
return true; return true;
} }
private List<Element> findSubItems(Element item) {
List<Element> results = item.getChildren(ITEM_ELEMENT)
.stream()
.flatMap(i -> findSubItems(i).stream())
.collect(Collectors.toList());
results.add(item);
return results;
}
private boolean hasLinkId(Element item, String linkId) { private boolean hasLinkId(Element item, String linkId) {
Element linkIdChild = item.getNamedChild(LINKID_ELEMENT); Element linkIdChild = item.getNamedChild(LINKID_ELEMENT);

View File

@ -2172,7 +2172,7 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
long t = System.nanoTime(); long t = System.nanoTime();
StructureDefinition sd = context.fetchResource(StructureDefinition.class, url); StructureDefinition sd = context.fetchResource(StructureDefinition.class, url);
sdTime = sdTime + (System.nanoTime() - t); sdTime = sdTime + (System.nanoTime() - t);
if (sd != null && (sd.getType().equals(type) || sd.getUrl().equals(type)) && sd.hasSnapshot()) if (sd != null && (sd.getType().equals(type) || sd.getUrl().equals("http://hl7.org/fhir/StructureDefinition/" + type)) && sd.hasSnapshot())
return sd; return sd;
} }
return null; return null;