NetworkDNS/src-wip/org/xbill/DNS2/clients/Serial.java

75 lines
2.1 KiB
Java
Executable File

// Copyright (c) 2003-2004 Brian Wellington (bwelling@xbill.org)
package org.xbill.DNS2.clients;
/**
* Helper functions for doing serial arithmetic. These should be used when
* setting/checking SOA serial numbers. SOA serial number arithmetic is
* defined in RFC 1982.
*
* @author Brian Wellington
*/
public final
class Serial {
private static final long MAX32 = 0xFFFFFFFFL;
private
Serial() {
}
/**
* Compares two numbers using serial arithmetic. The numbers are assumed
* to be 32 bit unsigned integers stored in longs.
*
* @param serial1 The first integer
* @param serial2 The second integer
*
* @return 0 if the 2 numbers are equal, a positive number if serial1 is greater
* than serial2, and a negative number if serial2 is greater than serial1.
*
* @throws IllegalArgumentException serial1 or serial2 is out of range
*/
public static
int compare(long serial1, long serial2) {
if (serial1 < 0 || serial1 > MAX32) {
throw new IllegalArgumentException(serial1 + " out of range");
}
if (serial2 < 0 || serial2 > MAX32) {
throw new IllegalArgumentException(serial2 + " out of range");
}
long diff = serial1 - serial2;
if (diff >= MAX32) {
diff -= (MAX32 + 1);
}
else if (diff < -MAX32) {
diff += (MAX32 + 1);
}
return (int) diff;
}
/**
* Increments a serial number. The number is assumed to be a 32 bit unsigned
* integer stored in a long. This basically adds 1 and resets the value to
* 0 if it is 2^32.
*
* @param serial The serial number
*
* @return The incremented serial number
*
* @throws IllegalArgumentException serial is out of range
*/
public static
long increment(long serial) {
if (serial < 0 || serial > MAX32) {
throw new IllegalArgumentException(serial + " out of range");
}
if (serial == MAX32) {
return 0;
}
return serial + 1;
}
}