Skip to content

Commit

Permalink
Cleaned up numerals
Browse files Browse the repository at this point in the history
  • Loading branch information
WillFP committed Jan 10, 2021
1 parent 2c886dc commit b16266e
Showing 1 changed file with 7 additions and 15 deletions.
22 changes: 7 additions & 15 deletions src/main/java/com/willfp/eco/util/NumberUtils.java
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
package com.willfp.eco.util;

import com.sun.javaws.exceptions.InvalidArgumentException;
import lombok.experimental.UtilityClass;

import java.text.DecimalFormat;
import java.util.Map;
import java.util.TreeMap;
import java.util.concurrent.ThreadLocalRandom;

Expand Down Expand Up @@ -94,20 +94,12 @@ public String toNumeral(final int number) {
*/
public static int fromNumeral(String numeral) {
if (numeral.isEmpty()) return 0;
if (numeral.startsWith("M")) return 1000 + fromNumeral(numeral.substring(1));
if (numeral.startsWith("CM")) return 900 + fromNumeral(numeral.substring(2));
if (numeral.startsWith("D")) return 500 + fromNumeral(numeral.substring(1));
if (numeral.startsWith("CD")) return 400 + fromNumeral(numeral.substring(2));
if (numeral.startsWith("C")) return 100 + fromNumeral(numeral.substring(1));
if (numeral.startsWith("XC")) return 90 + fromNumeral(numeral.substring(2));
if (numeral.startsWith("L")) return 50 + fromNumeral(numeral.substring(1));
if (numeral.startsWith("XL")) return 40 + fromNumeral(numeral.substring(2));
if (numeral.startsWith("X")) return 10 + fromNumeral(numeral.substring(1));
if (numeral.startsWith("IX")) return 9 + fromNumeral(numeral.substring(2));
if (numeral.startsWith("V")) return 5 + fromNumeral(numeral.substring(1));
if (numeral.startsWith("IV")) return 4 + fromNumeral(numeral.substring(2));
if (numeral.startsWith("I")) return 1 + fromNumeral(numeral.substring(1));
throw new IllegalArgumentException("Number is invalid!");
for (Map.Entry<Integer, String> entry : NUMERALS.entrySet()) {
if (numeral.startsWith(entry.getValue())) {
return entry.getKey() + fromNumeral(numeral.substring(entry.getValue().length()));
}
}
return 0;
}

/**
Expand Down

0 comments on commit b16266e

Please sign in to comment.