/*
 * Copyright 2012 The Netty Project
 *
 * The Netty Project licenses this file to you 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
 *
 * 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 io.netty.channel.socket;

import io.netty.util.NetUtil;

import java.net.Inet4Address;
import java.net.Inet6Address;
import java.net.InetAddress;

Internet Protocol (IP) families used byte the DatagramChannel
/** * Internet Protocol (IP) families used byte the {@link DatagramChannel} */
public enum InternetProtocolFamily { IPv4(Inet4Address.class, 1, NetUtil.LOCALHOST4), IPv6(Inet6Address.class, 2, NetUtil.LOCALHOST6); private final Class<? extends InetAddress> addressType; private final int addressNumber; private final InetAddress localHost; InternetProtocolFamily(Class<? extends InetAddress> addressType, int addressNumber, InetAddress localHost) { this.addressType = addressType; this.addressNumber = addressNumber; this.localHost = localHost; }
Returns the address type of this protocol family.
/** * Returns the address type of this protocol family. */
public Class<? extends InetAddress> addressType() { return addressType; }
Returns the address number of the family.
/** * Returns the * <a href="http://www.iana.org/assignments/address-family-numbers/address-family-numbers.xhtml">address number</a> * of the family. */
public int addressNumber() { return addressNumber; }
Returns the InetAddress that represent the LOCALHOST for the family.
/** * Returns the {@link InetAddress} that represent the {@code LOCALHOST} for the family. */
public InetAddress localhost() { return localHost; }
Returns the InternetProtocolFamily for the given InetAddress.
/** * Returns the {@link InternetProtocolFamily} for the given {@link InetAddress}. */
public static InternetProtocolFamily of(InetAddress address) { if (address instanceof Inet4Address) { return IPv4; } if (address instanceof Inet6Address) { return IPv6; } throw new IllegalArgumentException("address " + address + " not supported"); } }