All Downloads are FREE. Search and download functionalities are using the official Maven repository.

inet.ipaddr.AddressSegment Maven / Gradle / Ivy

There is a newer version: 5.5.1
Show newest version
/*
 * Copyright 2016-2018 Sean C Foley
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *     or at
 *     https://github.com/seancfoley/IPAddress/blob/master/LICENSE
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package inet.ipaddr;


import java.util.Iterator;
import java.util.stream.Stream;

import inet.ipaddr.format.AddressGenericDivision;
import inet.ipaddr.format.util.AddressComponentSpliterator;

/**
 * Represents a single segment of an address.
 * 

* The current implementations of this class are the most common representations of IPv4, IPv6 and MAC; * segments are 1 byte for Ipv4, they are two bytes for Ipv6, and they are 1 byte for MAC addresses. *

* There are alternative forms of dividing addresses into divisions, such as the dotted representation for MAC like 1111.2222.3333, * the embedded IPv4 representation for IPv6 like f:f:f:f:f:f:1.2.3.4, the inet_aton formats like 1.2 for IPv4, and so on. *

* If those alternative representations were to follow the general rules for segment representation, then you could reuse this class * for those alternative representations. *

* The general rules are that segments have a whole number of bytes, and in a given address all segments have the same length. *

* When alternatives forms do not follow the general rules for segments, * you can use the {@link inet.ipaddr.format.standard.AddressDivision} interface instead. * Divisions do not have the restriction that divisions of an address are equal length and a whole number of bytes. * Divisions can be grouped using {@link inet.ipaddr.format.standard.AddressDivisionGrouping}. *

* AddressSegment objects are immutable and thus also thread-safe. * * @author sfoley * */ public interface AddressSegment extends AddressComponent, AddressGenericDivision { /** * Returns the count of values in this address segment. * * @return the same value as {@link #getCount()} as an integer */ int getValueCount(); /** * Returns the count of prefix values in this address segment for the given prefix bit count. * * @return the count of values */ int getPrefixValueCount(int segmentPrefixLength); /** * returns the lower value */ int getSegmentValue(); /** * returns the upper value */ int getUpperSegmentValue(); /** * If this segment represents a range of values, returns a segment representing just the lowest value in the range, otherwise returns this. * @return */ @Override AddressSegment getLower(); /** * If this segment represents a range of values, returns a segment representing just the highest value in the range, otherwise returns this. * @return */ @Override AddressSegment getUpper(); @Override AddressSegment reverseBits(boolean perByte); @Override AddressSegment reverseBytes(); @Override Iterable getIterable(); @Override Iterator iterator(); @Override AddressComponentSpliterator spliterator(); @Override Stream stream(); boolean matches(int value); boolean matchesWithMask(int value, int mask); boolean matchesWithMask(int lowerValue, int upperValue, int mask); boolean contains(AddressSegment other); @Override boolean equals(Object other); /** * Returns whether the given prefix bits match the same bits of the given segment. * * @param other * @param prefixLength * @return */ boolean prefixEquals(AddressSegment other, int prefixLength); /** * Analogous to {@link java.math.BigInteger#testBit}, * Computes (this & (1 << n)) != 0), using the lower value of this segment. * * @see AddressSegmentSeries#testBit(int) * @see #isOneBit(int) * * @throws IndexOutOfBoundsException if the index is negative or as large as the bit count * * @param n * @return */ default boolean testBit(int n) { int value = getSegmentValue(); int bitCount = getBitCount(); if(n < 0 || n >= bitCount) { throw new IndexOutOfBoundsException(); } return (value & (1 << n)) != 0; } /** * Returns true if the bit in the lower value of this segment at the given index is 1, where index 0 is the most significant bit. * * @see AddressSegmentSeries#isOneBit(int) * @see #testBit(int) * * @throws IndexOutOfBoundsException if the index is negative or as large as the bit count * * @param segmentBitIndex * @return */ default boolean isOneBit(int segmentBitIndex) { int value = getSegmentValue(); int bitCount = getBitCount(); if(segmentBitIndex < 0 || segmentBitIndex >= bitCount) { throw new IndexOutOfBoundsException(); } return (value & (1 << (bitCount - (segmentBitIndex + 1)))) != 0; } /** * Gets the maximum possible value for this type of segment (for the highest range value of this particular segment, use {@link #getUpper()} * * @return */ int getMaxSegmentValue(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy