Merge pull request #621 from afischerdev/update-expressions

Replace multiple occurrences of toLowerCase() - continued
This commit is contained in:
afischerdev 2023-09-19 12:09:27 +02:00 committed by GitHub
commit 1e061d7157
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 63 additions and 59 deletions

View file

@ -565,85 +565,89 @@ public abstract class BExpressionContext implements IByteArrayUnifier {
String org = value; String org = value;
try { try {
// remove some unused characters // remove some unused characters
value = value.replace(",", "."); value = value.replaceAll(",", ".");
value = value.replace(">", ""); value = value.replaceAll(">", "");
value = value.replace("_", ""); value = value.replaceAll("_", "");
value = value.replaceAll(" ", "");
value = value.replaceAll("~", "");
value = value.replace((char) 8217, '\'');
value = value.replace((char) 8221, '"');
if (value.indexOf("-") == 0) value = value.substring(1); if (value.indexOf("-") == 0) value = value.substring(1);
if (value.indexOf("~") == 0) value = value.substring(1); if (value.contains("-")) {
if (value.contains("-")) { // replace eg. 1.4-1.6 m // replace eg. 1.4-1.6 m to 1.4m
// but also 1'-6" to 1'
// keep the unit of measure
String tmp = value.substring(value.indexOf("-") + 1).replaceAll("[0-9.,-]", ""); String tmp = value.substring(value.indexOf("-") + 1).replaceAll("[0-9.,-]", "");
value = value.substring(0, value.indexOf("-")) + tmp; value = value.substring(0, value.indexOf("-"));
if (value.matches("\\d+(\\.\\d+)?")) value += tmp;
} }
value = value.toLowerCase(Locale.US);
// do some value conversion // do some value conversion
if (value.toLowerCase().contains("ft")) { if (value.contains("ft")) {
float foot = 0f; float feet = 0f;
int inch = 0; int inch = 0;
String[] sa = value.trim().toLowerCase().split("ft"); String[] sa = value.split("ft");
if (sa.length >= 1) foot = Float.parseFloat(sa[0].trim()); if (sa.length >= 1) feet = Float.parseFloat(sa[0]);
if (sa.length == 2) { if (sa.length == 2) {
value = sa[1]; value = sa[1];
if (value.indexOf("in") > 0) value = value.substring(0, value.indexOf("in")); if (value.indexOf("in") > 0) value = value.substring(0, value.indexOf("in"));
inch = Integer.parseInt(value.trim()); inch = Integer.parseInt(value);
foot += inch / 12f; feet += inch / 12f;
} }
value = String.format(Locale.US, "%3.1f", foot * 0.3048f); value = String.format(Locale.US, "%3.1f", feet * 0.3048f);
} } else if (value.contains("'")) {
String valueLowerCase = value.toLowerCase(Locale.US); float feet = 0f;
if (value.contains("'")) {
float foot = 0f;
int inch = 0; int inch = 0;
String[] sa = valueLowerCase.trim().split("'"); String[] sa = value.split("'");
if (sa.length >= 1) foot = Float.parseFloat(sa[0].trim()); if (sa.length >= 1) feet = Float.parseFloat(sa[0]);
if (sa.length == 2) { if (sa.length == 2) {
value = sa[1]; value = sa[1];
if (value.indexOf("''") > 0) value = value.substring(0, value.indexOf("''")); if (value.indexOf("''") > 0) value = value.substring(0, value.indexOf("''"));
if (value.indexOf("\"") > 0) value = value.substring(0, value.indexOf("\"")); if (value.indexOf("\"") > 0) value = value.substring(0, value.indexOf("\""));
inch = Integer.parseInt(value.trim()); inch = Integer.parseInt(value);
foot += inch / 12f; feet += inch / 12f;
} }
value = String.format(Locale.US, "%3.1f", foot * 0.3048f);
} else if (valueLowerCase.contains("in") || value.contains("\"")) {
float inch = 0f;
if (valueLowerCase.indexOf("in") > 0) value = value.substring(0, valueLowerCase.indexOf("in"));
if (value.indexOf("\"") > 0) value = value.substring(0, value.indexOf("\""));
inch = Float.parseFloat(value.trim());
value = String.format(Locale.US, "%3.1f", inch * 0.0254f);
} else if (valueLowerCase.contains("feet") || valueLowerCase.contains("foot")) {
float feet = 0f;
String s = value.substring(0, valueLowerCase.indexOf("f"));
feet = Float.parseFloat(s.trim());
value = String.format(Locale.US, "%3.1f", feet * 0.3048f); value = String.format(Locale.US, "%3.1f", feet * 0.3048f);
} else if (valueLowerCase.contains("fathom") || valueLowerCase.contains("fm")) { } else if (value.contains("in") || value.contains("\"")) {
String s = value.substring(0, valueLowerCase.indexOf("f")); float inch = 0f;
float fathom = Float.parseFloat(s.trim()); if (value.indexOf("in") > 0) value = value.substring(0, value.indexOf("in"));
if (value.indexOf("\"") > 0) value = value.substring(0, value.indexOf("\""));
inch = Float.parseFloat(value);
value = String.format(Locale.US, "%3.1f", inch * 0.0254f);
} else if (value.contains("feet") || value.contains("foot")) {
float feet = 0f;
String s = value.substring(0, value.indexOf("f"));
feet = Float.parseFloat(s);
value = String.format(Locale.US, "%3.1f", feet * 0.3048f);
} else if (value.contains("fathom") || value.contains("fm")) {
String s = value.substring(0, value.indexOf("f"));
float fathom = Float.parseFloat(s);
value = String.format(Locale.US, "%3.1f", fathom * 1.8288f); value = String.format(Locale.US, "%3.1f", fathom * 1.8288f);
} else if (valueLowerCase.contains("cm")) { } else if (value.contains("cm")) {
String[] sa = valueLowerCase.trim().split("cm"); String[] sa = value.split("cm");
if (sa.length >= 1) value = sa[0].trim(); if (sa.length >= 1) value = sa[0];
float cm = Float.parseFloat(value.trim()); float cm = Float.parseFloat(value);
value = String.format(Locale.US, "%3.1f", cm / 100f); value = String.format(Locale.US, "%3.1f", cm / 100f);
} else if (valueLowerCase.contains("meter")) { } else if (value.contains("meter")) {
String s = value.substring(0, valueLowerCase.indexOf("m")); value = value.substring(0, value.indexOf("m"));
value = s.trim(); } else if (value.contains("mph")) {
} else if (valueLowerCase.contains("mph")) { String[] sa = value.split("mph");
String[] sa = valueLowerCase.trim().split("mph"); if (sa.length >= 1) value = sa[0];
if (sa.length >= 1) value = sa[0].trim(); float mph = Float.parseFloat(value);
float mph = Float.parseFloat(value.trim());
value = String.format(Locale.US, "%3.1f", mph * 1.609344f); value = String.format(Locale.US, "%3.1f", mph * 1.609344f);
} else if (valueLowerCase.contains("knot")) { } else if (value.contains("knot")) {
String[] sa = valueLowerCase.trim().split("knot"); String[] sa = value.split("knot");
if (sa.length >= 1) value = sa[0].trim(); if (sa.length >= 1) value = sa[0];
float nm = Float.parseFloat(value.trim()); float nm = Float.parseFloat(value);
value = String.format(Locale.US, "%3.1f", nm * 1.852f); value = String.format(Locale.US, "%3.1f", nm * 1.852f);
} else if (valueLowerCase.contains("kmh") || valueLowerCase.contains("km/h") || valueLowerCase.contains("kph")) { } else if (value.contains("kmh") || value.contains("km/h") || value.contains("kph")) {
String[] sa = valueLowerCase.trim().split("k"); String[] sa = value.split("k");
if (sa.length > 1) value = sa[0].trim(); if (sa.length > 1) value = sa[0];
} else if (valueLowerCase.contains("m")) { } else if (value.contains("m")) {
String s = value.substring(0, valueLowerCase.indexOf("m")); value = value.substring(0, value.indexOf("m"));
value = s.trim();
} else if (value.contains("(")) { } else if (value.contains("(")) {
String s = value.substring(0, valueLowerCase.indexOf("(")); value = value.substring(0, value.indexOf("("));
value = s.trim();
} }
// found negative maxdraft values // found negative maxdraft values
// no negative values // no negative values

View file

@ -29,7 +29,7 @@ public class EncodeDecodeTest {
"depth=1'6\"", "depth=1'6\"",
// "depth=6 feet", // "depth=6 feet",
"maxheight=5.1m", "maxheight=5.1m",
"maxdraft=~3 mt", "maxdraft=~3 m - 4 m",
"reversedirection=yes" "reversedirection=yes"
}; };