kv-3.5.2.src.com.sleepycat.je.utilint.PropUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of oracle-nosql-client Show documentation
Show all versions of oracle-nosql-client Show documentation
Oracle NoSQL Database Client - supplies build and runtime support for the client side of the Oracle NoSQL Database. Note that a running Oracle NoSQL Database Server (store) is required to do anything meaningful with this client.
/*-
*
* This file is part of Oracle NoSQL Database
* Copyright (C) 2011, 2015 Oracle and/or its affiliates. All rights reserved.
*
* If you have received this file as part of Oracle NoSQL Database the
* following applies to the work as a whole:
*
* Oracle NoSQL Database server software is free software: you can
* redistribute it and/or modify it under the terms of the GNU Affero
* General Public License as published by the Free Software Foundation,
* version 3.
*
* Oracle NoSQL Database is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Affero General Public License for more details.
*
* If you have received this file as part of Oracle NoSQL Database Client or
* distributed separately the following applies:
*
* Oracle NoSQL Database client software is free software: you can
* redistribute it and/or modify it under the terms of the Apache License
* as published by the Apache Software Foundation, version 2.0.
*
* You should have received a copy of the GNU Affero General Public License
* and/or the Apache License in the LICENSE file along with Oracle NoSQL
* Database client or server distribution. If not, see
*
* or
* .
*
* An active Oracle commercial licensing agreement for this product supersedes
* these licenses and in such case the license notices, but not the copyright
* notice, may be removed by you in connection with your distribution that is
* in accordance with the commercial licensing terms.
*
* For more information please contact:
*
* [email protected]
*
*/
package com.sleepycat.je.utilint;
import java.util.StringTokenizer;
import java.util.concurrent.TimeUnit;
/**
* Convenience methods for handling JE properties.
*/
public class PropUtil {
private static final long NS_IN_MS = 1000000;
private static final long NS_IN_SEC = 1000000000;
private static final long NS_IN_MINUTE = NS_IN_SEC * 60;
private static final long NS_IN_HOUR = NS_IN_MINUTE * 60;
/**
* Converts the given duration (interval value plus unit) to milliseconds,
* ensuring that any given value greater than zero converts to at least one
* millisecond to avoid a zero millisecond result, since Object.wait(0)
* waits forever.
*
* @throws IllegalArgumentException if the duration argument is illegal.
* Thrown via API setter methods such as Transaction.setLockTimeout.
*/
public static int durationToMillis(final long val, final TimeUnit unit) {
if (val == 0) {
/* Allow zero duration with null unit. */
return 0;
}
if (unit == null) {
throw new IllegalArgumentException
("Duration TimeUnit argument may not be null if interval " +
"is non-zero");
}
if (val < 0) {
throw new IllegalArgumentException
("Duration argument may not be negative: " + val);
}
final long newVal = unit.toMillis(val);
if (newVal == 0) {
/* Input val is positive, so return at least one. */
return 1;
}
if (newVal > Integer.MAX_VALUE) {
throw new IllegalArgumentException
("Duration argument may not be greater than " +
"Integer.MAX_VALUE milliseconds: " + newVal);
}
return (int) newVal;
}
/**
* Converts the given duration value in milliseconds to the given unit.
*
* @throws IllegalArgumentException if the unit is null. Thrown via API
* getter methods such as Transaction.getLockTimeout.
*/
public static long millisToDuration(final int val, final TimeUnit unit) {
if (unit == null) {
throw new IllegalArgumentException
("TimeUnit argument may not be null");
}
return unit.convert(val, TimeUnit.MILLISECONDS);
}
/**
* Parses a String duration property (time + optional unit) and returns the
* value in millis.
*
* @throws IllegalArgumentException if the duration string is illegal.
* Thrown via the Environment ctor and setMutableConfig, and likewise for a
* ReplicatedEnvironment.
*/
public static int parseDuration(final String property) {
long ns = parseDurationNS(property);
long millis = ns / NS_IN_MS;
/* If input val is positive, return at least one. */
if (ns > 0 && millis == 0) {
return 1;
}
if (millis > Integer.MAX_VALUE) {
throw new IllegalArgumentException(
"Duration argument may not be greater than " +
"Integer.MAX_VALUE milliseconds: " + property);
}
return (int)millis;
}
/**
* Parses a String duration property (time + optional unit) and returns the
* value in nanos.
*
* @throws IllegalArgumentException if the duration string is illegal.
* Thrown via the Environment ctor and setMutableConfig, and likewise for a
* ReplicatedEnvironment.
*/
public static long parseDurationNS(final String property) {
StringTokenizer tokens =
new StringTokenizer(property.toUpperCase(java.util.Locale.ENGLISH),
" \t");
if (!tokens.hasMoreTokens()) {
throw new IllegalArgumentException("Duration argument is empty");
}
final long time;
try {
time = Long.parseLong(tokens.nextToken());
} catch (NumberFormatException e) {
throw new IllegalArgumentException
("Duration argument does not start with a long integer: " +
property);
}
/* Convert time from specified unit to millis. */
long ns;
if (tokens.hasMoreTokens()) {
final String unitName = tokens.nextToken();
if (tokens.hasMoreTokens()) {
throw new IllegalArgumentException
("Duration argument has extra characters after unit: " +
property);
}
try {
final TimeUnit unit = TimeUnit.valueOf(unitName);
ns = TimeUnit.NANOSECONDS.convert(time, unit);
} catch (IllegalArgumentException e) {
try {
final IEEETimeUnit unit = IEEETimeUnit.valueOf(unitName);
ns = unit.toNanos(time);
} catch (IllegalArgumentException e2) {
throw new IllegalArgumentException
("Duration argument has unknown unit name: " +
property);
}
}
} else {
/* Default unit is micros. */
ns = TimeUnit.NANOSECONDS.convert(time, TimeUnit.MICROSECONDS);
}
/* If input val is positive, return at least one. */
if (time > 0 && ns == 0) {
return 1;
}
return ns;
}
/**
* Formats a String duration property (time + optional unit).
* value in millis.
*/
public static String formatDuration(long time, TimeUnit unit) {
return String.valueOf(time) + ' ' + unit.name();
}
/**
* Support for conversion of IEEE time units. Although names are defined
* in uppercase, we uppercase the input string before calling
* IEEETimeUnit.valueOf, in order to support input names in both upper and
* lower case.
*/
private enum IEEETimeUnit {
/* Nanoseconds */
NS() {
long toNanos(long val) {
return nanosUnit.convert(val, TimeUnit.NANOSECONDS);
}
},
/* Microseconds */
US() {
long toNanos(long val) {
return nanosUnit.convert(val, TimeUnit.MICROSECONDS);
}
},
/* Milliseconds */
MS() {
long toNanos(long val) {
return nanosUnit.convert(val, TimeUnit.MILLISECONDS);
}
},
/* Seconds */
S() {
long toNanos(long val) {
return nanosUnit.convert(val, TimeUnit.SECONDS);
}
},
/* Minutes */
MIN() {
long toNanos(long val) {
return val * NS_IN_MINUTE;
}
},
/* Hours */
H() {
long toNanos(long val) {
return val * NS_IN_HOUR;
}
};
private static final TimeUnit nanosUnit = TimeUnit.NANOSECONDS;
abstract long toNanos(long val);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy