refuse to format nor parse invalid units
authorWladimir J. van der Laan <laanwj@gmail.com>
Tue, 26 Jul 2011 11:11:28 +0000 (13:11 +0200)
committerWladimir J. van der Laan <laanwj@gmail.com>
Tue, 26 Jul 2011 11:27:33 +0000 (13:27 +0200)
src/qt/bitcoinunits.cpp
src/qt/bitcoinunits.h

index 8414a75..7cd5023 100644 (file)
@@ -17,6 +17,19 @@ QList<BitcoinUnits::Unit> BitcoinUnits::availableUnits()
     return unitlist;
 }
 
+bool BitcoinUnits::valid(int unit)
+{
+    switch(unit)
+    {
+    case BTC:
+    case mBTC:
+    case uBTC:
+        return true;
+    default:
+        return false;
+    }
+}
+
 QString BitcoinUnits::name(int unit)
 {
     switch(unit)
@@ -54,7 +67,7 @@ int BitcoinUnits::amountDigits(int unit)
 {
     switch(unit)
     {
-    case BTC: return 8; // 21,000,000
+    case BTC: return 8; // 21,000,000 (# digits, without commas)
     case mBTC: return 11; // 21,000,000,000
     case uBTC: return 14; // 21,000,000,000,000
     default: return 0;
@@ -76,6 +89,8 @@ QString BitcoinUnits::format(int unit, qint64 n, bool fPlus)
 {
     // Note: not using straight sprintf here because we do NOT want
     // localized number formatting.
+    if(!valid(unit))
+        return QString(); // Refuse to format invalid unit
     qint64 coin = factor(unit);
     int num_decimals = decimals(unit);
     qint64 n_abs = (n > 0 ? n : -n);
@@ -104,6 +119,8 @@ QString BitcoinUnits::formatWithUnit(int unit, qint64 amount, bool plussign)
 
 bool BitcoinUnits::parse(int unit, const QString &value, qint64 *val_out)
 {
+    if(!valid(unit))
+        return false; // Refuse to parse invalid unit
     int num_decimals = decimals(unit);
     QStringList parts = value.split(".");
     if(parts.size() != 2 || parts.at(1).size() > num_decimals)
index 18b6235..4dfdbea 100644 (file)
@@ -22,6 +22,8 @@ public:
     /// Static API
     // Get list of units, for dropdown box
     static QList<Unit> availableUnits();
+    // Is unit ID valid?
+    static bool valid(int unit);
     // Short name
     static QString name(int unit);
     // Longer description