com.mdfromhtml.core.MDfromHTMLDuration Maven / Gradle / Ivy
/**
* (c) Copyright 2020 IBM Corporation
* 1 New Orchard Road,
* Armonk, New York, 10504-1722
* United States
* +1 914 499 1900
* support: Nathaniel Mills [email protected]
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package com.mdfromhtml.core;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Date;
/**
* Utility class for durations in time.
*
* @author wnm3
*/
public class MDfromHTMLDuration
implements Serializable, Comparable {
// --------
// statics
// --------
static final public String m_strClassName = MDfromHTMLUtils
.getNameFromClass(MDfromHTMLDuration.class);
private static final long serialVersionUID = 2151322379607630650L;
/**
* An undefined version of this object. An undefinedMDfromHTMLDuration has
* an undefined name.
*
* @see MDfromHTMLUtils#isUndefined(String)
*/
static public MDfromHTMLDuration UNDEFINED_MDfromHTMLDuration = new MDfromHTMLDuration();
/**
* Calculate the number of elapsed days between the start and end of this
* duration. If no end date has been set, then the duration is 0L. If no
* start date has been set, then the duration is the number of days since
* the epoch (midnight 1/1/70 GMT) until the end date. If the start date is
* greater than the end date, then 0L is returned.
*
* @param dateStart
* the start date of the duration
* @param dateEnd
* the end date of the duration
* @return the number of elapsed days between the start and end of this
* duration.
*/
static public long elapsedDays(Date dateStart, Date dateEnd) {
long lElapsedTime = elapsedHours(dateStart, dateEnd);
lElapsedTime /= 24L;
return lElapsedTime;
}
/**
* Calculate the number of elapsed hours between the start and end of this
* duration. If no end date has been set, then the duration is 0L. If no
* start date has been set, then the duration is the number of hours since
* the epoch (midnight 1/1/70 GMT) until the end date. If the start date is
* greater than the end date, then 0L is returned.
*
* @param dateStart
* the start date of the duration
* @param dateEnd
* the end date of the duration
* @return the number of elapsed hours between the start and end of this
* duration.
*/
static public long elapsedHours(Date dateStart, Date dateEnd) {
long lElapsedTime = elapsedMinutes(dateStart, dateEnd);
lElapsedTime /= 60L;
return lElapsedTime;
}
/**
* Calculate the number of elapsed minutes between the start and end of this
* duration. If no end date has been set, then the duration is 0L. If no
* start date has been set, then the duration is the number of minutes since
* the epoch (midnight 1/1/70 GMT) until the end date. If the start date is
* greater than the end date, then 0L is returned.
*
* @param dateStart
* the start date of the duration
* @param dateEnd
* the end date of the duration
* @return the number of elapsed minutes between the start and end of this
* duration.
*/
static public long elapsedMinutes(Date dateStart, Date dateEnd) {
long lElapsedTime = elapsedSeconds(dateStart, dateEnd);
lElapsedTime /= 60L;
return lElapsedTime;
}
/**
* Calculate the number of elapsed seconds between the start and end of this
* duration. If no end date has been set, then the duration is 0L. If no
* start date has been set, then the duration is the number of seconds since
* the epoch (midnight 1/1/70 GMT) until the end date. If the start date is
* greater than the end date, then 0L is returned.
*
* @param dateStart
* the start date of the duration
* @param dateEnd
* the end date of the duration
* @return the number of elapsed seconds between the start and end of this
* duration.
*/
static public long elapsedSeconds(Date dateStart, Date dateEnd) {
long lElapsedTime = elapsedTime(dateStart, dateEnd);
lElapsedTime /= 1000L;
return lElapsedTime;
}
/**
* Calculate the number of elapsed milliseconds between the start and end of
* this duration. If no end date has been set, then the duration is 0L. If
* no start date has been set, then the duration is the number of
* milliseconds since the epoch (midnight 1/1/70 GMT) until the end date. If
* the start date is greater than the end date, then the negative of the
* elapsed time from the end date to the start date is returned.
*
* @param dateStart
* the start date of the duration
* @param dateEnd
* the end date of the duration
* @return the number of elapsed milliseconds between the start and end of
* this duration.
*/
static public long elapsedTime(Date dateStart, Date dateEnd) {
dateStart = MDfromHTMLUtils.undefinedForNull(dateStart);
dateEnd = MDfromHTMLUtils.undefinedForNull(dateEnd);
if (MDfromHTMLDate.isUndefined(dateEnd) == true) {
return 0L;
}
if (MDfromHTMLDate.isUndefined(dateStart) == true) {
return dateEnd.getTime();
}
if (dateStart.compareTo(dateEnd) > 0) {
return 0L - elapsedTime(dateEnd, dateStart);
}
return dateEnd.getTime() - dateStart.getTime();
}
static public String formattedElapsedTime(Date dateStart, Date dateEnd) {
long lElapsedMS = elapsedTime(dateStart, dateEnd);
return formattedElapsedTime(lElapsedMS);
}
static public String formattedElapsedTime(double dElapsedSeconds) {
long lElapsedMS = (long) (dElapsedSeconds * 1000L);
return formattedElapsedTime(lElapsedMS);
}
static public String formattedElapsedTime(long lElapsedMS) {
String strSign = MDfromHTMLConstants.EMPTY_String;
if (lElapsedMS < 0L) {
strSign = "-";
lElapsedMS = -lElapsedMS;
}
long lElapsedMilli = lElapsedMS % 1000;
lElapsedMS /= 1000;
StringBuffer sb = new StringBuffer();
long lDays = lElapsedMS / 86400;
lElapsedMS = lElapsedMS % 86400;
long lHours = lElapsedMS / 3600;
lElapsedMS = lElapsedMS % 3600;
long lMinutes = lElapsedMS / 60;
lElapsedMS = lElapsedMS % 60;
if (MDfromHTMLUtils.isEmpty(strSign) == false) {
sb.append("-");
}
sb.append(lDays);
sb.append("-");
sb.append(MDfromHTMLUtils.padLeftZero((int) lHours, 2));
sb.append(":");
sb.append(MDfromHTMLUtils.padLeftZero((int) lMinutes, 2));
sb.append(":");
sb.append(MDfromHTMLUtils.padLeftZero((int) lElapsedMS, 2));
sb.append(".");
sb.append(MDfromHTMLUtils.padLeftZero((int) lElapsedMilli, 3));
return sb.toString();
}
public static void main(String[] args) {
try {
String strBirthday = MDfromHTMLUtils.prompt(
"Enter your birthday in the form: YYYY/MM/DD-hh:mm:ss.SSS(ZZZ):");
if (strBirthday == null || strBirthday.length() == 0) {
strBirthday = "1957/08/04-07:15:00.000(EDT)";
}
MDfromHTMLDuration dur = new MDfromHTMLDuration("Birthday",
new MDfromHTMLDate(strBirthday), new MDfromHTMLDate());
String strTimeZone = MDfromHTMLUtils.prompt(
"Enter the output timezone (e.g., -0500 for EST or +0000 for GMT):");
System.out.println(dur.toString(strTimeZone));
MDfromHTMLDuration negdur = new MDfromHTMLDuration("Reverse",
dur.getEndDate(), dur.getStartDate());
System.out.println(negdur.toString(strTimeZone));
} catch (Exception aer) {
aer.printStackTrace();
}
System.out.println("Goodbye");
}
/**
* Create anMDfromHTMLDuration from the passed list string.
*
* @param listString
* the list of String fields needed to create
* anMDfromHTMLDuration (name, start date, end date);
* @return a newly createdMDfromHTMLDuration object filled with the content
* of the supplied listString. If the listString is null or empty,
* or does not contain at least the name field, an
* undefinedMDfromHTMLDuration is returned.
* @throws Exception
* if listString is null or empty, or if the name in the list is
* null, empty or undefined.
* @see #isUndefined()
*/
static public MDfromHTMLDuration newInstanceFromListString(
String listString) throws Exception {
if (listString == null || listString.length() == 0) {
throw new Exception("String listString is null or empty.");
}
MDfromHTMLDuration duration = MDfromHTMLDuration.UNDEFINED_MDfromHTMLDuration;
ArrayList
© 2015 - 2025 Weber Informatics LLC | Privacy Policy