]> git.ktnx.net Git - mobile-ledger.git/commitdiff
Revert "add support for floatingPoint member of the quantity objects"
authorDamyan Ivanov <dam+mobileledger@ktnx.net>
Tue, 29 Sep 2020 15:27:24 +0000 (15:27 +0000)
committerDamyan Ivanov <dam+mobileledger@ktnx.net>
Tue, 29 Sep 2020 19:10:04 +0000 (19:10 +0000)
This reverts commit d6d15ebf2287b3e9d7c213241367ef053e971e60.

The problem with that is that it breaks sending new transactions for older
versions of hledger-web.

It is also not really necessary, because the precision got limited so that
there is no longer possible to get 255 decimal digits for periodic results

app/src/main/java/net/ktnx/mobileledger/json/v1_14/ParsedQuantity.java
app/src/main/java/net/ktnx/mobileledger/json/v1_15/ParsedQuantity.java

index 2588054ffb9419d70191c47330ac153b062973dc..5c27f6fbab8fe10e05075da1ed5aad1f062f6d01 100644 (file)
@@ -21,8 +21,8 @@ import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
 
 @JsonIgnoreProperties(ignoreUnknown = true)
 public class ParsedQuantity {
-    protected long decimalMantissa;
-    protected int decimalPlaces;
+    private long decimalMantissa;
+    private int decimalPlaces;
     public ParsedQuantity() {
     }
     public ParsedQuantity(String input) {
index 7ce1d12d3816efc5f1bc0a8b9906a7e1748105ee..f40968307301df8aa41ee7652bc4003d055a2aa7 100644 (file)
@@ -20,21 +20,39 @@ package net.ktnx.mobileledger.json.v1_15;
 import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
 
 @JsonIgnoreProperties(ignoreUnknown = true)
-public class ParsedQuantity extends net.ktnx.mobileledger.json.v1_14.ParsedQuantity {
-    private float floatingPoint;
-    private boolean floatingPointSet = false;
-    public float getFloatingPoint() {
-        if (!floatingPointSet)
-            throw new IllegalStateException("floatingPoint is not set");
-        return floatingPoint;
-    }
-    public void setFloatingPoint(float floatingPoint) {
-        this.floatingPoint = floatingPoint;
-        floatingPointSet = true;
+public class ParsedQuantity {
+    private long decimalMantissa;
+    private int decimalPlaces;
+    public ParsedQuantity() {
+    }
+    public ParsedQuantity(String input) {
+        parseString(input);
+    }
+    public long getDecimalMantissa() {
+        return decimalMantissa;
+    }
+    public void setDecimalMantissa(long decimalMantissa) {
+        this.decimalMantissa = decimalMantissa;
+    }
+    public int getDecimalPlaces() {
+        return decimalPlaces;
+    }
+    public void setDecimalPlaces(int decimalPlaces) {
+        this.decimalPlaces = decimalPlaces;
     }
     public float asFloat() {
-        if (floatingPointSet)
-            return floatingPoint;
         return (float) (decimalMantissa * Math.pow(10, -decimalPlaces));
     }
+    public void parseString(String input) {
+        int pointPos = input.indexOf('.');
+        if (pointPos >= 0) {
+            String integral = input.replace(".", "");
+            decimalMantissa = Long.parseLong(integral);
+            decimalPlaces = input.length() - pointPos - 1;
+        }
+        else {
+            decimalMantissa = Long.parseLong(input);
+            decimalPlaces = 0;
+        }
+    }
 }