de.schlichtherle.truezip.zip.UInt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of truezip-driver-zip Show documentation
Show all versions of truezip-driver-zip Show documentation
The file system driver family for ZIP and related archive file types.
Add the JAR artifact of this module to the run time class path to
make its file system drivers available for service location in the
client API modules.
/*
* Copyright (C) 2005-2013 Schlichtherle IT Services.
* All rights reserved. Use is subject to license terms.
*/
package de.schlichtherle.truezip.zip;
import javax.annotation.CheckForNull;
import javax.annotation.concurrent.ThreadSafe;
/**
* Provides constants and static utility methods for unsigned integer
* values ({@value SIZE} bits).
*
* @author Christian Schlichtherle
*/
@ThreadSafe
final class UInt {
/**
* The minimum value of an unsigned integer,
* which is {@value MIN_VALUE}.
*/
public static final long MIN_VALUE = 0x00000000L;
/**
* The maximum value of an unsigned integer,
* which is {@value MAX_VALUE}.
*/
public static final long MAX_VALUE = 0xffffffffL;
/**
* The number of bits used to represent an unsigned integer in
* binary form, which is {@value SIZE}.
*/
public static final int SIZE = 32;
/** This class cannot get instantiated. */
private UInt() {
}
/**
* Checks the parameter range.
*
* @param l The long integer to check to be in the range of an unsigned
* integer ({@value SIZE} bits).
* @param subject The subject of the exception message
* - may be {@code null}.
* This should not end with a punctuation character.
* @param error First sentence of the exception message
* - may be {@code null}.
* This should not end with a punctuation character.
* @return {@code true}
* @throws IllegalArgumentException If {@code l} is less than
* {@link #MIN_VALUE} or greater than {@link #MAX_VALUE}.
*/
public static boolean check(
final long l,
final @CheckForNull String subject,
final @CheckForNull String error) {
if (MIN_VALUE <= l && l <= MAX_VALUE)
return true;
final StringBuilder message = new StringBuilder();
if (null != subject) {
message.append(subject);
message.append(": ");
}
if (null != error) {
message.append(error);
message.append(": ");
}
message.append(l);
message.append(" is not within ");
message.append(MIN_VALUE);
message.append(" and ");
message.append(MAX_VALUE);
message.append(" inclusive.");
throw new IllegalArgumentException(message.toString());
}
/**
* Checks the parameter range.
*
* @param l The long integer to check to be in the range of an unsigned
* integer ({@value SIZE} bits).
* @return {@code true}
* @throws IllegalArgumentException If {@code l} is less than
* {@link #MIN_VALUE} or greater than {@link #MAX_VALUE}.
*/
public static boolean check(final long l) {
return check(l, "Long integer out of range", null);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy