| /* GENERATED SOURCE. DO NOT MODIFY. */ |
| package com.android.org.bouncycastle.asn1; |
| |
| import java.io.IOException; |
| |
| /** |
| * Definite length SEQUENCE, encoding tells explicit number of bytes |
| * that the content of this sequence occupies. |
| * <p> |
| * For X.690 syntax rules, see {@link ASN1Sequence}. |
| * @hide This class is not part of the Android public SDK API |
| */ |
| public class DERSequence |
| extends ASN1Sequence |
| { |
| public static DERSequence convert(ASN1Sequence seq) |
| { |
| return (DERSequence)seq.toDERObject(); |
| } |
| |
| private int bodyLength = -1; |
| |
| /** |
| * Create an empty sequence |
| */ |
| @android.compat.annotation.UnsupportedAppUsage |
| public DERSequence() |
| { |
| } |
| |
| /** |
| * Create a sequence containing one object |
| * @param element the object to go in the sequence. |
| */ |
| public DERSequence(ASN1Encodable element) |
| { |
| super(element); |
| } |
| |
| /** |
| * Create a sequence containing a vector of objects. |
| * @param elementVector the vector of objects to make up the sequence. |
| */ |
| @android.compat.annotation.UnsupportedAppUsage |
| public DERSequence(ASN1EncodableVector elementVector) |
| { |
| super(elementVector); |
| } |
| |
| /** |
| * Create a sequence containing an array of objects. |
| * @param elements the array of objects to make up the sequence. |
| */ |
| public DERSequence(ASN1Encodable[] elements) |
| { |
| super(elements); |
| } |
| |
| DERSequence(ASN1Encodable[] elements, boolean clone) |
| { |
| super(elements, clone); |
| } |
| |
| private int getBodyLength() throws IOException |
| { |
| if (bodyLength < 0) |
| { |
| int count = elements.length; |
| int totalLength = 0; |
| |
| for (int i = 0; i < count; ++i) |
| { |
| ASN1Primitive derObject = elements[i].toASN1Primitive().toDERObject(); |
| totalLength += derObject.encodedLength(); |
| } |
| |
| this.bodyLength = totalLength; |
| } |
| |
| return bodyLength; |
| } |
| |
| int encodedLength() throws IOException |
| { |
| int length = getBodyLength(); |
| |
| return 1 + StreamUtil.calculateBodyLength(length) + length; |
| } |
| |
| /* |
| * A note on the implementation: |
| * <p> |
| * As DER requires the constructed, definite-length model to |
| * be used for structured types, this varies slightly from the |
| * ASN.1 descriptions given. Rather than just outputting SEQUENCE, |
| * we also have to specify CONSTRUCTED, and the objects length. |
| */ |
| void encode(ASN1OutputStream out, boolean withTag) throws IOException |
| { |
| if (withTag) |
| { |
| out.write(BERTags.SEQUENCE | BERTags.CONSTRUCTED); |
| } |
| |
| DEROutputStream derOut = out.getDERSubStream(); |
| |
| int count = elements.length; |
| if (bodyLength >= 0 || count > 16) |
| { |
| out.writeLength(getBodyLength()); |
| |
| for (int i = 0; i < count; ++i) |
| { |
| ASN1Primitive derObject = elements[i].toASN1Primitive().toDERObject(); |
| derObject.encode(derOut, true); |
| } |
| } |
| else |
| { |
| int totalLength = 0; |
| |
| ASN1Primitive[] derObjects = new ASN1Primitive[count]; |
| for (int i = 0; i < count; ++i) |
| { |
| ASN1Primitive derObject = elements[i].toASN1Primitive().toDERObject(); |
| derObjects[i] = derObject; |
| totalLength += derObject.encodedLength(); |
| } |
| |
| this.bodyLength = totalLength; |
| out.writeLength(totalLength); |
| |
| for (int i = 0; i < count; ++i) |
| { |
| derObjects[i].encode(derOut, true); |
| } |
| } |
| } |
| |
| ASN1Primitive toDERObject() |
| { |
| return this; |
| } |
| |
| ASN1Primitive toDLObject() |
| { |
| return this; |
| } |
| } |