Simplify FileSize

pull/321/head
Alexey Golub 5 years ago
parent 6f1c944cb3
commit f153aad3f1

@ -4,79 +4,58 @@ namespace DiscordChatExporter.Core.Models
{ {
// Loosely based on https://github.com/omar/ByteSize (MIT license) // Loosely based on https://github.com/omar/ByteSize (MIT license)
public struct FileSize public readonly struct FileSize
{ {
public const long BytesInKiloByte = 1024; public long TotalBytes { get; }
public const long BytesInMegaByte = 1024 * BytesInKiloByte;
public const long BytesInGigaByte = 1024 * BytesInMegaByte; public double TotalKiloBytes => TotalBytes / 1024.0;
public const long BytesInTeraByte = 1024 * BytesInGigaByte; public double TotalMegaBytes => TotalKiloBytes / 1024.0;
public const long BytesInPetaByte = 1024 * BytesInTeraByte; public double TotalGigaBytes => TotalMegaBytes / 1024.0;
public double TotalTeraBytes => TotalGigaBytes / 1024.0;
public const string ByteSymbol = "B"; public double TotalPetaBytes => TotalTeraBytes / 1024.0;
public const string KiloByteSymbol = "KB";
public const string MegaByteSymbol = "MB"; public FileSize(long bytes) => TotalBytes = bytes;
public const string GigaByteSymbol = "GB";
public const string TeraByteSymbol = "TB"; private double GetLargestWholeNumberValue()
public const string PetaByteSymbol = "PB";
public double Bytes { get; }
public double KiloBytes => Bytes / BytesInKiloByte;
public double MegaBytes => Bytes / BytesInMegaByte;
public double GigaBytes => Bytes / BytesInGigaByte;
public double TeraBytes => Bytes / BytesInTeraByte;
public double PetaBytes => Bytes / BytesInPetaByte;
public string LargestWholeNumberSymbol
{ {
get if (Math.Abs(TotalPetaBytes) >= 1)
{ return TotalPetaBytes;
if (Math.Abs(PetaBytes) >= 1)
return PetaByteSymbol;
if (Math.Abs(TeraBytes) >= 1) if (Math.Abs(TotalTeraBytes) >= 1)
return TeraByteSymbol; return TotalTeraBytes;
if (Math.Abs(GigaBytes) >= 1) if (Math.Abs(TotalGigaBytes) >= 1)
return GigaByteSymbol; return TotalGigaBytes;
if (Math.Abs(MegaBytes) >= 1) if (Math.Abs(TotalMegaBytes) >= 1)
return MegaByteSymbol; return TotalMegaBytes;
if (Math.Abs(KiloBytes) >= 1) if (Math.Abs(TotalKiloBytes) >= 1)
return KiloByteSymbol; return TotalKiloBytes;
return ByteSymbol; return TotalBytes;
}
} }
public double LargestWholeNumberValue private string GetLargestWholeNumberSymbol()
{ {
get if (Math.Abs(TotalPetaBytes) >= 1)
{ return "PB";
if (Math.Abs(PetaBytes) >= 1)
return PetaBytes;
if (Math.Abs(TeraBytes) >= 1) if (Math.Abs(TotalTeraBytes) >= 1)
return TeraBytes; return "TB";
if (Math.Abs(GigaBytes) >= 1) if (Math.Abs(TotalGigaBytes) >= 1)
return GigaBytes; return "GB";
if (Math.Abs(MegaBytes) >= 1) if (Math.Abs(TotalMegaBytes) >= 1)
return MegaBytes; return "MB";
if (Math.Abs(KiloBytes) >= 1) if (Math.Abs(TotalKiloBytes) >= 1)
return KiloBytes; return "KB";
return Bytes; return "B";
}
}
public FileSize(double bytes)
{
Bytes = bytes;
} }
public override string ToString() => $"{LargestWholeNumberValue:0.##} {LargestWholeNumberSymbol}"; public override string ToString() => $"{GetLargestWholeNumberValue():0.##} {GetLargestWholeNumberSymbol()}";
} }
} }

@ -88,7 +88,7 @@ namespace DiscordChatExporter.Core.Rendering.Formatters
_writer.WriteString("id", attachment.Id); _writer.WriteString("id", attachment.Id);
_writer.WriteString("url", attachment.Url); _writer.WriteString("url", attachment.Url);
_writer.WriteString("fileName", attachment.FileName); _writer.WriteString("fileName", attachment.FileName);
_writer.WriteNumber("fileSizeBytes", (long) attachment.FileSize.Bytes); _writer.WriteNumber("fileSizeBytes", attachment.FileSize.TotalBytes);
_writer.WriteEndObject(); _writer.WriteEndObject();
} }

Loading…
Cancel
Save