|
|
@ -16,14 +16,26 @@ namespace NzbDrone.Core.Parser
|
|
|
|
public static string NormalizeMultiSpaces(string s) =>
|
|
|
|
public static string NormalizeMultiSpaces(string s) =>
|
|
|
|
new Regex(@"\s+").Replace(s.Trim(), " ");
|
|
|
|
new Regex(@"\s+").Replace(s.Trim(), " ");
|
|
|
|
|
|
|
|
|
|
|
|
private static string NormalizeNumber(string s)
|
|
|
|
private static string NormalizeNumber(string s, bool isInt = false)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var valStr = new string(s.Where(c => char.IsDigit(c) || c == '.' || c == ',').ToArray());
|
|
|
|
var valStr = new string(s.Where(c => char.IsDigit(c) || c == '.' || c == ',').ToArray());
|
|
|
|
|
|
|
|
|
|
|
|
valStr = (valStr.Length == 0) ? "0" : valStr.Replace(",", ".");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
valStr = valStr.Trim().Replace("-", "0");
|
|
|
|
valStr = valStr.Trim().Replace("-", "0");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (isInt)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (valStr.Contains(',') && valStr.Contains('.'))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return valStr;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
valStr = (valStr.Length == 0) ? "0" : valStr.Replace(".", ",");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return valStr;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
valStr = (valStr.Length == 0) ? "0" : valStr.Replace(",", ".");
|
|
|
|
|
|
|
|
|
|
|
|
if (valStr.Count(c => c == '.') > 1)
|
|
|
|
if (valStr.Count(c => c == '.') > 1)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var lastOcc = valStr.LastIndexOf('.');
|
|
|
|
var lastOcc = valStr.LastIndexOf('.');
|
|
|
@ -39,17 +51,17 @@ namespace NzbDrone.Core.Parser
|
|
|
|
|
|
|
|
|
|
|
|
public static float CoerceFloat(string str) => float.Parse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture);
|
|
|
|
public static float CoerceFloat(string str) => float.Parse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture);
|
|
|
|
|
|
|
|
|
|
|
|
public static int CoerceInt(string str) => int.Parse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture);
|
|
|
|
public static int CoerceInt(string str) => int.Parse(NormalizeNumber(str, true), NumberStyles.Any, CultureInfo.InvariantCulture);
|
|
|
|
|
|
|
|
|
|
|
|
public static long CoerceLong(string str) => long.Parse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture);
|
|
|
|
public static long CoerceLong(string str) => long.Parse(NormalizeNumber(str, true), NumberStyles.Any, CultureInfo.InvariantCulture);
|
|
|
|
|
|
|
|
|
|
|
|
public static bool TryCoerceDouble(string str, out double result) => double.TryParse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
public static bool TryCoerceDouble(string str, out double result) => double.TryParse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
|
|
|
|
|
|
|
|
public static bool TryCoerceFloat(string str, out float result) => float.TryParse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
public static bool TryCoerceFloat(string str, out float result) => float.TryParse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
|
|
|
|
|
|
|
|
public static bool TryCoerceInt(string str, out int result) => int.TryParse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
public static bool TryCoerceInt(string str, out int result) => int.TryParse(NormalizeNumber(str, true), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
|
|
|
|
|
|
|
|
public static bool TryCoerceLong(string str, out long result) => long.TryParse(NormalizeNumber(str), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
public static bool TryCoerceLong(string str, out long result) => long.TryParse(NormalizeNumber(str, true), NumberStyles.Any, CultureInfo.InvariantCulture, out result);
|
|
|
|
|
|
|
|
|
|
|
|
public static long? GetLongFromString(string str)
|
|
|
|
public static long? GetLongFromString(string str)
|
|
|
|
{
|
|
|
|
{
|
|
|
|