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

com.versionone.Duration Maven / Gradle / Ivy

package com.versionone;

import com.versionone.utils.HashCode;

/**
 * Class representing some duration of time
 */
public class Duration {

	/**
	 * Valid units for Duration
	 */
	public enum Unit {
		Days, Weeks, Months
	}

	private int _amount;
	private Unit _units;

	/**
	 * Default constructor
	 * sets duration to 0 days
	 */
	public Duration() {
		this(0, Unit.Days);
	}

	/**
	 * Create from amount and unit
	 * @param amount - amount value for this instance
	 * @param units  - unit value for this instance
	 */
	public Duration(int amount, Unit units) {
		_units = units;
		setAmount(amount);
	}
	
	/**
	 * Create instance from a String 
	 * Expected format is "%d {Unit}" for example "3 Days" (without the quotes)
	 * 
	 * @param value - string value used to set amount and unit
	 * @throws IllegalArgumentException if thre is an error in parsing the value
	 */
	public Duration(String value) {
		this(0, Unit.Days);
		if ((value == null || value.length() == 0)) {
			return;
		}
		try {
			String[] parts = value.split(" ");
			setAmount(Integer.parseInt(parts[0]));
			if (_amount != 0)
				_units = Unit.valueOf(parts[1]);
		} catch (Exception e) {
			throw new IllegalArgumentException("Not a valid Duration: " + value, e);
		}
	}
	
	/**
	 * return the amount specified by this Duration
	 * @return integer 
	 */
	public int getAmount() {
		return _amount;
	}

	/**
	 * return the units specified by this Duration
	 * @return Unit
	 */
	public Unit getUnits() {
		return _units;
	}

	/**
	 * Get amount of this Duration in days 
	 * @return int
	 */
	public int getDays() {
		switch (_units) {
		case Days:
			return _amount;
		case Weeks:
			return _amount * 7;
		case Months:
			if (_amount <= 1)
				return _amount * 30;
			else if (_amount < 12)
				return (_amount * 61) / 2;
			else
				return (_amount * 365) / 12;
		default:
			throw new UnsupportedOperationException();
		}
	}

	/**
	 * Compare two Duration instances
	 * 
	 * @param a - one instance
	 * @param b - the other instance
	 * @return true if they are equal, false otherwise
	 */
	public static boolean compare(Duration a, Duration b) {
		if (null == a || null == b)
			return (null == a) && (null == b);
		return a.equals(b);
	}

	/**
	 * Create a Duration from a String
	 * 
	 * @param value - string used to create
	 * @return an instance of Duration with value set from string
	 * @see #Duration(String)
	 */
	public static Duration parse(String value) {
		return new Duration(value);
	}

	/**
	 * Convert this instance to it's string representation (%d {Unit}) 
	 */
	@Override
	public String toString() {
		return _amount + " " + _units.toString();
	}

	/**
	 * Compare this instance to another Duration
	 * 
	 * @return true if they are equal, false otherwise
	 */
	@Override
	public boolean equals(Object obj) {
		boolean rc = false;
		if ((obj != null) && (obj instanceof Duration)) {
			Duration other = (Duration) obj;
			rc = (_amount == other.getAmount()) && (_units == other.getUnits());
		}
		return rc;
	}

	/**
	 * Get the hash code for this instance
	 */
	@Override
	public int hashCode() {
		return HashCode.Hash(_amount, _units);
	}
	
	private void setAmount(int amount) {
		if (amount < 0) {
			throw new IllegalArgumentException("Amount must be non-negative");
		}
		_amount = amount;
		if (amount == 0)
			_units = Unit.Days;
	}	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy