package org.bouncycastle.asn1;
import java.io.IOException;
import java.util.Enumeration;
/**
* A DER encoded SET object
* <p>
* For X.690 syntax rules, see {@link ASN1Set}.
* </p><p>
* For short: Constructing this form does sort the supplied elements,
* and the sorting happens also before serialization (if necesssary).
* This is different from the way {@link BERSet},{@link DLSet} does things.
* </p>
*/
public class DERSet
extends ASN1Set
{
private int bodyLength = -1;
create an empty set
/**
* create an empty set
*/
public DERSet()
{
}
create a set containing one object
Params: - obj – the object to go in the set
/**
* create a set containing one object
* @param obj the object to go in the set
*/
public DERSet(
ASN1Encodable obj)
{
super(obj);
}
create a set containing a vector of objects.
Params: - v – the vector of objects to make up the set.
/**
* create a set containing a vector of objects.
* @param v the vector of objects to make up the set.
*/
public DERSet(
ASN1EncodableVector v)
{
super(v, true);
}
create a set containing an array of objects.
Params: - a – the array of objects to make up the set.
/**
* create a set containing an array of objects.
* @param a the array of objects to make up the set.
*/
public DERSet(
ASN1Encodable[] a)
{
super(a, true);
}
DERSet(
ASN1EncodableVector v,
boolean doSort)
{
super(v, doSort);
}
private int getBodyLength()
throws IOException
{
if (bodyLength < 0)
{
int length = 0;
for (Enumeration e = this.getObjects(); e.hasMoreElements();)
{
Object obj = e.nextElement();
length += ((ASN1Encodable)obj).toASN1Primitive().toDERObject().encodedLength();
}
bodyLength = length;
}
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 SET,
* we also have to specify CONSTRUCTED, and the objects length.
*/
void encode(
ASN1OutputStream out)
throws IOException
{
ASN1OutputStream dOut = out.getDERSubStream();
int length = getBodyLength();
out.write(BERTags.SET | BERTags.CONSTRUCTED);
out.writeLength(length);
for (Enumeration e = this.getObjects(); e.hasMoreElements();)
{
Object obj = e.nextElement();
dOut.writeObject((ASN1Encodable)obj);
}
}
}