All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ucar.nc2.units.TimeDuration Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 1998-2018 John Caron and University Corporation for Atmospheric Research/Unidata
 * See LICENSE for license information.
 */

package ucar.nc2.units;

import ucar.units.ConversionException;
import javax.xml.datatype.DatatypeFactory;
import javax.xml.datatype.Duration;
import java.util.Calendar;
import java.util.Date;

/**
 * Implements the thredds "duration" XML element type: specifies a length of time.
 * This is really the same as a ucar.nc2.units.TimeUnit, but it allows xsd:duration syntax as well as udunits syntax.
 * It also keeps track if the text is empty.
 * 

* A duration can be one of the following: *

    *
  1. a valid udunits string compatible with "secs" *
  2. an xsd:duration type specified in the following form "PnYnMnDTnHnMnS" where: *
      *
    • P indicates the period (required) *
    • nY indicates the number of years *
    • nM indicates the number of months *
    • nD indicates the number of days *
    • T indicates the start of a time section (required if you are going to specify hours, minutes, or seconds) *
    • nH indicates the number of hours *
    • nM indicates the number of minutes *
    • nS indicates the number of seconds *
    *
* * @author john caron * @see "https://www.unidata.ucar.edu/projects/THREDDS/tech/catalog/InvCatalogSpec.html#durationType" */ public class TimeDuration { private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(TimeDuration.class); /* * private static TimeUnit secUnits; * * static { * try { * secUnits = new TimeUnit("1 sec"); * } catch (Exception e) { * e.printStackTrace(); * } * } */ private String text; private TimeUnit timeUnit; private boolean isBlank; private static boolean debug; private TimeDuration() {} /** * Copy constructor. * * @param src copy this */ public TimeDuration(TimeDuration src) { text = src.getText(); timeUnit = new TimeUnit(src.getTimeUnit()); isBlank = src.isBlank(); } /** * Construct from a TimeUnit. * * @param timeUnit copy this */ public TimeDuration(TimeUnit timeUnit) { this.timeUnit = timeUnit; this.text = timeUnit.toString(); } /** * Construct from 1) udunit time unit string, 2) xsd:duration syntax, 3) blank string. * * @param text parse this text. * @throws java.text.ParseException if invalid text. */ public TimeDuration(String text) throws java.text.ParseException { text = (text == null) ? "" : text.trim(); this.text = text; // see if its blank LOOK WTF ? if (text.isEmpty()) { isBlank = true; try { timeUnit = new TimeUnit("1 sec"); } catch (Exception e) { // cant happen } return; } // see if its a udunits string try { timeUnit = new TimeUnit(text); if (debug) System.out.println(" set time unit= " + timeUnit); } catch (Exception e) { // see if its a xsd:duration try { DatatypeFactory factory = DatatypeFactory.newInstance(); Duration d = factory.newDuration(text); // long secs = d.getTimeInMillis(new Date()) / 1000; Calendar c = Calendar.getInstance(); c.set(1900, 0, 1, 0, 0, 0); long secs = d.getTimeInMillis(c.getTime()) / 1000; timeUnit = new TimeUnit(secs + " secs"); } catch (Exception e1) { throw new java.text.ParseException(e.getMessage(), 0); } } } /** * A time span as defined in the W3C XML Schema 1.0 specification: * "PnYnMnDTnHnMnS, where nY represents the number of years, nM the number of months, nD the number of days, * 'T' is the date/time separator, nH the number of hours, nM the number of minutes and nS the number of seconds. * The number of seconds can include decimal digits to arbitrary precision." * * @param text parse this text, format PnYnMnDTnHnMnS * @return TimeDuration * @throws java.text.ParseException when text is misformed */ public static TimeDuration parseW3CDuration(String text) throws java.text.ParseException { TimeDuration td = new TimeDuration(); text = (text == null) ? "" : text.trim(); td.text = text; try { DatatypeFactory factory = DatatypeFactory.newInstance(); Duration d = factory.newDuration(text); // long secs = d.getTimeInMillis(new Date()) / 1000; Calendar c = Calendar.getInstance(); c.set(1900, 0, 1, 0, 0, 0); long secs = d.getTimeInMillis(c.getTime()) / 1000; td.timeUnit = new TimeUnit(secs + " secs"); } catch (Exception e) { throw new java.text.ParseException(e.getMessage(), 0); } return td; } /** * Get the duration in natural units, ie units of getTimeUnit() * * @return the duration in natural units */ public double getValue() { return timeUnit.getValue(); } /** * Get the time duration in a specified unit of time. * * @param want in these units * @return the duration in units * @throws ucar.units.ConversionException is specified unit is not compatible with time */ public double getValue(TimeUnit want) throws ConversionException { return timeUnit.convertTo(timeUnit.getValue(), want); } public double getValue(String unit) { try { TimeUnit tdayUnit = new TimeUnit(unit); return getValue(tdayUnit); } catch (Exception e) { log.error("Illegal time unit = {}", unit, e); return -1; } } /** * Get the duration in seconds * * @return the duration in seconds */ public double getValueInSeconds() { return timeUnit.getValueInSeconds(); } /** * Set the duration in seconds * * @param secs the duration in seconds */ public void setValueInSeconds(double secs) { timeUnit.setValueInSeconds(secs); text = null; } /** * If this is a blank string * * @return true if this is a blank string */ public boolean isBlank() { return isBlank; } /** * Get the corresponding time unit * * @return the corresponding time unit */ public TimeUnit getTimeUnit() { return timeUnit; } /** * Get the String text * * @return the text */ public String getText() { return text == null ? timeUnit.toString() : text; } /** * String representation * * @return getText() */ public String toString() { return getText(); } /** * Override to be consistent with equals */ public int hashCode() { return isBlank() ? 0 : (int) getValueInSeconds(); } /** * TimeDurations with same value in seconds are equals */ public boolean equals(Object o) { if (this == o) return true; if (!(o instanceof TimeDuration)) return false; TimeDuration to = (TimeDuration) o; return to.getValueInSeconds() == getValueInSeconds(); } public Date add(Date d) { return timeUnit.add(d); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy