Merge branch 'master' into do-terminology-cache-filewpipechar
This commit is contained in:
commit
8e663f3ce9
|
@ -60,52 +60,52 @@ public class ExpansionProfile30_40 {
|
|||
if (src == null)
|
||||
return null;
|
||||
org.hl7.fhir.dstu3.model.ExpansionProfile tgt = new org.hl7.fhir.dstu3.model.ExpansionProfile();
|
||||
if (src.hasParameter("profile-url"))
|
||||
tgt.setUrl(src.getParameter("profile-url").primitiveValue());
|
||||
if (src.hasParameter("profile-version"))
|
||||
tgt.setVersion(src.getParameter("profile-version").primitiveValue());
|
||||
if (src.hasParameter("profile-name"))
|
||||
tgt.setName(src.getParameter("profile-name").primitiveValue());
|
||||
if (src.hasParameter("profile-status"))
|
||||
tgt.setStatus(PublicationStatus.fromCode(src.getParameter("profile-status").primitiveValue()));
|
||||
for (Type t : src.getParameters("system-version")) {
|
||||
if (src.hasParameterValue("profile-url"))
|
||||
tgt.setUrl(src.getParameterValue("profile-url").primitiveValue());
|
||||
if (src.hasParameterValue("profile-version"))
|
||||
tgt.setVersion(src.getParameterValue("profile-version").primitiveValue());
|
||||
if (src.hasParameterValue("profile-name"))
|
||||
tgt.setName(src.getParameterValue("profile-name").primitiveValue());
|
||||
if (src.hasParameterValue("profile-status"))
|
||||
tgt.setStatus(PublicationStatus.fromCode(src.getParameterValue("profile-status").primitiveValue()));
|
||||
for (Type t : src.getParameterValues("system-version")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.addFixedVersion().setSystem(v[0]).setVersion(v[1]).setMode(SystemVersionProcessingMode.DEFAULT);
|
||||
}
|
||||
for (Type t : src.getParameters("force-system-version")) {
|
||||
for (Type t : src.getParameterValues("force-system-version")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.addFixedVersion().setSystem(v[0]).setVersion(v[1]).setMode(SystemVersionProcessingMode.OVERRIDE);
|
||||
}
|
||||
for (Type t : src.getParameters("check-system-version")) {
|
||||
for (Type t : src.getParameterValues("check-system-version")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.addFixedVersion().setSystem(v[0]).setVersion(v[1]).setMode(SystemVersionProcessingMode.CHECK);
|
||||
}
|
||||
for (Type t : src.getParameters("exclude-system")) {
|
||||
for (Type t : src.getParameterValues("exclude-system")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.getExcludedSystem().setSystem(v[0]).setVersion(v[1]);
|
||||
}
|
||||
if (src.hasParameter("includeDesignations"))
|
||||
if (src.hasParameterValue("includeDesignations"))
|
||||
tgt.setIncludeDesignations(src.getParameterBool(""));
|
||||
for (Type t : src.getParameters("designation")) {
|
||||
for (Type t : src.getParameterValues("designation")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
if ("urn:ietf:bcp:47".equals(v[0]))
|
||||
tgt.getDesignation().getInclude().addDesignation().setLanguage(v[1]);
|
||||
else
|
||||
tgt.getDesignation().getInclude().addDesignation().getUse().setSystem(v[0]).setCode(v[1]);
|
||||
}
|
||||
if (src.hasParameter("includeDefinition"))
|
||||
if (src.hasParameterValue("includeDefinition"))
|
||||
tgt.setIncludeDefinition(src.getParameterBool("includeDefinition"));
|
||||
if (src.hasParameter("activeOnly"))
|
||||
if (src.hasParameterValue("activeOnly"))
|
||||
tgt.setActiveOnly(src.getParameterBool("activeOnly"));
|
||||
if (src.hasParameter("excludeNested"))
|
||||
if (src.hasParameterValue("excludeNested"))
|
||||
tgt.setExcludeNested(src.getParameterBool("excludeNested"));
|
||||
if (src.hasParameter("excludeNotForUI"))
|
||||
if (src.hasParameterValue("excludeNotForUI"))
|
||||
tgt.setExcludeNotForUI(src.getParameterBool("excludeNotForUI"));
|
||||
if (src.hasParameter("excludeNotForUI"))
|
||||
if (src.hasParameterValue("excludeNotForUI"))
|
||||
tgt.setExcludePostCoordinated(src.getParameterBool("excludeNotForUI"));
|
||||
if (src.hasParameter("displayLanguage"))
|
||||
tgt.setDisplayLanguage(src.getParameter("displayLanguage").primitiveValue());
|
||||
if (src.hasParameter("limitedExpansion"))
|
||||
if (src.hasParameterValue("displayLanguage"))
|
||||
tgt.setDisplayLanguage(src.getParameterValue("displayLanguage").primitiveValue());
|
||||
if (src.hasParameterValue("limitedExpansion"))
|
||||
tgt.setLimitedExpansion(src.getParameterBool("getParameterBool"));
|
||||
return tgt;
|
||||
}
|
||||
|
|
|
@ -214,7 +214,7 @@ public class Resource30_40 {
|
|||
public org.hl7.fhir.dstu3.model.Resource convertResource(org.hl7.fhir.r4.model.Resource src, BaseAdvisor_30_40 advisor) throws FHIRException {
|
||||
if (src == null) return null;
|
||||
if (src instanceof org.hl7.fhir.r4.model.Parameters) {
|
||||
if (((org.hl7.fhir.r4.model.Parameters) src).hasParameter("profile-url"))
|
||||
if (((org.hl7.fhir.r4.model.Parameters) src).hasParameterValue("profile-url"))
|
||||
return ExpansionProfile30_40.convertExpansionProfile((org.hl7.fhir.r4.model.Parameters) src);
|
||||
else return Parameters30_40.convertParameters((org.hl7.fhir.r4.model.Parameters) src);
|
||||
}
|
||||
|
|
|
@ -285,7 +285,7 @@ public class Resource30_50 {
|
|||
public org.hl7.fhir.dstu3.model.Resource convertResource(org.hl7.fhir.r5.model.Resource src) throws FHIRException {
|
||||
if (src == null) return null;
|
||||
if (src instanceof org.hl7.fhir.r5.model.Parameters) {
|
||||
if (((org.hl7.fhir.r5.model.Parameters) src).hasParameter("profile-url"))
|
||||
if (((org.hl7.fhir.r5.model.Parameters) src).hasParameterValue("profile-url"))
|
||||
return ExpansionProfile30_50.convertExpansionProfile((org.hl7.fhir.r5.model.Parameters) src);
|
||||
else return Parameters30_50.convertParameters((org.hl7.fhir.r5.model.Parameters) src);
|
||||
}
|
||||
|
|
|
@ -12,52 +12,52 @@ public class ExpansionProfile30_50 {
|
|||
if (src == null)
|
||||
return null;
|
||||
org.hl7.fhir.dstu3.model.ExpansionProfile tgt = new org.hl7.fhir.dstu3.model.ExpansionProfile();
|
||||
if (src.hasParameter("profile-url"))
|
||||
tgt.setUrl(src.getParameter("profile-url").primitiveValue());
|
||||
if (src.hasParameter("profile-version"))
|
||||
tgt.setVersion(src.getParameter("profile-version").primitiveValue());
|
||||
if (src.hasParameter("profile-name"))
|
||||
tgt.setName(src.getParameter("profile-name").primitiveValue());
|
||||
if (src.hasParameter("profile-status"))
|
||||
tgt.setStatus(PublicationStatus.fromCode(src.getParameter("profile-status").primitiveValue()));
|
||||
for (DataType t : src.getParameters("system-version")) {
|
||||
if (src.hasParameterValue("profile-url"))
|
||||
tgt.setUrl(src.getParameterValue("profile-url").primitiveValue());
|
||||
if (src.hasParameterValue("profile-version"))
|
||||
tgt.setVersion(src.getParameterValue("profile-version").primitiveValue());
|
||||
if (src.hasParameterValue("profile-name"))
|
||||
tgt.setName(src.getParameterValue("profile-name").primitiveValue());
|
||||
if (src.hasParameterValue("profile-status"))
|
||||
tgt.setStatus(PublicationStatus.fromCode(src.getParameterValue("profile-status").primitiveValue()));
|
||||
for (DataType t : src.getParameterValues("system-version")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.addFixedVersion().setSystem(v[0]).setVersion(v[1]).setMode(SystemVersionProcessingMode.DEFAULT);
|
||||
}
|
||||
for (DataType t : src.getParameters("force-system-version")) {
|
||||
for (DataType t : src.getParameterValues("force-system-version")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.addFixedVersion().setSystem(v[0]).setVersion(v[1]).setMode(SystemVersionProcessingMode.OVERRIDE);
|
||||
}
|
||||
for (DataType t : src.getParameters("check-system-version")) {
|
||||
for (DataType t : src.getParameterValues("check-system-version")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.addFixedVersion().setSystem(v[0]).setVersion(v[1]).setMode(SystemVersionProcessingMode.CHECK);
|
||||
}
|
||||
for (DataType t : src.getParameters("exclude-system")) {
|
||||
for (DataType t : src.getParameterValues("exclude-system")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
tgt.getExcludedSystem().setSystem(v[0]).setVersion(v[1]);
|
||||
}
|
||||
if (src.hasParameter("includeDesignations"))
|
||||
if (src.hasParameterValue("includeDesignations"))
|
||||
tgt.setIncludeDesignations(src.getParameterBool(""));
|
||||
for (DataType t : src.getParameters("designation")) {
|
||||
for (DataType t : src.getParameterValues("designation")) {
|
||||
String[] v = t.primitiveValue().split("\\|");
|
||||
if ("urn:ietf:bcp:47".equals(v[0]))
|
||||
tgt.getDesignation().getInclude().addDesignation().setLanguage(v[1]);
|
||||
else
|
||||
tgt.getDesignation().getInclude().addDesignation().getUse().setSystem(v[0]).setCode(v[1]);
|
||||
}
|
||||
if (src.hasParameter("includeDefinition"))
|
||||
if (src.hasParameterValue("includeDefinition"))
|
||||
tgt.setIncludeDefinition(src.getParameterBool("includeDefinition"));
|
||||
if (src.hasParameter("activeOnly"))
|
||||
if (src.hasParameterValue("activeOnly"))
|
||||
tgt.setActiveOnly(src.getParameterBool("activeOnly"));
|
||||
if (src.hasParameter("excludeNested"))
|
||||
if (src.hasParameterValue("excludeNested"))
|
||||
tgt.setExcludeNested(src.getParameterBool("excludeNested"));
|
||||
if (src.hasParameter("excludeNotForUI"))
|
||||
if (src.hasParameterValue("excludeNotForUI"))
|
||||
tgt.setExcludeNotForUI(src.getParameterBool("excludeNotForUI"));
|
||||
if (src.hasParameter("excludeNotForUI"))
|
||||
if (src.hasParameterValue("excludeNotForUI"))
|
||||
tgt.setExcludePostCoordinated(src.getParameterBool("excludeNotForUI"));
|
||||
if (src.hasParameter("displayLanguage"))
|
||||
tgt.setDisplayLanguage(src.getParameter("displayLanguage").primitiveValue());
|
||||
if (src.hasParameter("limitedExpansion"))
|
||||
if (src.hasParameterValue("displayLanguage"))
|
||||
tgt.setDisplayLanguage(src.getParameterValue("displayLanguage").primitiveValue());
|
||||
if (src.hasParameterValue("limitedExpansion"))
|
||||
tgt.setLimitedExpansion(src.getParameterBool("getParameterBool"));
|
||||
return tgt;
|
||||
}
|
||||
|
|
|
@ -877,6 +877,14 @@ public class Parameters extends Resource implements IBaseParameters {
|
|||
return this;
|
||||
}
|
||||
|
||||
public boolean hasParameterValue(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name) && p.hasValue())
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public boolean hasParameter(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
|
@ -885,7 +893,7 @@ public class Parameters extends Resource implements IBaseParameters {
|
|||
return false;
|
||||
}
|
||||
|
||||
public Type getParameter(String name) {
|
||||
public Type getParameterValue(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
return p.getValue();
|
||||
|
@ -893,7 +901,15 @@ public class Parameters extends Resource implements IBaseParameters {
|
|||
return null;
|
||||
}
|
||||
|
||||
public List<Type> getParameters(String name) {
|
||||
public ParametersParameterComponent getParameter(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
return p;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<Type> getParameterValues(String name) {
|
||||
List<Type> res = new ArrayList<Type>();
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
|
@ -902,7 +918,15 @@ public class Parameters extends Resource implements IBaseParameters {
|
|||
return res;
|
||||
}
|
||||
|
||||
|
||||
public List<ParametersParameterComponent> getParameters(String name) {
|
||||
List<ParametersParameterComponent> res = new ArrayList<ParametersParameterComponent>();
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
res.add(p);
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
public boolean getParameterBool(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name)) {
|
||||
|
|
|
@ -1667,6 +1667,14 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return this;
|
||||
}
|
||||
|
||||
public boolean hasParameterValue(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name) && p.hasValue())
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public boolean hasParameter(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
|
@ -1675,7 +1683,7 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return false;
|
||||
}
|
||||
|
||||
public DataType getParameter(String name) {
|
||||
public DataType getParameterValue(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
return p.getValue();
|
||||
|
@ -1683,7 +1691,15 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return null;
|
||||
}
|
||||
|
||||
public List<DataType> getParameters(String name) {
|
||||
public ParametersParameterComponent getParameter(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
return p;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<DataType> getParameterValues(String name) {
|
||||
List<DataType> res = new ArrayList<>();
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
|
@ -1692,6 +1708,15 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return res;
|
||||
}
|
||||
|
||||
public List<ParametersParameterComponent> getParameters(String name) {
|
||||
List<ParametersParameterComponent> res = new ArrayList<>();
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
res.add(p);
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
|
||||
public boolean getParameterBool(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
|
|
|
@ -1238,5 +1238,18 @@ public class Element extends Base {
|
|||
}
|
||||
return "e:"+e+",w:"+w+",h:"+h;
|
||||
}
|
||||
|
||||
public void populatePaths(String path) {
|
||||
if (path == null) {
|
||||
path = fhirType();
|
||||
}
|
||||
setPath(path);
|
||||
if (children != null) {
|
||||
for (Element n : children) {
|
||||
n.populatePaths(path+"."+n.getName());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -636,6 +636,10 @@ public class JsonParser extends ParserBase {
|
|||
|
||||
@Override
|
||||
public void compose(Element e, OutputStream stream, OutputStyle style, String identity) throws FHIRException, IOException {
|
||||
if (e.getPath() == null) {
|
||||
e.populatePaths(null);
|
||||
}
|
||||
|
||||
OutputStreamWriter osw = new OutputStreamWriter(stream, "UTF-8");
|
||||
if (style == OutputStyle.CANONICAL)
|
||||
json = new JsonCreatorCanonical(osw);
|
||||
|
@ -654,6 +658,10 @@ public class JsonParser extends ParserBase {
|
|||
}
|
||||
|
||||
public void compose(Element e, JsonCreator json) throws Exception {
|
||||
if (e.getPath() == null) {
|
||||
e.populatePaths(null);
|
||||
}
|
||||
|
||||
this.json = json;
|
||||
json.beginObject();
|
||||
|
||||
|
|
|
@ -315,6 +315,10 @@ public class TurtleParser extends ParserBase {
|
|||
|
||||
|
||||
public void compose(Element e, Turtle ttl, String base) throws FHIRException {
|
||||
if (e.getPath() == null) {
|
||||
e.populatePaths(null);
|
||||
}
|
||||
|
||||
ttl.prefix("fhir", FHIR_URI_BASE);
|
||||
ttl.prefix("rdfs", "http://www.w3.org/2000/01/rdf-schema#");
|
||||
ttl.prefix("owl", "http://www.w3.org/2002/07/owl#");
|
||||
|
|
|
@ -602,6 +602,9 @@ public class XmlParser extends ParserBase {
|
|||
xml.setSortAttributes(false);
|
||||
xml.setPretty(style == OutputStyle.PRETTY);
|
||||
xml.start();
|
||||
if (e.getPath() == null) {
|
||||
e.populatePaths(null);
|
||||
}
|
||||
String ns = e.getProperty().getXmlNamespace();
|
||||
if (ns!=null && !"noNamespace".equals(ns)) {
|
||||
xml.setDefaultNamespace(ns);
|
||||
|
@ -654,6 +657,9 @@ public class XmlParser extends ParserBase {
|
|||
}
|
||||
|
||||
public void compose(Element e, IXMLWriter xml) throws Exception {
|
||||
if (e.getPath() == null) {
|
||||
e.populatePaths(null);
|
||||
}
|
||||
xml.start();
|
||||
xml.setDefaultNamespace(e.getProperty().getXmlNamespace());
|
||||
if (schemaPath != null) {
|
||||
|
|
|
@ -39,6 +39,7 @@ import org.hl7.fhir.r5.model.Enumerations.*;
|
|||
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
|
||||
import org.hl7.fhir.exceptions.FHIRException;
|
||||
import org.hl7.fhir.instance.model.api.ICompositeType;
|
||||
|
||||
import ca.uhn.fhir.model.api.annotation.ResourceDef;
|
||||
import ca.uhn.fhir.model.api.annotation.SearchParamDefinition;
|
||||
import org.hl7.fhir.instance.model.api.IBaseBackboneElement;
|
||||
|
@ -1747,6 +1748,14 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return this;
|
||||
}
|
||||
|
||||
public boolean hasParameterValue(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name) && p.hasValue())
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public boolean hasParameter(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
|
@ -1755,7 +1764,7 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return false;
|
||||
}
|
||||
|
||||
public DataType getParameter(String name) {
|
||||
public DataType getParameterValue(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
return p.getValue();
|
||||
|
@ -1763,7 +1772,15 @@ public Parameters addParameter(String name, boolean b) {
|
|||
return null;
|
||||
}
|
||||
|
||||
public List<DataType> getParameters(String name) {
|
||||
public ParametersParameterComponent getParameter(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
return p;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<DataType> getParameterValues(String name) {
|
||||
List<DataType> res = new ArrayList<>();
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
|
@ -1771,7 +1788,15 @@ public Parameters addParameter(String name, boolean b) {
|
|||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
|
||||
public List<ParametersParameterComponent> getParameters(String name) {
|
||||
List<ParametersParameterComponent> res = new ArrayList<ParametersParameterComponent>();
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
if (p.getName().equals(name))
|
||||
res.add(p);
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
public boolean getParameterBool(String name) {
|
||||
for (ParametersParameterComponent p : getParameter()) {
|
||||
|
|
|
@ -15,6 +15,7 @@ import java.time.format.FormatStyle;
|
|||
import java.time.format.SignStyle;
|
||||
import java.util.Currency;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
import org.hl7.fhir.exceptions.DefinitionException;
|
||||
import org.hl7.fhir.exceptions.FHIRException;
|
||||
|
@ -97,6 +98,45 @@ public class DataRenderer extends Renderer {
|
|||
|
||||
// -- 2. Markdown support -------------------------------------------------------
|
||||
|
||||
public static String processRelativeUrls(String markdown, String path) {
|
||||
if (markdown == null) {
|
||||
return "";
|
||||
}
|
||||
if (!Utilities.isAbsoluteUrl(path)) {
|
||||
return markdown;
|
||||
}
|
||||
String basePath = path.contains("/") ? path.substring(0, path.lastIndexOf("/")+1) : path+"/";
|
||||
StringBuilder b = new StringBuilder();
|
||||
int i = 0;
|
||||
while (i < markdown.length()) {
|
||||
if (i < markdown.length()-3 && markdown.substring(i, i+2).equals("](")) {
|
||||
int j = i + 2;
|
||||
while (j < markdown.length() && markdown.charAt(j) != ')')
|
||||
j++;
|
||||
if (j < markdown.length()) {
|
||||
String url = markdown.substring(i+2, j);
|
||||
if (!Utilities.isAbsoluteUrl(url) && !url.startsWith("..")) {
|
||||
// it's relative - so it's relative to the base URL
|
||||
b.append("](");
|
||||
b.append(basePath);
|
||||
} else {
|
||||
b.append("](");
|
||||
}
|
||||
i = i + 1;
|
||||
} else
|
||||
b.append(markdown.charAt(i));
|
||||
} else {
|
||||
b.append(markdown.charAt(i));
|
||||
}
|
||||
i++;
|
||||
}
|
||||
return b.toString();
|
||||
}
|
||||
|
||||
protected void addMarkdown(XhtmlNode x, String text, String path) throws FHIRFormatError, IOException, DefinitionException {
|
||||
addMarkdown(x, processRelativeUrls(text, path));
|
||||
}
|
||||
|
||||
protected void addMarkdown(XhtmlNode x, String text) throws FHIRFormatError, IOException, DefinitionException {
|
||||
if (text != null) {
|
||||
// 1. custom FHIR extensions
|
||||
|
|
|
@ -68,6 +68,7 @@ import org.hl7.fhir.r5.renderers.utils.DirectWrappers;
|
|||
import org.hl7.fhir.r5.renderers.utils.DirectWrappers.BaseWrapperDirect;
|
||||
import org.hl7.fhir.r5.renderers.utils.DirectWrappers.PropertyWrapperDirect;
|
||||
import org.hl7.fhir.r5.renderers.utils.DirectWrappers.ResourceWrapperDirect;
|
||||
import org.hl7.fhir.r5.renderers.utils.ElementWrappers;
|
||||
import org.hl7.fhir.r5.renderers.utils.RenderingContext;
|
||||
import org.hl7.fhir.r5.renderers.utils.Resolver.ResourceContext;
|
||||
import org.hl7.fhir.r5.renderers.utils.Resolver.ResourceWithReference;
|
||||
|
@ -103,7 +104,7 @@ public class ProfileDrivenRenderer extends ResourceRenderer {
|
|||
boolean idDone = false;
|
||||
XhtmlNode p = x.para();
|
||||
if (context.isAddGeneratedNarrativeHeader()) {
|
||||
p.b().tx("Generated Narrative: "+r.fhirType());
|
||||
p.b().tx("Generated Narrative: "+r.fhirType()+(context.isContained() ? " #"+r.getId() : ""));
|
||||
if (!Utilities.noString(r.getId())) {
|
||||
p.an(r.getId());
|
||||
}
|
||||
|
@ -756,35 +757,50 @@ public class ProfileDrivenRenderer extends ResourceRenderer {
|
|||
if (children.isEmpty()) {
|
||||
renderLeaf(res, e, defn, x, x, false, showCodeDetails, readDisplayHints(defn), path, indent);
|
||||
} else {
|
||||
for (PropertyWrapper p : splitExtensions(profile, e.children())) {
|
||||
if (p.hasValues()) {
|
||||
ElementDefinition child = getElementDefinition(children, path+"."+p.getName(), p);
|
||||
if (child == null) {
|
||||
child = p.getElementDefinition();
|
||||
}
|
||||
if (child != null) {
|
||||
if (!child.getBase().hasPath() || !child.getBase().getPath().startsWith("Resource.")) {
|
||||
generateElementByProfile(res, profile, allElements, x, path, showCodeDetails, indent, p, child);
|
||||
}
|
||||
}
|
||||
List<PropertyWrapper> pl = splitExtensions(profile, e.children());
|
||||
for (PropertyWrapper p : pl) {
|
||||
generateForProperty(res, profile, allElements, children, x, path, showCodeDetails, indent, false, p);
|
||||
}
|
||||
for (PropertyWrapper p : pl) {
|
||||
generateForProperty(res, profile, allElements, children, x, path, showCodeDetails, indent, true, p);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void generateForProperty(ResourceWrapper res, StructureDefinition profile,
|
||||
List<ElementDefinition> allElements, List<ElementDefinition> children, XhtmlNode x, String path,
|
||||
boolean showCodeDetails, int indent, boolean round2, PropertyWrapper p)
|
||||
throws UnsupportedEncodingException, IOException, EOperationOutcome {
|
||||
if (p.hasValues()) {
|
||||
ElementDefinition child = getElementDefinition(children, path+"."+p.getName(), p);
|
||||
if (child == null) {
|
||||
child = p.getElementDefinition();
|
||||
}
|
||||
if (child != null) {
|
||||
if (!child.getBase().hasPath() || !child.getBase().getPath().startsWith("Resource.")) {
|
||||
generateElementByProfile(res, profile, allElements, x, path, showCodeDetails, indent, p, child, round2);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void generateElementByProfile(ResourceWrapper res, StructureDefinition profile, List<ElementDefinition> allElements, XhtmlNode x, String path,
|
||||
boolean showCodeDetails, int indent, PropertyWrapper p, ElementDefinition child) throws UnsupportedEncodingException, IOException, EOperationOutcome {
|
||||
boolean showCodeDetails, int indent, PropertyWrapper p, ElementDefinition child, boolean round2) throws UnsupportedEncodingException, IOException, EOperationOutcome {
|
||||
Map<String, String> displayHints = readDisplayHints(child);
|
||||
if ("DomainResource.contained".equals(child.getBase().getPath())) {
|
||||
// for (BaseWrapper v : p.getValues()) {
|
||||
// x.hr();
|
||||
// RenderingContext ctxt = context.clone();
|
||||
// ctxt.setContained(true);
|
||||
// ResourceRenderer rnd = RendererFactory.factory(v.fhirType(), ctxt);
|
||||
// ResourceWrapper rw = new ElementWrappers.ResourceWrapperMetaElement(ctxt, (org.hl7.fhir.r5.elementmodel.Element) v.getBase());
|
||||
// rnd.render(x.blockquote(), rw);
|
||||
// }
|
||||
} else if (!exemptFromRendering(child)) {
|
||||
if (round2) {
|
||||
for (BaseWrapper v : p.getValues()) {
|
||||
if (!RendererFactory.hasSpecificRenderer(v.fhirType())) {
|
||||
x.hr();
|
||||
RenderingContext ctxt = context.copy();
|
||||
ctxt.setContained(true);
|
||||
ResourceRenderer rnd = RendererFactory.factory(v.fhirType(), ctxt);
|
||||
ResourceWrapper rw = new ElementWrappers.ResourceWrapperMetaElement(ctxt, (org.hl7.fhir.r5.elementmodel.Element) v.getBase());
|
||||
rnd.render(x.blockquote(), rw);
|
||||
}
|
||||
}
|
||||
}
|
||||
} else if (!round2 && !exemptFromRendering(child)) {
|
||||
if (isExtension(p)) {
|
||||
hasExtensions = true;
|
||||
}
|
||||
|
@ -1004,7 +1020,7 @@ public class ProfileDrivenRenderer extends ResourceRenderer {
|
|||
PropertyWrapper pe = map.get(p.getName()+"["+url+"]");
|
||||
if (pe == null) {
|
||||
if (ed == null) {
|
||||
if (url.startsWith("http://hl7.org/fhir") && !url.startsWith("http://hl7.org/fhir/us")) {
|
||||
if (url != null && url.startsWith("http://hl7.org/fhir") && !url.startsWith("http://hl7.org/fhir/us")) {
|
||||
throw new DefinitionException("unknown extension "+url);
|
||||
}
|
||||
// System.out.println("unknown extension "+url);
|
||||
|
|
|
@ -769,7 +769,7 @@ public class ValueSetRenderer extends TerminologyRenderer {
|
|||
td = tr.td();
|
||||
if (cs != null) {
|
||||
String defn = CodeSystemUtilities.getCodeDefinition(cs, c.getCode());
|
||||
addMarkdown(td, defn);
|
||||
addMarkdown(td, defn, cs.getUserString("path"));
|
||||
}
|
||||
}
|
||||
for (String n : Utilities.sorted(properties.keySet())) {
|
||||
|
|
|
@ -98,7 +98,7 @@ public class Resolver {
|
|||
if (resource instanceof Bundle) {
|
||||
Bundle b = (Bundle) resource;
|
||||
for (BundleEntryComponent be : b.getEntry()) {
|
||||
if (be.getFullUrl().equals(value))
|
||||
if (be.hasFullUrl() && be.getFullUrl().equals(value))
|
||||
return be;
|
||||
if (value.equals(be.getResource().fhirType()+"/"+be.getResource().getId()))
|
||||
return be;
|
||||
|
|
|
@ -139,7 +139,9 @@ public class SimpleHTTPClient {
|
|||
u = new URL(url);
|
||||
c = (HttpURLConnection) u.openConnection();
|
||||
c.setRequestMethod("GET");
|
||||
c.setRequestProperty("Accept", accept);
|
||||
if (accept != null) {
|
||||
c.setRequestProperty("Accept", accept);
|
||||
}
|
||||
setHeaders(c);
|
||||
c.setInstanceFollowRedirects(false);
|
||||
if (trustAll && url.startsWith("https://")) {
|
||||
|
|
|
@ -6,6 +6,6 @@ public class CommonPackages {
|
|||
public static final String VER_XVER = "0.0.11";
|
||||
|
||||
public static final String ID_PUBPACK = "hl7.fhir.pubpack";
|
||||
public static final String VER_PUBPACK = "0.1.2";
|
||||
public static final String VER_PUBPACK = "0.1.3";
|
||||
|
||||
}
|
||||
|
|
|
@ -618,6 +618,7 @@ public class ValidationEngine implements IValidatorResourceFetcher, IValidationP
|
|||
if (map == null) throw new Error("Unable to find map " + mapUri + " (Known Maps = " + context.listMapUrls() + ")");
|
||||
org.hl7.fhir.r5.elementmodel.Element resource = getTargetResourceFromStructureMap(map);
|
||||
scu.transform(null, src, map, resource);
|
||||
resource.populatePaths(null);
|
||||
return resource;
|
||||
}
|
||||
|
||||
|
|
|
@ -385,6 +385,7 @@ public class ValidationService {
|
|||
for (String src : cliContext.getIgs()) {
|
||||
igLoader.loadIg(validator.getIgs(), validator.getBinaries(), src, cliContext.isRecursive());
|
||||
}
|
||||
System.out.println(" Package Summary: "+validator.getContext().loadedPackageSummary());
|
||||
System.out.print(" Get set... ");
|
||||
validator.setQuestionnaireMode(cliContext.getQuestionnaireMode());
|
||||
validator.setLevel(cliContext.getLevel());
|
||||
|
|
|
@ -2410,12 +2410,20 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
|
|||
DecimalStatus ds = Utilities.checkDecimal(e.primitiveValue(), true, false);
|
||||
if (rule(errors, IssueType.INVALID, e.line(), e.col(), path, ds == DecimalStatus.OK || ds == DecimalStatus.RANGE, I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_VALID, e.primitiveValue())) {
|
||||
warning(errors, IssueType.VALUE, e.line(), e.col(), path, ds != DecimalStatus.RANGE, I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_RANGE, e.primitiveValue());
|
||||
try {
|
||||
try {
|
||||
Decimal v = new Decimal(e.getValue());
|
||||
ok = rule(errors, IssueType.INVALID, e.line(), e.col(), path, !context.hasMaxValueIntegerType() ||
|
||||
!context.getMaxValueIntegerType().hasValue() || checkDecimalMaxValue(v, context.getMaxValueDecimalType().getValue()), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_GT, (context.hasMaxValueIntegerType() ? context.getMaxValueIntegerType() : "")) && ok;
|
||||
ok = rule(errors, IssueType.INVALID, e.line(), e.col(), path, !context.hasMinValueIntegerType() ||
|
||||
!context.getMinValueIntegerType().hasValue() || checkDecimalMinValue(v, context.getMaxValueDecimalType().getValue()), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_LT, (context.hasMinValueIntegerType() ? context.getMinValueIntegerType() : "")) && ok;
|
||||
if (context.hasMaxValueDecimalType() && context.getMaxValueDecimalType().hasValue()) {
|
||||
ok = rule(errors, IssueType.INVALID, e.line(), e.col(), path, checkDecimalMaxValue(v, context.getMaxValueDecimalType().getValue()), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_GT, context.getMaxValueDecimalType()) && ok;
|
||||
} else if (context.hasMaxValueIntegerType() && context.getMaxValueIntegerType().hasValue()) {
|
||||
// users can also provide a max integer type. It's not clear whether that's actually valid, but we'll check for it anyway
|
||||
ok = rule(errors, IssueType.INVALID, e.line(), e.col(), path, checkDecimalMaxValue(v, new BigDecimal(context.getMaxValueIntegerType().getValue())), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_GT, context.getMaxValueIntegerType()) && ok;
|
||||
}
|
||||
|
||||
if (context.hasMinValueDecimalType() && context.getMaxValueDecimalType().hasValue()) {
|
||||
ok = rule(errors, IssueType.INVALID, e.line(), e.col(), path, checkDecimalMinValue(v, context.getMaxValueDecimalType().getValue()), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_LT, context.getMaxValueDecimalType()) && ok;
|
||||
} else if (context.hasMinValueIntegerType() && context.getMaxValueIntegerType().hasValue()) {
|
||||
ok = rule(errors, IssueType.INVALID, e.line(), e.col(), path, checkDecimalMinValue(v, new BigDecimal(context.getMaxValueIntegerType().getValue())), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_DECIMAL_LT, context.getMaxValueIntegerType()) && ok;
|
||||
}
|
||||
} catch (Exception ex) {
|
||||
// should never happen?
|
||||
}
|
||||
|
|
|
@ -2162,3 +2162,14 @@ v: {
|
|||
"system" : "http://loinc.org"
|
||||
}
|
||||
-------------------------------------------------------------------------------------
|
||||
{"code" : {
|
||||
"system" : "http://loinc.org",
|
||||
"code" : "57024-2",
|
||||
"display" : "Health Quality Measure Document"
|
||||
}, "valueSet" :null, "lang":"null", "useServer":"true", "useClient":"true", "guessSystem":"false", "valueSetMode":"ALL_CHECKS", "versionFlexible":"false"}####
|
||||
v: {
|
||||
"display" : "Health Quality Measure document",
|
||||
"code" : "57024-2",
|
||||
"system" : "http://loinc.org"
|
||||
}
|
||||
-------------------------------------------------------------------------------------
|
||||
|
|
|
@ -2056,3 +2056,25 @@ v: {
|
|||
"system" : "http://snomed.info/sct"
|
||||
}
|
||||
-------------------------------------------------------------------------------------
|
||||
{"code" : {
|
||||
"system" : "http://snomed.info/sct",
|
||||
"code" : "116288000",
|
||||
"display" : "Paralytic stroke (disorder)"
|
||||
}, "valueSet" :null, "lang":"null", "useServer":"true", "useClient":"true", "guessSystem":"false", "valueSetMode":"ALL_CHECKS", "versionFlexible":"false"}####
|
||||
v: {
|
||||
"display" : "Paralytic stroke",
|
||||
"code" : "116288000",
|
||||
"system" : "http://snomed.info/sct"
|
||||
}
|
||||
-------------------------------------------------------------------------------------
|
||||
{"code" : {
|
||||
"system" : "http://snomed.info/sct",
|
||||
"code" : "324689003",
|
||||
"display" : "Nystatin 100000 unit/mL oral suspension"
|
||||
}, "valueSet" :null, "lang":"null", "useServer":"true", "useClient":"true", "guessSystem":"false", "valueSetMode":"ALL_CHECKS", "versionFlexible":"false"}####
|
||||
v: {
|
||||
"display" : "Product containing precisely nystatin 100000 unit/1 milliliter conventional release oral suspension (clinical drug)",
|
||||
"code" : "324689003",
|
||||
"system" : "http://snomed.info/sct"
|
||||
}
|
||||
-------------------------------------------------------------------------------------
|
||||
|
|
Loading…
Reference in New Issue