add support for integer64

This commit is contained in:
Grahame Grieve 2019-12-07 06:54:16 +11:00
parent 89195efad3
commit 0cbb586dd1
16 changed files with 341 additions and 8 deletions

View File

@ -10410,7 +10410,7 @@ public class VersionConvertor_10_50 {
return null;
switch (src) {
case DATATYPE:
if (Utilities.existsInList(dtName, "boolean", "integer", "decimal", "base64Binary", "instant", "string", "uri", "date", "dateTime", "time", "code", "oid", "uuid", "id", "unsignedInt", "positiveInt", "markdown", "xhtml", "url", "canonical"))
if (Utilities.existsInList(dtName, "boolean", "integer", "integer64", "decimal", "base64Binary", "instant", "string", "uri", "date", "dateTime", "time", "code", "oid", "uuid", "id", "unsignedInt", "positiveInt", "markdown", "xhtml", "url", "canonical"))
return org.hl7.fhir.r5.model.StructureDefinition.StructureDefinitionKind.PRIMITIVETYPE;
else
return org.hl7.fhir.r5.model.StructureDefinition.StructureDefinitionKind.COMPLEXTYPE;

View File

@ -249,6 +249,12 @@ public class VersionConvertor_30_50 {
return tgt;
}
public static org.hl7.fhir.dstu3.model.DecimalType convertInteger64(org.hl7.fhir.r5.model.Integer64Type src) throws FHIRException {
org.hl7.fhir.dstu3.model.DecimalType tgt = new org.hl7.fhir.dstu3.model.DecimalType(src.getValue().toString());
copyElement(src, tgt);
return tgt;
}
public static org.hl7.fhir.r5.model.MarkdownType convertMarkdown(org.hl7.fhir.dstu3.model.MarkdownType src) throws FHIRException {
org.hl7.fhir.r5.model.MarkdownType tgt = new org.hl7.fhir.r5.model.MarkdownType(src.getValue());
copyElement(src, tgt);
@ -2838,6 +2844,8 @@ public class VersionConvertor_30_50 {
return convertInstant((org.hl7.fhir.r5.model.InstantType) src);
if (src instanceof org.hl7.fhir.r5.model.IntegerType)
return convertInteger((org.hl7.fhir.r5.model.IntegerType) src);
if (src instanceof org.hl7.fhir.r5.model.Integer64Type)
return convertInteger64((org.hl7.fhir.r5.model.Integer64Type) src);
if (src instanceof org.hl7.fhir.r5.model.MarkdownType)
return convertMarkdown((org.hl7.fhir.r5.model.MarkdownType) src);
if (src instanceof org.hl7.fhir.r5.model.OidType)

View File

@ -3736,7 +3736,7 @@ public class ProfileUtilities extends TranslatingUtilities {
public boolean isPrimitive(String value) {
StructureDefinition sd = context.fetchTypeDefinition(value);
if (sd == null) // might be running before all SDs are available
return Utilities.existsInList(value, "base64Binary", "boolean", "canonical", "code", "date", "dateTime", "decimal", "id", "instant", "integer", "markdown", "oid", "positiveInt", "string", "time", "unsignedInt", "uri", "url", "uuid");
return Utilities.existsInList(value, "base64Binary", "boolean", "canonical", "code", "date", "dateTime", "decimal", "id", "instant", "integer", "integer64", "markdown", "oid", "positiveInt", "string", "time", "unsignedInt", "uri", "url", "uuid");
else
return sd.getKind() == StructureDefinitionKind.PRIMITIVETYPE;
}

View File

@ -466,7 +466,7 @@ public class SimpleWorkerContext extends BaseWorkerContext implements IWorkerCon
@Override
public Set<String> typeTails() {
return new HashSet<String>(Arrays.asList("Integer","UnsignedInt","PositiveInt","Decimal","DateTime","Date","Time","Instant","String","Uri","Url","Canonical","Oid","Uuid","Id","Boolean","Code","Markdown","Base64Binary","Coding","CodeableConcept","Attachment","Identifier","Quantity","SampledData","Range","Period","Ratio","HumanName","Address","ContactPoint","Timing","Reference","Annotation","Signature","Meta"));
return new HashSet<String>(Arrays.asList("Integer","Integer64","UnsignedInt","PositiveInt","Decimal","DateTime","Date","Time","Instant","String","Uri","Url","Canonical","Oid","Uuid","Id","Boolean","Code","Markdown","Base64Binary","Coding","CodeableConcept","Attachment","Identifier","Quantity","SampledData","Range","Period","Ratio","HumanName","Address","ContactPoint","Timing","Reference","Annotation","Signature","Meta"));
}
@Override

View File

@ -52,7 +52,7 @@ public abstract class ParserBase {
public enum ValidationPolicy { NONE, QUICK, EVERYTHING }
public boolean isPrimitive(String code) {
return Utilities.existsInList(code, "boolean", "integer", "string", "decimal", "uri", "base64Binary", "instant", "date", "dateTime", "time", "code", "oid", "id", "markdown", "unsignedInt", "positiveInt", "xhtml", "url", "canonical");
return Utilities.existsInList(code, "boolean", "integer", "integer64", "string", "decimal", "uri", "base64Binary", "instant", "date", "dateTime", "time", "code", "oid", "id", "markdown", "unsignedInt", "positiveInt", "xhtml", "url", "canonical");
// StructureDefinition sd = context.fetchTypeDefinition(code);
// return sd != null && sd.getKind() == StructureDefinitionKind.PRIMITIVETYPE;

View File

@ -464,6 +464,8 @@ public class TurtleParser extends ParserBase {
xst = "^^xsd:boolean";
else if (type.equals("integer"))
xst = "^^xsd:integer";
else if (type.equals("integer64"))
xst = "^^xsd:long";
else if (type.equals("unsignedInt"))
xst = "^^xsd:nonNegativeInteger";
else if (type.equals("positiveInt"))

View File

@ -141,6 +141,11 @@ public class JsonParser extends JsonParserBase {
return res;
}
protected Integer64Type parseInteger64(java.lang.Long v) throws IOException, FHIRFormatError {
Integer64Type res = new Integer64Type(v);
return res;
}
protected OidType parseOid(String v) throws IOException, FHIRFormatError {
OidType res = new OidType(v);
return res;
@ -28567,6 +28572,12 @@ public class JsonParser extends JsonParserBase {
parseElementProperties(json.getAsJsonObject("_"+prefix+"Integer"), t);
return t;
}
else if (json.has(prefix+"Integer64") || json.has("_"+prefix+"Integer64")) {
Type t = json.has(prefix+"Integer64") ? parseInteger64(json.get(prefix+"Integer64").getAsLong()) : new Integer64Type();
if (json.has("_"+prefix+"Integer64"))
parseElementProperties(json.getAsJsonObject("_"+prefix+"Integer64"), t);
return t;
}
else if (json.has(prefix+"Oid") || json.has("_"+prefix+"Oid")) {
Type t = json.has(prefix+"Oid") ? parseOid(json.get(prefix+"Oid").getAsString()) : new OidType();
if (json.has("_"+prefix+"Oid"))
@ -29113,6 +29124,8 @@ public class JsonParser extends JsonParserBase {
return true;
if (json.has(prefix+"Integer") || json.has("_"+prefix+"Integer"))
return true;
if (json.has(prefix+"Integer64") || json.has("_"+prefix+"Integer64"))
return true;
if (json.has(prefix+"Oid") || json.has("_"+prefix+"Oid"))
return true;
if (json.has(prefix+"Canonical") || json.has("_"+prefix+"Canonical"))
@ -29302,6 +29315,24 @@ public class JsonParser extends JsonParserBase {
writeNull(name);
}
protected void composeInteger64Core(String name, Integer64Type value, boolean inArray) throws IOException {
if (value != null && value.hasValue()) {
prop(name, value.getValue().toString());
}
else if (inArray)
writeNull(name);
}
protected void composeInteger64Extras(String name, Integer64Type value, boolean inArray) throws IOException {
if (value != null && (!Utilities.noString(value.getId()) || ExtensionHelper.hasExtensions(value) || makeComments(value))) {
open(inArray ? null : "_"+name);
composeElement(value);
close();
}
else if (inArray)
writeNull(name);
}
protected void composeOidCore(String name, OidType value, boolean inArray) throws IOException {
if (value != null && value.hasValue()) {
prop(name, toString(value.getValue()));
@ -60262,6 +60293,10 @@ public class JsonParser extends JsonParserBase {
composeIntegerCore(prefix+"Integer", (IntegerType) type, false);
composeIntegerExtras(prefix+"Integer", (IntegerType) type, false);
}
else if (type instanceof Integer64Type) {
composeInteger64Core(prefix+"Integer64", (Integer64Type) type, false);
composeInteger64Extras(prefix+"Integer64", (Integer64Type) type, false);
}
else if (type instanceof UriType) {
composeUriCore(prefix+"Uri", (UriType) type, false);
composeUriExtras(prefix+"Uri", (UriType) type, false);

View File

@ -158,6 +158,14 @@ public class RdfParser extends RdfParserBase {
composeElement(t, parentType, name, value, index);
}
protected void composeInteger64(Complex parent, String parentType, String name, Integer64Type value, int index) {
if (value == null)
return;
Complex t = parent.predicate("fhir:"+parentType+"."+name);
t.predicate("fhir:value", ttlLiteral(value.asStringValue()));
composeElement(t, parentType, name, value, index);
}
protected void composeOid(Complex parent, String parentType, String name, OidType value, int index) {
if (value == null)
return;
@ -18416,6 +18424,8 @@ public class RdfParser extends RdfParserBase {
composeString(parent, parentType, name, (StringType)value, index);
else if (value instanceof IntegerType)
composeInteger(parent, parentType, name, (IntegerType)value, index);
else if (value instanceof Integer64Type)
composeInteger64(parent, parentType, name, (Integer64Type)value, index);
else if (value instanceof OidType)
composeOid(parent, parentType, name, (OidType)value, index);
else if (value instanceof CanonicalType)

View File

@ -190,6 +190,21 @@ public class XmlParser extends XmlParserBase {
return res;
}
protected Integer64Type parseInteger64(XmlPullParser xpp) throws XmlPullParserException, IOException, FHIRFormatError {
Integer64Type res = new Integer64Type(xpp.getAttributeValue(null, "value"));
parseElementAttributes(xpp, res);
next(xpp);
int eventType = nextNoWhitespace(xpp);
while (eventType != XmlPullParser.END_TAG) {
if (!parseElementContent(eventType, xpp, res))
unknownContent(xpp);
eventType = nextNoWhitespace(xpp);
}
next(xpp);
parseElementClose(res);
return res;
}
protected OidType parseOid(XmlPullParser xpp) throws XmlPullParserException, IOException, FHIRFormatError {
OidType res = new OidType(xpp.getAttributeValue(null, "value"));
parseElementAttributes(xpp, res);
@ -24697,6 +24712,8 @@ public class XmlParser extends XmlParserBase {
return parseString(xpp);
else if (xpp.getName().equals(prefix+"integer"))
return parseInteger(xpp);
else if (xpp.getName().equals(prefix+"integer64"))
return parseInteger64(xpp);
else if (xpp.getName().equals(prefix+"oid"))
return parseOid(xpp);
else if (xpp.getName().equals(prefix+"canonical"))
@ -24815,6 +24832,8 @@ public class XmlParser extends XmlParserBase {
return parseString(xpp);
else if (xpp.getName().equals(prefix+"Integer"))
return parseInteger(xpp);
else if (xpp.getName().equals(prefix+"Integer64"))
return parseInteger64(xpp);
else if (xpp.getName().equals(prefix+"Oid"))
return parseOid(xpp);
else if (xpp.getName().equals(prefix+"Canonical"))
@ -24857,6 +24876,8 @@ public class XmlParser extends XmlParserBase {
return parseString(xpp);
else if (type.equals("integer"))
return parseInteger(xpp);
else if (type.equals("integer64"))
return parseInteger64(xpp);
else if (type.equals("oid"))
return parseOid(xpp);
else if (type.equals("canonical"))
@ -25343,6 +25364,8 @@ public class XmlParser extends XmlParserBase {
return parseString(xpp);
else if (type.equals("integer"))
return parseInteger(xpp);
else if (type.equals("integer64"))
return parseInteger64(xpp);
else if (type.equals("oid"))
return parseOid(xpp);
else if (type.equals("canonical"))
@ -25745,6 +25768,8 @@ public class XmlParser extends XmlParserBase {
return true;
if (xpp.getName().equals(prefix+"Integer"))
return true;
if (xpp.getName().equals(prefix+"Integer64"))
return true;
if (xpp.getName().equals(prefix+"Oid"))
return true;
if (xpp.getName().equals(prefix+"Canonical"))
@ -25884,6 +25909,19 @@ public class XmlParser extends XmlParserBase {
}
}
protected void composeInteger64(String name, Integer64Type value) throws IOException {
if (value != null) { // integer
composeElementAttributes(value);
if (value.asStringValue() != null)
xml.attribute("value", value.asStringValue());
xml.enter(FHIR_NS, name);
composeElementElements(value);
composeElementClose(value);
xml.exit(FHIR_NS, name);
}
}
protected void composeOid(String name, OidType value) throws IOException {
if (value != null && (!Utilities.noString(value.getId()) || ExtensionHelper.hasExtensions(value) || !Utilities.noString(value.getValue()))) {// oid
composeElementAttributes(value);
@ -51806,6 +51844,8 @@ public class XmlParser extends XmlParserBase {
composeString(prefix+"String", (StringType) type);
else if (type instanceof IntegerType)
composeInteger(prefix+"Integer", (IntegerType) type);
else if (type instanceof Integer64Type)
composeInteger64(prefix+"Integer64", (Integer64Type) type);
else if (type instanceof UriType)
composeUri(prefix+"Uri", (UriType) type);
else if (type instanceof InstantType)

View File

@ -5507,6 +5507,18 @@ When pattern[x] is used to constrain a complex object, it means that each proper
return this != null && this.minValue instanceof IntegerType;
}
public Integer64Type getMinValueInteger64Type() throws FHIRException {
if (this.minValue == null)
this.minValue = new Integer64Type();
if (!(this.minValue instanceof Integer64Type))
throw new FHIRException("Type mismatch: the type Integer64Type was expected, but "+this.minValue.getClass().getName()+" was encountered");
return (Integer64Type) this.minValue;
}
public boolean hasMinValueInteger64Type() {
return this != null && this.minValue instanceof IntegerType;
}
/**
* @return {@link #minValue} (The minimum allowed value for the element. The value is inclusive. This is allowed for the types date, dateTime, instant, time, decimal, integer, and Quantity.)
*/
@ -5560,7 +5572,7 @@ When pattern[x] is used to constrain a complex object, it means that each proper
* @param value {@link #minValue} (The minimum allowed value for the element. The value is inclusive. This is allowed for the types date, dateTime, instant, time, decimal, integer, and Quantity.)
*/
public ElementDefinition setMinValue(Type value) {
if (value != null && !(value instanceof DateType || value instanceof DateTimeType || value instanceof InstantType || value instanceof TimeType || value instanceof DecimalType || value instanceof IntegerType || value instanceof PositiveIntType || value instanceof UnsignedIntType || value instanceof Quantity))
if (value != null && !(value instanceof DateType || value instanceof DateTimeType || value instanceof InstantType || value instanceof TimeType || value instanceof DecimalType || value instanceof IntegerType || value instanceof Integer64Type || value instanceof PositiveIntType || value instanceof UnsignedIntType || value instanceof Quantity))
throw new Error("Not the right type for ElementDefinition.minValue[x]: "+value.fhirType());
this.minValue = value;
return this;
@ -5663,6 +5675,19 @@ When pattern[x] is used to constrain a complex object, it means that each proper
return this != null && this.maxValue instanceof IntegerType;
}
public Integer64Type getMaxValueInteger64Type() throws FHIRException {
if (this.maxValue == null)
this.maxValue = new Integer64Type();
if (!(this.maxValue instanceof Integer64Type))
throw new FHIRException("Type mismatch: the type Integer64Type was expected, but "+this.maxValue.getClass().getName()+" was encountered");
return (Integer64Type) this.maxValue;
}
public boolean hasMaxValueInteger64Type() {
return this != null && this.maxValue instanceof Integer64Type;
}
/**
* @return {@link #maxValue} (The maximum allowed value for the element. The value is inclusive. This is allowed for the types date, dateTime, instant, time, decimal, integer, and Quantity.)
*/
@ -5716,7 +5741,7 @@ When pattern[x] is used to constrain a complex object, it means that each proper
* @param value {@link #maxValue} (The maximum allowed value for the element. The value is inclusive. This is allowed for the types date, dateTime, instant, time, decimal, integer, and Quantity.)
*/
public ElementDefinition setMaxValue(Type value) {
if (value != null && !(value instanceof DateType || value instanceof DateTimeType || value instanceof InstantType || value instanceof TimeType || value instanceof DecimalType || value instanceof IntegerType || value instanceof PositiveIntType || value instanceof UnsignedIntType || value instanceof Quantity))
if (value != null && !(value instanceof DateType || value instanceof DateTimeType || value instanceof InstantType || value instanceof TimeType || value instanceof DecimalType || value instanceof IntegerType || value instanceof Integer64Type || value instanceof PositiveIntType || value instanceof UnsignedIntType || value instanceof Quantity))
throw new Error("Not the right type for ElementDefinition.maxValue[x]: "+value.fhirType());
this.maxValue = value;
return this;

View File

@ -1439,6 +1439,10 @@ public class Enumerations {
* A whole number
*/
INTEGER,
/**
* A whole number
*/
INTEGER64,
/**
* A string that may contain Github Flavored Markdown syntax for optional processing by a mark down presentation engine
*/
@ -1596,6 +1600,8 @@ public class Enumerations {
return INSTANT;
if ("integer".equals(codeString))
return INTEGER;
if ("integer64".equals(codeString))
return INTEGER64;
if ("markdown".equals(codeString))
return MARKDOWN;
if ("oid".equals(codeString))
@ -1675,6 +1681,7 @@ public class Enumerations {
case ID: return "id";
case INSTANT: return "instant";
case INTEGER: return "integer";
case INTEGER64: return "integer64";
case MARKDOWN: return "markdown";
case OID: return "oid";
case POSITIVEINT: return "positiveInt";
@ -1745,6 +1752,7 @@ public class Enumerations {
case ID: return "http://hl7.org/fhir/data-types";
case INSTANT: return "http://hl7.org/fhir/data-types";
case INTEGER: return "http://hl7.org/fhir/data-types";
case INTEGER64: return "http://hl7.org/fhir/data-types";
case MARKDOWN: return "http://hl7.org/fhir/data-types";
case OID: return "http://hl7.org/fhir/data-types";
case POSITIVEINT: return "http://hl7.org/fhir/data-types";
@ -1885,6 +1893,7 @@ public class Enumerations {
case ID: return "id";
case INSTANT: return "instant";
case INTEGER: return "integer";
case INTEGER64: return "integer64";
case MARKDOWN: return "markdown";
case OID: return "oid";
case POSITIVEINT: return "positiveInt";
@ -2015,6 +2024,8 @@ public class Enumerations {
return DataType.INSTANT;
if ("integer".equals(codeString))
return DataType.INTEGER;
if ("integer64".equals(codeString))
return DataType.INTEGER64;
if ("markdown".equals(codeString))
return DataType.MARKDOWN;
if ("oid".equals(codeString))
@ -2155,6 +2166,8 @@ public class Enumerations {
return new Enumeration<DataType>(this, DataType.INSTANT);
if ("integer".equals(codeString))
return new Enumeration<DataType>(this, DataType.INTEGER);
if ("integer64".equals(codeString))
return new Enumeration<DataType>(this, DataType.INTEGER64);
if ("markdown".equals(codeString))
return new Enumeration<DataType>(this, DataType.MARKDOWN);
if ("oid".equals(codeString))
@ -2288,6 +2301,8 @@ public class Enumerations {
return "instant";
if (code == DataType.INTEGER)
return "integer";
if (code == DataType.INTEGER64)
return "integer64";
if (code == DataType.MARKDOWN)
return "markdown";
if (code == DataType.OID)
@ -3395,6 +3410,10 @@ public class Enumerations {
* A whole number
*/
INTEGER,
/**
* A whole number
*/
INTEGER64,
/**
* A string that may contain Github Flavored Markdown syntax for optional processing by a mark down presentation engine
*/
@ -4139,6 +4158,8 @@ The primary difference between a medicationusage and a medicationadministration
return INSTANT;
if ("integer".equals(codeString))
return INTEGER;
if ("integer64".equals(codeString))
return INTEGER64;
if ("markdown".equals(codeString))
return MARKDOWN;
if ("oid".equals(codeString))
@ -4510,6 +4531,7 @@ The primary difference between a medicationusage and a medicationadministration
case ID: return "id";
case INSTANT: return "instant";
case INTEGER: return "integer";
case INTEGER64: return "integer64";
case MARKDOWN: return "markdown";
case OID: return "oid";
case POSITIVEINT: return "positiveInt";
@ -5158,6 +5180,7 @@ The primary difference between a medicationusage and a medicationadministration
case ID: return "id";
case INSTANT: return "instant";
case INTEGER: return "integer";
case INTEGER64: return "integer64";
case MARKDOWN: return "markdown";
case OID: return "oid";
case POSITIVEINT: return "positiveInt";
@ -5434,6 +5457,8 @@ The primary difference between a medicationusage and a medicationadministration
return FHIRAllTypes.INSTANT;
if ("integer".equals(codeString))
return FHIRAllTypes.INTEGER;
if ("integer64".equals(codeString))
return FHIRAllTypes.INTEGER64;
if ("markdown".equals(codeString))
return FHIRAllTypes.MARKDOWN;
if ("oid".equals(codeString))
@ -5866,6 +5891,8 @@ The primary difference between a medicationusage and a medicationadministration
return new Enumeration<FHIRAllTypes>(this, FHIRAllTypes.INSTANT);
if ("integer".equals(codeString))
return new Enumeration<FHIRAllTypes>(this, FHIRAllTypes.INTEGER);
if ("integer64".equals(codeString))
return new Enumeration<FHIRAllTypes>(this, FHIRAllTypes.INTEGER64);
if ("markdown".equals(codeString))
return new Enumeration<FHIRAllTypes>(this, FHIRAllTypes.MARKDOWN);
if ("oid".equals(codeString))
@ -6291,6 +6318,8 @@ The primary difference between a medicationusage and a medicationadministration
return "instant";
if (code == FHIRAllTypes.INTEGER)
return "integer";
if (code == FHIRAllTypes.INTEGER64)
return "integer64";
if (code == FHIRAllTypes.MARKDOWN)
return "markdown";
if (code == FHIRAllTypes.OID)
@ -6831,6 +6860,10 @@ The primary difference between a medicationusage and a medicationadministration
* A whole number
*/
INTEGER,
/**
* A whole number
*/
INTEGER64,
/**
* A string that may contain Github Flavored Markdown syntax for optional processing by a mark down presentation engine
*/
@ -7567,6 +7600,8 @@ The primary difference between a medicationusage and a medicationadministration
return INSTANT;
if ("integer".equals(codeString))
return INTEGER;
if ("integer64".equals(codeString))
return INTEGER64;
if ("markdown".equals(codeString))
return MARKDOWN;
if ("oid".equals(codeString))
@ -7934,6 +7969,7 @@ The primary difference between a medicationusage and a medicationadministration
case ID: return "id";
case INSTANT: return "instant";
case INTEGER: return "integer";
case INTEGER64: return "integer64";
case MARKDOWN: return "markdown";
case OID: return "oid";
case POSITIVEINT: return "positiveInt";
@ -8576,6 +8612,7 @@ The primary difference between a medicationusage and a medicationadministration
case ID: return "id";
case INSTANT: return "instant";
case INTEGER: return "integer";
case INTEGER64: return "integer64";
case MARKDOWN: return "markdown";
case OID: return "oid";
case POSITIVEINT: return "positiveInt";
@ -8850,6 +8887,8 @@ The primary difference between a medicationusage and a medicationadministration
return FHIRDefinedType.INSTANT;
if ("integer".equals(codeString))
return FHIRDefinedType.INTEGER;
if ("integer64".equals(codeString))
return FHIRDefinedType.INTEGER64;
if ("markdown".equals(codeString))
return FHIRDefinedType.MARKDOWN;
if ("oid".equals(codeString))
@ -9278,6 +9317,8 @@ The primary difference between a medicationusage and a medicationadministration
return new Enumeration<FHIRDefinedType>(this, FHIRDefinedType.INSTANT);
if ("integer".equals(codeString))
return new Enumeration<FHIRDefinedType>(this, FHIRDefinedType.INTEGER);
if ("integer64".equals(codeString))
return new Enumeration<FHIRDefinedType>(this, FHIRDefinedType.INTEGER64);
if ("markdown".equals(codeString))
return new Enumeration<FHIRDefinedType>(this, FHIRDefinedType.MARKDOWN);
if ("oid".equals(codeString))
@ -9699,6 +9740,8 @@ The primary difference between a medicationusage and a medicationadministration
return "instant";
if (code == FHIRDefinedType.INTEGER)
return "integer";
if (code == FHIRDefinedType.INTEGER64)
return "integer64";
if (code == FHIRDefinedType.MARKDOWN)
return "markdown";
if (code == FHIRDefinedType.OID)

View File

@ -220,6 +220,8 @@ public class Factory {
return new BooleanType();
else if (name.equals("integer"))
return new IntegerType();
else if (name.equals("integer64"))
return new Integer64Type();
else if (name.equals("decimal"))
return new DecimalType();
else if (name.equals("base64Binary"))

View File

@ -0,0 +1,133 @@
/*
Copyright (c) 2011+, HL7, Inc
All rights reserved.
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
* Neither the name of HL7 nor the names of its contributors may be used to
endorse or promote products derived from this software without specific
prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
*/
/**
*
*/
package org.hl7.fhir.r5.model;
/*-
* #%L
* org.hl7.fhir.r5
* %%
* Copyright (C) 2014 - 2019 Health Level 7
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import org.hl7.fhir.instance.model.api.IBaseIntegerDatatype;
import ca.uhn.fhir.model.api.annotation.DatatypeDef;
/**
* Primitive type "integer" in FHIR: A signed 32-bit integer
*/
@DatatypeDef(name = "integer")
public class Integer64Type extends PrimitiveType<Long> /* implements IBaseInteger64Datatype */ {
private static final long serialVersionUID = 3L;
/**
* Constructor
*/
public Integer64Type() {
// nothing
}
/**
* Constructor
*/
public Integer64Type(long theInteger) {
setValue(theInteger);
}
/**
* Constructor
*
* @param theIntegerAsString
* A string representation of an integer
* @throws IllegalArgumentException
* If the string is not a valid integer representation
*/
public Integer64Type(String theIntegerAsString) {
setValueAsString(theIntegerAsString);
}
/**
* Constructor
*
* @param theValue The value
* @throws IllegalArgumentException If the value is too large to fit in a signed integer
*/
public Integer64Type(Long theValue) {
if (theValue < java.lang.Long.MIN_VALUE || theValue > java.lang.Long.MAX_VALUE) {
throw new IllegalArgumentException
(theValue + " cannot be cast to int without changing its value.");
}
if(theValue!=null) {
setValue((long)theValue.longValue());
}
}
@Override
protected Long parse(String theValue) {
try {
return Long.parseLong(theValue);
} catch (NumberFormatException e) {
throw new IllegalArgumentException(e);
}
}
@Override
protected String encode(Long theValue) {
return Long.toString(theValue);
}
@Override
public Integer64Type copy() {
Integer64Type ret = new Integer64Type(getValue());
copyValues(ret);
return ret;
}
public String fhirType() {
return "integer64";
}
}

View File

@ -98,6 +98,7 @@ public class TypesUtilities {
res.add(new WildcardInformation("id", TypeClassification.PRIMITIVE));
res.add(new WildcardInformation("instant", TypeClassification.PRIMITIVE));
res.add(new WildcardInformation("integer", TypeClassification.PRIMITIVE));
res.add(new WildcardInformation("integer64", TypeClassification.PRIMITIVE));
res.add(new WildcardInformation("markdown", TypeClassification.PRIMITIVE));
res.add(new WildcardInformation("oid", TypeClassification.PRIMITIVE));
res.add(new WildcardInformation("positiveInt", TypeClassification.PRIMITIVE));
@ -148,7 +149,7 @@ public class TypesUtilities {
}
public static boolean isPrimitive(String code) {
return Utilities.existsInList(code, "boolean", "integer", "string", "decimal", "uri", "url", "canonical", "base64Binary", "instant", "date", "dateTime", "time", "code", "oid", "id", "markdown", "unsignedInt", "positiveInt", "xhtml");
return Utilities.existsInList(code, "boolean", "integer", "integer64", "string", "decimal", "uri", "url", "canonical", "base64Binary", "instant", "date", "dateTime", "time", "code", "oid", "id", "markdown", "unsignedInt", "positiveInt", "xhtml");
}
}

View File

@ -142,6 +142,29 @@ public class Utilities {
return true;
}
public static boolean isLong(String string) {
if (isBlank(string)) {
return false;
}
String value = string.startsWith("-") ? string.substring(1) : string;
for (char next : value.toCharArray()) {
if (!Character.isDigit(next)) {
return false;
}
}
// check bounds -9,223,372,036,854,775,808 to +9,223,372,036,854,775,807
if (value.length() > 20)
return false;
if (string.startsWith("-")) {
if (value.length() == 20 && string.compareTo("9223372036854775808") > 0)
return false;
} else {
if (value.length() == 20 && string.compareTo("9223372036854775807") > 0)
return false;
}
return true;
}
public static boolean isHex(String string) {
try {
int i = Integer.parseInt(string, 16);

View File

@ -1735,6 +1735,17 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
rule(errors, IssueType.INVALID, e.line(), e.col(), path, v > 0, "value is less than permitted minimum value of 1");
}
}
if (type.equals("integer64")) {
if (rule(errors, IssueType.INVALID, e.line(), e.col(), path, Utilities.isLong(e.primitiveValue()), "The value '" + e.primitiveValue() + "' is not a valid integer64")) {
Long v = new Long(e.getValue()).longValue();
rule(errors, IssueType.INVALID, e.line(), e.col(), path, !context.hasMaxValueInteger64Type() || !context.getMaxValueInteger64Type().hasValue() || (context.getMaxValueInteger64Type().getValue() >= v), "value is greater than permitted maximum value of " + (context.hasMaxValueInteger64Type() ? context.getMaxValueInteger64Type() : ""));
rule(errors, IssueType.INVALID, e.line(), e.col(), path, !context.hasMinValueInteger64Type() || !context.getMinValueInteger64Type().hasValue() || (context.getMinValueInteger64Type().getValue() <= v), "value is less than permitted minimum value of " + (context.hasMinValueInteger64Type() ? context.getMinValueInteger64Type() : ""));
if (type.equals("unsignedInt"))
rule(errors, IssueType.INVALID, e.line(), e.col(), path, v >= 0, "value is less than permitted minimum value of 0");
if (type.equals("positiveInt"))
rule(errors, IssueType.INVALID, e.line(), e.col(), path, v > 0, "value is less than permitted minimum value of 1");
}
}
if (type.equals("decimal")) {
if (e.primitiveValue() != null) {
DecimalStatus ds = Utilities.checkDecimal(e.primitiveValue(), true, false);