* @return An Ipv4Address object
*/
public final @NonNull A4 ipv4AddressFor(final int bits) {
- return address4Factory.newInstance(addressString(bits));
+ return address4Factory.newInstance(Ipv4Utils.addressString(bits));
}
/**
* @return An Ipv4AddressNoZone object
*/
public final @NonNull A4NZ ipv4AddressNoZoneFor(final int bits) {
- return address4NoZoneFactory.newInstance(addressString(bits));
+ return address4NoZoneFactory.newInstance(Ipv4Utils.addressString(bits));
}
public final @NonNull A4 ipv4AddressFrom(final @NonNull P4 prefix) {
*/
final String str = ipv4AddressString(addr);
final int percent = str.indexOf('%');
- return ipv4StringBytes(str, percent == -1 ? str.length() : percent);
+ return Ipv4Utils.addressBytes(str, percent == -1 ? str.length() : percent);
}
public final int ipv4AddressBits(final @NonNull A4 addr) {
final String str = ipv4AddressString(addr);
final int percent = str.indexOf('%');
- return ipv4StringBits(str, percent == -1 ? str.length() : percent);
+ return Ipv4Utils.addressBits(str, percent == -1 ? str.length() : percent);
}
public final byte @NonNull[] ipv4AddressNoZoneBytes(final @NonNull A4NZ addr) {
* the Ipv4AddressNoZone pattern, which must not include a zone index.
*/
final String str = ipv4AddressString(addr);
- return ipv4StringBytes(str, str.length());
+ return Ipv4Utils.addressBytes(str, str.length());
}
public final int ipv4AddressNoZoneBits(final @NonNull A4NZ addr) {
final String str = ipv4AddressString(addr);
- return ipv4StringBits(str, str.length());
- }
-
- private static byte @NonNull[] ipv4StringBytes(final String str, final int limit) {
- final byte[] bytes = new byte[INET4_LENGTH];
- Ipv4Utils.fillIpv4Bytes(bytes, 0, str, 0, limit);
- return bytes;
- }
-
- private static int ipv4StringBits(final String str, final int limit) {
- int prev = 0;
- int current = 0;
- for (int i = 0, shift = 24; i < limit; ++i) {
- final char c = str.charAt(i);
- if (c == '.') {
- prev |= current << shift;
- shift -= 8;
- current = 0;
- } else {
- current = 10 * current + c - '0';
- }
- }
- return prev | current;
+ return Ipv4Utils.addressBits(str, str.length());
}
/**
}
}
- private static String addressString(final int bits) {
- return new StringBuilder(15)
- .append(bits >>> 24).append('.')
- .append(bits >>> 16 & 0xFF).append('.')
- .append(bits >>> 8 & 0xFF).append('.')
- .append(bits & 0xFF)
- .toString();
- }
-
static String addressStringV4(final byte @NonNull[] bytes) {
final StringBuilder sb = new StringBuilder(15);
appendIpv4String(sb, bytes);
return quadFactory.newInstance(AbstractIetfInetUtil.addressStringV4(bytes));
}
- public final byte @NonNull[] dottedQuadBytes(final @NonNull Q hexString) {
- final String str = getQuadValue(hexString);
- final byte[] bytes = new byte[4];
- Ipv4Utils.fillIpv4Bytes(bytes, 0, str, 0, str.length());
- return bytes;
+ public final @NonNull Q dottedQuadFor(final int bits) {
+ return quadFactory.newInstance(Ipv4Utils.addressString(bits));
+ }
+
+ public final int dottedQuadBits(final @NonNull Q dottedQuad) {
+ final String str = getQuadValue(dottedQuad);
+ return Ipv4Utils.addressBits(str, str.length());
+ }
+
+ public final byte @NonNull[] dottedQuadBytes(final @NonNull Q dottedQuad) {
+ final String str = getQuadValue(dottedQuad);
+ return Ipv4Utils.addressBytes(str, str.length());
}
public final @NonNull U uuidFor(final @NonNull UUID uuid) {
bytes[out] = (byte) val;
}
+
+ static int addressBits(final String str, final int limit) {
+ int prev = 0;
+ int current = 0;
+ for (int i = 0, shift = 24; i < limit; ++i) {
+ final char c = str.charAt(i);
+ if (c == '.') {
+ prev |= current << shift;
+ shift -= 8;
+ current = 0;
+ } else {
+ current = 10 * current + c - '0';
+ }
+ }
+ return prev | current;
+ }
+
+ static byte @NonNull[] addressBytes(final String str, final int limit) {
+ final byte[] bytes = new byte[4];
+ Ipv4Utils.fillIpv4Bytes(bytes, 0, str, 0, limit);
+ return bytes;
+ }
+
+ static String addressString(final int bits) {
+ return new StringBuilder(15)
+ .append(bits >>> 24).append('.')
+ .append(bits >>> 16 & 0xFF).append('.')
+ .append(bits >>> 8 & 0xFF).append('.')
+ .append(bits & 0xFF)
+ .toString();
+ }
}
assertArrayEquals(new byte[] { (byte) 0xaa, (byte) 0xbb }, UTIL.physAddressBytes(new PhysClass("aa:bb")));
}
+ @Test
+ public void testQuadBits() {
+ assertEquals(0x01020304, UTIL.dottedQuadBits(new QuadClass("1.2.3.4")));
+ assertEquals(0xFFFFFFFF, UTIL.dottedQuadBits(new QuadClass("255.255.255.255")));
+ }
+
@Test
public void testQuadBytes() {
assertArrayEquals(new byte[] { 1, 2, 3, 4 }, UTIL.dottedQuadBytes(new QuadClass("1.2.3.4")));
}
@Test
- public void testQuadFor() {
+ public void testQuadForBits() {
+ assertEquals("1.2.3.4", UTIL.dottedQuadFor(0x01020304).getValue());
+ assertEquals("255.255.255.255", UTIL.dottedQuadFor(0xFFFFFFFF).getValue());
+ }
+
+ @Test
+ public void testQuadForBytes() {
assertEquals("1.2.3.4", UTIL.dottedQuadFor(new byte[] { 1, 2, 3, 4 }).getValue());
}