View Javadoc
1   /*
2    * Portions of this software was developed by employees of the National Institute
3    * of Standards and Technology (NIST), an agency of the Federal Government and is
4    * being made available as a public service. Pursuant to title 17 United States
5    * Code Section 105, works of NIST employees are not subject to copyright
6    * protection in the United States. This software may be subject to foreign
7    * copyright. Permission in the United States and in foreign countries, to the
8    * extent that NIST may hold copyright, to use, copy, modify, create derivative
9    * works, and distribute this software and its documentation without fee is hereby
10   * granted on a non-exclusive basis, provided that this notice and disclaimer
11   * of warranty appears in all copies.
12   *
13   * THE SOFTWARE IS PROVIDED 'AS IS' WITHOUT ANY WARRANTY OF ANY KIND, EITHER
14   * EXPRESSED, IMPLIED, OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, ANY WARRANTY
15   * THAT THE SOFTWARE WILL CONFORM TO SPECIFICATIONS, ANY IMPLIED WARRANTIES OF
16   * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND FREEDOM FROM
17   * INFRINGEMENT, AND ANY WARRANTY THAT THE DOCUMENTATION WILL CONFORM TO THE
18   * SOFTWARE, OR ANY WARRANTY THAT THE SOFTWARE WILL BE ERROR FREE.  IN NO EVENT
19   * SHALL NIST BE LIABLE FOR ANY DAMAGES, INCLUDING, BUT NOT LIMITED TO, DIRECT,
20   * INDIRECT, SPECIAL OR CONSEQUENTIAL DAMAGES, ARISING OUT OF, RESULTING FROM,
21   * OR IN ANY WAY CONNECTED WITH THIS SOFTWARE, WHETHER OR NOT BASED UPON WARRANTY,
22   * CONTRACT, TORT, OR OTHERWISE, WHETHER OR NOT INJURY WAS SUSTAINED BY PERSONS OR
23   * PROPERTY OR OTHERWISE, AND WHETHER OR NOT LOSS WAS SUSTAINED FROM, OR AROSE OUT
24   * OF THE RESULTS OF, OR USE OF, THE SOFTWARE OR SERVICES PROVIDED HEREUNDER.
25   */
26  
27  package gov.nist.secauto.metaschema.core.metapath.item.atomic;
28  
29  import gov.nist.secauto.metaschema.core.datatype.adapter.DecimalAdapter;
30  import gov.nist.secauto.metaschema.core.datatype.adapter.MetaschemaDataTypeProvider;
31  
32  import java.math.BigDecimal;
33  import java.math.BigInteger;
34  import java.math.RoundingMode;
35  
36  import edu.umd.cs.findbugs.annotations.NonNull;
37  
38  class DecimalItemImpl
39      extends AbstractNumericItem<BigDecimal>
40      implements IDecimalItem {
41    public DecimalItemImpl(@NonNull BigDecimal value) {
42      super(value);
43    }
44  
45    @Override
46    public DecimalAdapter getJavaTypeAdapter() {
47      return MetaschemaDataTypeProvider.DECIMAL;
48    }
49  
50    @SuppressWarnings("null")
51    @Override
52    public String asString() {
53      BigDecimal decimal = getValue();
54      // if the fractional part is empty, render as an integer
55      return decimal.scale() <= 0 ? decimal.toBigIntegerExact().toString() : decimal.toPlainString();
56    }
57  
58    @Override
59    public boolean toEffectiveBoolean() {
60      return !BigDecimal.ZERO.equals(getValue());
61    }
62  
63    @Override
64    public BigDecimal asDecimal() {
65      return getValue();
66    }
67  
68    @SuppressWarnings("null")
69    @Override
70    public BigInteger asInteger() {
71      return getValue().toBigInteger();
72    }
73  
74    @SuppressWarnings("null")
75    @Override
76    public INumericItem abs() {
77      return new DecimalItemImpl(getValue().abs());
78    }
79  
80    @SuppressWarnings("null")
81    @Override
82    public IIntegerItem ceiling() {
83      return IIntegerItem.valueOf(getValue().setScale(0, RoundingMode.CEILING).toBigIntegerExact());
84    }
85  
86    @SuppressWarnings("null")
87    @Override
88    public IIntegerItem floor() {
89      return IIntegerItem.valueOf(getValue().setScale(0, RoundingMode.FLOOR).toBigIntegerExact());
90    }
91  
92    @Override
93    public int hashCode() {
94      final int prime = 31;
95      int result = 1;
96      result = prime * result + getValue().hashCode();
97      return result;
98    }
99  
100   @Override
101   public boolean equals(Object obj) {
102     if (this == obj) {
103       return true; // NOPMD readability
104     } else if (obj == null) {
105       return false; // NOPMD readability
106     } else if (getClass() != obj.getClass()) {
107       return false; // NOPMD readability
108     }
109     DecimalItemImpl other = (DecimalItemImpl) obj;
110     return getValue().equals(other.getValue());
111   }
112 
113 }