io.bdeploy.common.util.FormatHelper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of api Show documentation
Show all versions of api Show documentation
Public API including dependencies, ready to be used for integrations and plugins.
package io.bdeploy.common.util;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.time.Instant;
import java.time.ZoneId;
import java.time.format.DateTimeFormatter;
import java.time.format.FormatStyle;
import java.time.temporal.TemporalAccessor;
import java.util.Date;
import java.util.Locale;
/**
* Contains static helpers to format various data types into a human readable format.
*/
public class FormatHelper {
private static final DecimalFormat SIZE_FORMAT = new DecimalFormat("#,##0.#");
private static final DecimalFormat TRANSFER_FORMAT = new DecimalFormat("#0.0");
private static final String[] SIZE_UNITS = new String[] { "B", "kB", "MB", "GB", "TB" };
private static final DateTimeFormatter FORMATTER = DateTimeFormatter.ofLocalizedDateTime(FormatStyle.SHORT)
.withLocale(Locale.getDefault()).withZone(ZoneId.systemDefault());
private FormatHelper() {
}
/**
* Formats the given duration into a human readable format
*/
public static String formatDuration(long timeInMillis) {
return new SimpleDateFormat("mm 'min' ss 'sec' SSS 'ms'").format(new Date(timeInMillis));
}
/**
* Returns a human readable string of the given time. Only the most relevant unit is displayed.
*
*
* Sample output: 4 seconds
* 15 minutes
* 1 hour
*
*
* @param duration
* The duration in milliseconds
* @return The string representation.
*/
public static String formatRemainingTime(long duration) {
if (duration == 0) {
return "0 seconds";
}
long allSeconds = duration / 1000;
long seconds = allSeconds % 60;
long allMinutes = allSeconds / 60;
long minutes = allMinutes % 60;
long hours = allMinutes / 60;
final StringBuilder builder = new StringBuilder();
if (hours > 0) {
builder.append(hours);
builder.append(hours == 1 ? " hour" : " hours");
return builder.toString();
}
if (minutes > 0) {
builder.append(minutes);
builder.append(minutes == 1 ? " min" : " mins");
return builder.toString();
}
builder.append(seconds);
builder.append(seconds == 1 ? " sec" : " secs");
return builder.toString();
}
/**
* Calculates and formats the transfer rate into a human readable string
*
* @param bytes the number of bytes that have been transfered
* @param timeInMs the time in milliseconds that the transfer took
*/
public static String formatTransferRate(long bytes, long timeInMs) {
if (bytes <= 0 || timeInMs < 1000) {
return "N/A";
}
double bps = (bytes * 8) / (timeInMs / 1000.0);
double kBs = bps / 8000.0;
if (kBs > 1000) {
return TRANSFER_FORMAT.format(kBs / 1000.0) + " MB/s";
}
return TRANSFER_FORMAT.format(kBs) + " KB/s";
}
/**
* Formats the given date into a human readable string
*/
public static String format(Date date) {
return FORMATTER.format(date.toInstant());
}
/**
* Formats the given date into a human readable string
*/
public static String format(TemporalAccessor temporal) {
return FORMATTER.format(temporal);
}
/**
* Formats the given date into a human readable string
*/
public static String format(long timestamp) {
return FORMATTER.format(Instant.ofEpochMilli(timestamp));
}
/**
* Formats the given file size in bytes into a human readable format;
*/
public static String formatFileSize(long size) {
if (size <= 0) {
return "0 B";
}
int digitGroups = (int) (Math.log10(size) / Math.log10(1024));
return SIZE_FORMAT.format(size / Math.pow(1024, digitGroups)) + " " + SIZE_UNITS[digitGroups];
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy