001/* 002Copyright (c) 2011+, HL7, Inc 003All rights reserved. 004 005Redistribution and use in source and binary forms, with or without modification, 006are permitted provided that the following conditions are met: 007 008 * Redistributions of source code must retain the above copyright notice, this 009 list of conditions and the following disclaimer. 010 * Redistributions in binary form must reproduce the above copyright notice, 011 this list of conditions and the following disclaimer in the documentation 012 and/or other materials provided with the distribution. 013 * Neither the name of HL7 nor the names of its contributors may be used to 014 endorse or promote products derived from this software without specific 015 prior written permission. 016 017THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 018ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 019WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 020IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 021INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 022NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 023PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 024WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 025ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 026POSSIBILITY OF SUCH DAMAGE. 027 028 */ 029/** 030 * 031 */ 032package org.hl7.fhir.r4.model; 033 034/*- 035 * #%L 036 * org.hl7.fhir.r4 037 * %% 038 * Copyright (C) 2014 - 2019 Health Level 7 039 * %% 040 * Licensed under the Apache License, Version 2.0 (the "License"); 041 * you may not use this file except in compliance with the License. 042 * You may obtain a copy of the License at 043 * 044 * http://www.apache.org/licenses/LICENSE-2.0 045 * 046 * Unless required by applicable law or agreed to in writing, software 047 * distributed under the License is distributed on an "AS IS" BASIS, 048 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 049 * See the License for the specific language governing permissions and 050 * limitations under the License. 051 * #L% 052 */ 053 054 055import java.math.BigDecimal; 056import java.math.MathContext; 057import java.math.RoundingMode; 058 059import org.hl7.fhir.instance.model.api.IBaseDecimalDatatype; 060 061import ca.uhn.fhir.model.api.annotation.DatatypeDef; 062 063/** 064 * Primitive type "decimal" in FHIR: A rational number 065 */ 066@DatatypeDef(name = "decimal") 067public class DecimalType extends PrimitiveType<BigDecimal> implements Comparable<DecimalType>, IBaseDecimalDatatype { 068 069 private static final long serialVersionUID = 3L; 070 071 /** 072 * Constructor 073 */ 074 public DecimalType() { 075 super(); 076 } 077 078 /** 079 * Constructor 080 */ 081 public DecimalType(BigDecimal theValue) { 082 setValue(theValue); 083 } 084 085 /** 086 * Constructor 087 */ 088 public DecimalType(double theValue) { 089 // Use the valueOf here because the constructor gives wacky precision 090 // changes due to the floating point conversion 091 setValue(BigDecimal.valueOf(theValue)); 092 } 093 094 /** 095 * Constructor 096 */ 097 public DecimalType(long theValue) { 098 setValue(theValue); 099 } 100 101 /** 102 * Constructor 103 */ 104 public DecimalType(String theValue) { 105 setValue(new BigDecimal(theValue)); 106 setRepresentation(theValue); 107 } 108 109 @Override 110 public int compareTo(DecimalType theObj) { 111 if (getValue() == null && theObj.getValue() == null) { 112 return 0; 113 } 114 if (getValue() != null && theObj.getValue() == null) { 115 return 1; 116 } 117 if (getValue() == null && theObj.getValue() != null) { 118 return -1; 119 } 120 return getValue().compareTo(theObj.getValue()); 121 } 122 123 @Override 124 protected String encode(BigDecimal theValue) { 125 return getValue().toString(); 126 } 127 128 /** 129 * Gets the value as an integer, using {@link BigDecimal#intValue()} 130 */ 131 public int getValueAsInteger() { 132 return getValue().intValue(); 133 } 134 135 public Number getValueAsNumber() { 136 return getValue(); 137 } 138 139 @Override 140 protected BigDecimal parse(String theValue) { 141 return new BigDecimal(theValue); 142 } 143 144 /** 145 * Rounds the value to the given prevision 146 * 147 * @see MathContext#getPrecision() 148 */ 149 public void round(int thePrecision) { 150 if (getValue() != null) { 151 BigDecimal newValue = getValue().round(new MathContext(thePrecision)); 152 setValue(newValue); 153 } 154 } 155 156 /** 157 * Rounds the value to the given prevision 158 * 159 * @see MathContext#getPrecision() 160 * @see MathContext#getRoundingMode() 161 */ 162 public void round(int thePrecision, RoundingMode theRoundingMode) { 163 if (getValue() != null) { 164 BigDecimal newValue = getValue().round(new MathContext(thePrecision, theRoundingMode)); 165 setValue(newValue); 166 } 167 } 168 169 /** 170 * Sets a new value using an integer 171 */ 172 public void setValueAsInteger(int theValue) { 173 setValue(BigDecimal.valueOf(theValue)); 174 } 175 176 /** 177 * Sets a new value using a long 178 */ 179 public void setValue(long theValue) { 180 setValue(BigDecimal.valueOf(theValue)); 181 } 182 183 /** 184 * Sets a new value using a double 185 */ 186 public void setValue(double theValue) { 187 setValue(BigDecimal.valueOf(theValue)); 188 } 189 190 @Override 191 public DecimalType copy() { 192 DecimalType ret = new DecimalType(getValue()); 193 copyValues(ret); 194 return ret; 195 } 196 197 public String fhirType() { 198 return "decimal"; 199 } 200 201 /** 202 * A parser can provide a literal representation for the decimal value that preserves 203 * the presented form. 204 * 205 * All sorts of bad things can happen if this method is used to set the string representation 206 * to anything other than what was parsed into the actual value. Don't do that 207 * 208 * @param value 209 * @return 210 */ 211 public DecimalType setRepresentation(String value) { 212 forceStringValue(value); 213 return this; 214 } 215}