package org.bouncycastle.asn1;

import java.io.IOException;

Base class for ASN.1 primitive objects. These are the actual objects used to generate byte encodings.
/** * Base class for ASN.1 primitive objects. These are the actual objects used to generate byte encodings. */
public abstract class ASN1Primitive extends ASN1Object { ASN1Primitive() { }
Create a base ASN.1 object from a byte stream.
Params:
  • data – the byte stream to parse.
Throws:
  • IOException – if there is a problem parsing the data, or parsing the stream did not exhaust the available data.
Returns:the base ASN.1 object represented by the byte stream.
/** * Create a base ASN.1 object from a byte stream. * * @param data the byte stream to parse. * @return the base ASN.1 object represented by the byte stream. * @exception IOException if there is a problem parsing the data, or parsing the stream did not exhaust the available data. */
public static ASN1Primitive fromByteArray(byte[] data) throws IOException { ASN1InputStream aIn = new ASN1InputStream(data); try { ASN1Primitive o = aIn.readObject(); if (aIn.available() != 0) { throw new IOException("Extra data detected in stream"); } return o; } catch (ClassCastException e) { throw new IOException("cannot recognise object in stream"); } } public final boolean equals(Object o) { if (this == o) { return true; } return (o instanceof ASN1Encodable) && asn1Equals(((ASN1Encodable)o).toASN1Primitive()); } public ASN1Primitive toASN1Primitive() { return this; }
Return the current object as one which encodes using Distinguished Encoding Rules.
Returns:a DER version of this.
/** * Return the current object as one which encodes using Distinguished Encoding Rules. * * @return a DER version of this. */
ASN1Primitive toDERObject() { return this; }
Return the current object as one which encodes using Definite Length encoding.
Returns:a DL version of this.
/** * Return the current object as one which encodes using Definite Length encoding. * * @return a DL version of this. */
ASN1Primitive toDLObject() { return this; } public abstract int hashCode();
Return true if this objected is a CONSTRUCTED one, false otherwise.
Returns:true if CONSTRUCTED bit set on object's tag, false otherwise.
/** * Return true if this objected is a CONSTRUCTED one, false otherwise. * @return true if CONSTRUCTED bit set on object's tag, false otherwise. */
abstract boolean isConstructed();
Return the length of the encoding this object will produce.
Throws:
  • IOException – if the encoding length cannot be calculated.
Returns:the length of the object's encoding.
/** * Return the length of the encoding this object will produce. * @return the length of the object's encoding. * @throws IOException if the encoding length cannot be calculated. */
abstract int encodedLength() throws IOException; abstract void encode(ASN1OutputStream out) throws IOException;
Equality (similarity) comparison for two ASN1Primitive objects.
/** * Equality (similarity) comparison for two ASN1Primitive objects. */
abstract boolean asn1Equals(ASN1Primitive o); }