public abstract class IPAddressSegment extends IPAddressDivision implements AddressSegment
Modifier and Type | Method and Description |
---|---|
static int |
getBitCount(IPAddress.IPVersion version) |
static int |
getByteCount(IPAddress.IPVersion version) |
static int |
getDefaultTextualRadix(IPAddress.IPVersion version) |
long |
getDivisionValueCount() |
abstract IPAddress.IPVersion |
getIPVersion() |
abstract java.lang.Iterable<? extends IPAddressSegment> |
getIterable()
Useful for using an instance in a "for-each loop".
|
abstract IPAddressSegment |
getLower()
If this segment represents a range of values, returns a segment representing just the lowest value in the range, otherwise returns this.
|
int |
getLowerSegmentValue()
returns the lower value
|
long |
getLowerValue()
returns the lower value as a long, although for individual segments
getLowerSegmentValue() provides the same value as an int |
static int |
getMaxSegmentValue(IPAddress.IPVersion version) |
long |
getMaxValue() |
int |
getMinPrefixLengthForBlock() |
abstract IPAddressNetwork<?,?,?,?,?> |
getNetwork() |
int |
getPrefixValueCount()
Counts the number of prefixes in this address segment.
|
java.lang.Integer |
getSegmentPrefixLength() |
abstract IPAddressSegment |
getUpper()
If this segment represents a range of values, returns a segment representing just the highest value in the range, otherwise returns this.
|
int |
getUpperSegmentValue()
returns the upper value
|
long |
getUpperValue()
returns the lower upper value as a long, although for individual segments
getUpperSegmentValue() provides the same value as an int |
int |
getValueCount() |
int |
hashCode() |
boolean |
includesMax() |
boolean |
includesZero() |
boolean |
isBitwiseOrCompatibleWithRange(int maskValue,
java.lang.Integer segmentPrefixLength)
Similar to masking, checks that the range resulting from the bitwise or is contiguous.
|
boolean |
isBoundedBy(int value)
Returns true if the possible values of this division fall below the given value.
|
boolean |
isIPv4() |
boolean |
isIPv6() |
boolean |
isMaskCompatibleWithRange(int maskValue,
java.lang.Integer segmentPrefixLength)
Check that the range resulting from the mask is contiguous, otherwise we cannot represent it.
|
boolean |
isMultiple()
Whether this represents multiple potential values (eg a prefixed address or a segment representing a range of values)
|
boolean |
isPrefixBlock()
Returns whether the division range includes the block of values for its prefix length
|
abstract java.util.Iterator<? extends IPAddressSegment> |
iterator()
Iterates through the individual elements of this address component.
|
boolean |
matches(int value) |
boolean |
matchesWithMask(int value,
int mask) |
boolean |
matchesWithMask(int lowerValue,
int upperValue,
int mask) |
boolean |
matchesWithPrefixMask(int value,
java.lang.Integer segmentPrefixLength) |
abstract java.util.Iterator<? extends IPAddressSegment> |
prefixBlockIterator()
Iterates through the individual prefix blocks.
|
abstract IPAddressSegment |
removePrefixLength() |
abstract IPAddressSegment |
removePrefixLength(boolean zeroed) |
abstract IPAddressSegment |
reverseBits(boolean perByte)
Returns a new AddressComponent with the bits reversed.
|
abstract IPAddressSegment |
reverseBytes()
Returns an AddressComponent with the bytes reversed.
|
java.lang.String |
toHexString(boolean with0xPrefix)
Writes this address component as a single hexadecimal value with always the exact same number of characters, with or without a preceding 0x prefix.
|
abstract IPAddressSegment |
toHostSegment(java.lang.Integer segmentPrefixLength)
used by getHostSection, see
IPAddressSegmentSeries.getHostSection(int) |
IPAddressSegment |
toNetworkSegment(java.lang.Integer segmentPrefixLength)
used by constructors of IPAddressSection, see
IPAddressSegmentSeries.getNetworkSection(int, boolean) |
abstract IPAddressSegment |
toNetworkSegment(java.lang.Integer segmentPrefixLength,
boolean withPrefixLength)
used by getNetworkSection and by constructors of IPAddressSection, see
IPAddressSegmentSeries.getNetworkSection(int, boolean) |
java.lang.String |
toNormalizedString()
Produces a string that is somewhat similar for all address components of the same type.
|
java.lang.String |
toNormalizedString(IPAddressSection.IPStringOptions options) |
getBlockMaskPrefixLength, getDivisionPrefixLength, getPrefixAdjustedRangeString, getString, getWildcardString, isPrefixBlock, isPrefixed, isSinglePrefixBlock, isSinglePrefixBlock, matchesWithPrefixMask
compareTo, getCount, getDigitCount, getDivisionPrefixCount, getMaxDigitCount, hasUppercaseVariations, isFullRange, isMax, isZero, matches, matchesWithMask, matchesWithMask
getBytes, getBytes, getDefaultTextualRadix, getDigitCount, getLowerStandardString, getMaxDigitCount, getStandardString, getUpperBytes, getUpperBytes, toString
contains, equals, getMaxSegmentValue
getByteCount
getBitCount, getBytes, getBytes, getCount, getUpperBytes, getUpperBytes, isFullRange, isMax, isZero
getBitCount, isFullRange
getDigitCount, getLowerStandardString, getMaxDigitCount, getStandardString
public abstract IPAddressNetwork<?,?,?,?,?> getNetwork()
getNetwork
in interface AddressSegment
public boolean isIPv4()
public boolean isIPv6()
public abstract IPAddress.IPVersion getIPVersion()
public int getMinPrefixLengthForBlock()
public static int getMaxSegmentValue(IPAddress.IPVersion version)
public boolean isPrefixBlock()
IPAddressStringDivision
isPrefixBlock
in interface IPAddressStringDivision
isPrefixBlock
in class IPAddressDivision
public IPAddressSegment toNetworkSegment(java.lang.Integer segmentPrefixLength)
IPAddressSegmentSeries.getNetworkSection(int, boolean)
public abstract IPAddressSegment toNetworkSegment(java.lang.Integer segmentPrefixLength, boolean withPrefixLength)
IPAddressSegmentSeries.getNetworkSection(int, boolean)
public abstract IPAddressSegment toHostSegment(java.lang.Integer segmentPrefixLength)
IPAddressSegmentSeries.getHostSection(int)
public boolean isMaskCompatibleWithRange(int maskValue, java.lang.Integer segmentPrefixLength) throws PrefixLenException
maskValue
- segmentPrefixLength
- PrefixLenException
public boolean isBitwiseOrCompatibleWithRange(int maskValue, java.lang.Integer segmentPrefixLength) throws PrefixLenException
maskValue
- segmentPrefixLength
- PrefixLenException
public abstract IPAddressSegment getLower()
getLower
in interface AddressComponent
getLower
in interface AddressSegment
public abstract IPAddressSegment getUpper()
getUpper
in interface AddressComponent
getUpper
in interface AddressSegment
public abstract java.lang.Iterable<? extends IPAddressSegment> getIterable()
AddressComponent
AddressComponent.iterator()
directly.getIterable
in interface AddressComponent
getIterable
in interface AddressSegment
public abstract java.util.Iterator<? extends IPAddressSegment> iterator()
AddressComponent
An address component can represent a single segment, address, or section, or it can represent multiple, typically a subnet or range of segment, address, or section values.
Call AddressItem.isMultiple()
to determine if this instance represents multiple.
iterator
in interface AddressComponent
iterator
in interface AddressSegment
public abstract java.util.Iterator<? extends IPAddressSegment> prefixBlockIterator()
iterator()
public static int getBitCount(IPAddress.IPVersion version)
public static int getByteCount(IPAddress.IPVersion version)
public static int getDefaultTextualRadix(IPAddress.IPVersion version)
public boolean matches(int value)
matches
in interface AddressSegment
public boolean matchesWithPrefixMask(int value, java.lang.Integer segmentPrefixLength)
public boolean matchesWithMask(int value, int mask)
matchesWithMask
in interface AddressSegment
public boolean matchesWithMask(int lowerValue, int upperValue, int mask)
matchesWithMask
in interface AddressSegment
public int getValueCount()
getValueCount
in interface AddressSegment
AddressItem.getCount()
as an integerpublic int getPrefixValueCount()
If this segment has no prefix length, this is equivalent to getValueCount()
public long getDivisionValueCount()
getDivisionValueCount
in class AddressDivision
public long getMaxValue()
getMaxValue
in class AddressDivision
public boolean isMultiple()
AddressItem
isMultiple
in interface AddressItem
isMultiple
in class AddressDivision
public int getLowerSegmentValue()
getLowerSegmentValue
in interface AddressSegment
public int getUpperSegmentValue()
getUpperSegmentValue
in interface AddressSegment
public long getLowerValue()
getLowerSegmentValue()
provides the same value as an intgetLowerValue
in class AddressDivision
public long getUpperValue()
getUpperSegmentValue()
provides the same value as an intgetUpperValue
in class AddressDivision
public abstract IPAddressSegment reverseBits(boolean perByte)
AddressComponent
IncompatibleAddressException
. In a range the most significant bits stay constant
while the least significant bits range over different values, so reversing that scenario results in a series of non-consecutive values, in most cases,
which cannot be represented with a single AddressComponent object.
In such cases where isMultiple() is true, call iterator(), getLower(), getUpper() or some other methods to break the series down into a series representing a single value.
reverseBits
in interface AddressComponent
reverseBits
in interface AddressSegment
perByte
- if true, only the bits in each byte are reversed, if false, then all bits in the component are reversedpublic abstract IPAddressSegment reverseBytes()
AddressComponent
IncompatibleAddressException
. In a range the most significant bits stay constant
while the least significant bits range over different values, so reversing that scenario results in a series of non-consecutive values, in most cases,
which cannot be represented with a single AddressComponent object.
In such cases where isMultiple() is true, call iterator(), getLower(), getUpper() or some other methods to break the series down into a series representing a single value.
reverseBytes
in interface AddressComponent
reverseBytes
in interface AddressSegment
public abstract IPAddressSegment removePrefixLength()
public abstract IPAddressSegment removePrefixLength(boolean zeroed)
public boolean isBoundedBy(int value)
AddressDivision
isBoundedBy
in interface AddressStringDivision
isBoundedBy
in class AddressDivision
public java.lang.Integer getSegmentPrefixLength()
public int hashCode()
hashCode
in class java.lang.Object
public boolean includesZero()
includesZero
in interface AddressItem
includesZero
in class AddressDivision
public boolean includesMax()
includesMax
in interface AddressItem
includesMax
in class AddressDivision
public java.lang.String toHexString(boolean with0xPrefix)
AddressComponent
If this component represents a range of values outside of the network prefix length, then this is printed as a range of two hex values.
For instance, for IPv4 addresses there are 8 hex characters, for IPv6 addresses there are 32 hex characters.
toHexString
in interface AddressComponent
public java.lang.String toNormalizedString()
AddressComponent
toNormalizedString
in interface AddressComponent
public java.lang.String toNormalizedString(IPAddressSection.IPStringOptions options)