X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=pcep%2Fbase-parser%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fprotocol%2Fpcep%2Fparser%2Fsubobject%2FEROIpv4PrefixSubobjectParser.java;fp=pcep%2Fbase-parser%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fprotocol%2Fpcep%2Fparser%2Fsubobject%2FEROIpv4PrefixSubobjectParser.java;h=29a58f09c1edc92b444b5a805e4c2799ad0333cf;hb=12b06012259c6609c4b40488c8611a9431a39643;hp=c3e8877367a1544b69f79a034c9980f942046c4d;hpb=57c64bf6cae32b18b36956b33a3c956d9f0328e4;p=bgpcep.git diff --git a/pcep/base-parser/src/main/java/org/opendaylight/protocol/pcep/parser/subobject/EROIpv4PrefixSubobjectParser.java b/pcep/base-parser/src/main/java/org/opendaylight/protocol/pcep/parser/subobject/EROIpv4PrefixSubobjectParser.java index c3e8877367..29a58f09c1 100644 --- a/pcep/base-parser/src/main/java/org/opendaylight/protocol/pcep/parser/subobject/EROIpv4PrefixSubobjectParser.java +++ b/pcep/base-parser/src/main/java/org/opendaylight/protocol/pcep/parser/subobject/EROIpv4PrefixSubobjectParser.java @@ -7,9 +7,8 @@ */ package org.opendaylight.protocol.pcep.parser.subobject; -import static org.opendaylight.protocol.util.ByteBufWriteUtil.writeIpv4Prefix; +import static com.google.common.base.Preconditions.checkArgument; -import com.google.common.base.Preconditions; import io.netty.buffer.ByteBuf; import io.netty.buffer.Unpooled; import org.opendaylight.protocol.pcep.spi.EROSubobjectParser; @@ -19,6 +18,7 @@ import org.opendaylight.protocol.pcep.spi.PCEPDeserializerException; import org.opendaylight.protocol.util.ByteArray; import org.opendaylight.protocol.util.Ipv4Util; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.IpPrefix; +import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv6Prefix; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev181109.explicit.route.object.ero.Subobject; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev181109.explicit.route.object.ero.SubobjectBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.rsvp.rev150820.IpPrefixSubobject; @@ -30,19 +30,15 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.rsvp.rev * Parser for {@link IpPrefixCase}. */ public class EROIpv4PrefixSubobjectParser implements EROSubobjectParser, EROSubobjectSerializer { - public static final int TYPE = 1; private static final int PREFIX4_F_OFFSET = Ipv4Util.IP4_LENGTH; - private static final int RESERVED = 1; - private static final int CONTENT4_LENGTH = PREFIX4_F_OFFSET + RESERVED + 1; @Override public Subobject parseSubobject(final ByteBuf buffer, final boolean loose) throws PCEPDeserializerException { - Preconditions.checkArgument(buffer != null && buffer.isReadable(), - "Array of bytes is mandatory. Can't be null or empty."); + checkArgument(buffer != null && buffer.isReadable(), "Array of bytes is mandatory. Can't be null or empty."); if (buffer.readableBytes() != CONTENT4_LENGTH) { throw new PCEPDeserializerException( "Wrong length of array of bytes. Passed: " + buffer.readableBytes() + ";"); @@ -58,20 +54,20 @@ public class EROIpv4PrefixSubobjectParser implements EROSubobjectParser, EROSubo @Override public void serializeSubobject(final Subobject subobject, final ByteBuf buffer) { - Preconditions.checkArgument(subobject.getSubobjectType() instanceof IpPrefixCase, + checkArgument(subobject.getSubobjectType() instanceof IpPrefixCase, "Unknown subobject instance. Passed %s. Needed IpPrefixCase.", subobject.getSubobjectType().getClass()); final IpPrefixSubobject specObj = ((IpPrefixCase) subobject.getSubobjectType()).getIpPrefix(); final IpPrefix prefix = specObj.getIpPrefix(); - Preconditions.checkArgument(prefix.getIpv4Prefix() != null || prefix.getIpv6Prefix() != null, - "Unknown AbstractPrefix instance. Passed %s.", prefix.getClass()); - if (prefix.getIpv6Prefix() != null) { - new EROIpv6PrefixSubobjectParser().serializeSubobject(subobject, buffer); - } else { - final ByteBuf body = Unpooled.buffer(CONTENT4_LENGTH); - Preconditions.checkArgument(prefix.getIpv4Prefix() != null, "Ipv4Prefix is mandatory."); - writeIpv4Prefix(prefix.getIpv4Prefix(), body); - body.writeZero(RESERVED); - EROSubobjectUtil.formatSubobject(TYPE, subobject.isLoose(), body, buffer); + final Ipv6Prefix ipv6prefix = prefix.getIpv6Prefix(); + if (ipv6prefix != null) { + EROIpv6PrefixSubobjectParser.serializeSubobject(buffer, subobject, ipv6prefix); + return; } + + final ByteBuf body = Unpooled.buffer(CONTENT4_LENGTH); + checkArgument(prefix.getIpv4Prefix() != null, "Ipv4Prefix is mandatory."); + Ipv4Util.writeIpv4Prefix(prefix.getIpv4Prefix(), body); + body.writeZero(RESERVED); + EROSubobjectUtil.formatSubobject(TYPE, subobject.isLoose(), body, buffer); } }