summary refs log tree commit diff
path: root/crypto/src/asn1/LazyDLSet.cs
diff options
context:
space:
mode:
authorPeter Dettman <peter.dettman@bouncycastle.org>2021-11-16 22:37:52 +0700
committerPeter Dettman <peter.dettman@bouncycastle.org>2021-11-16 22:37:52 +0700
commitbe15049124860ccb7335b92215e8b8dfa1821bf9 (patch)
tree7a86ed2110021307465a617076d601ca812c69ed /crypto/src/asn1/LazyDLSet.cs
parentMake cast more specific (diff)
downloadBouncyCastle.NET-ed25519-be15049124860ccb7335b92215e8b8dfa1821bf9.tar.xz
ASN.1: Staged encoding
Diffstat (limited to 'crypto/src/asn1/LazyDLSet.cs')
-rw-r--r--crypto/src/asn1/LazyDLSet.cs21
1 files changed, 8 insertions, 13 deletions
diff --git a/crypto/src/asn1/LazyDLSet.cs b/crypto/src/asn1/LazyDLSet.cs
index a426bb4cb..551200513 100644
--- a/crypto/src/asn1/LazyDLSet.cs
+++ b/crypto/src/asn1/LazyDLSet.cs
@@ -32,9 +32,7 @@ namespace Org.BouncyCastle.Asn1
         {
             byte[] encoded = GetContents();
             if (null != encoded)
-            {
                 return new LazyDLEnumerator(encoded);
-            }
 
             return base.GetEnumerator();
         }
@@ -63,39 +61,36 @@ namespace Org.BouncyCastle.Asn1
             return base.ToString();
         }
 
-        internal override int EncodedLength(int encoding, bool withID)
+        internal override IAsn1Encoding GetEncoding(int encoding)
         {
             if (Asn1OutputStream.EncodingBer == encoding)
             {
                 byte[] encoded = GetContents();
                 if (null != encoded)
-                    return Asn1OutputStream.GetLengthOfEncodingDL(withID, encoded.Length);
+                    return new ConstructedLazyDLEncoding(Asn1Tags.Universal, Asn1Tags.Set, encoded);
             }
             else
             {
                 Force();
             }
 
-            return base.EncodedLength(encoding, withID);
+            return base.GetEncoding(encoding);
         }
 
-        internal override void Encode(Asn1OutputStream asn1Out, bool withID)
+        internal override IAsn1Encoding GetEncodingImplicit(int encoding, int tagClass, int tagNo)
         {
-            if (Asn1OutputStream.EncodingBer == asn1Out.Encoding)
+            if (Asn1OutputStream.EncodingBer == encoding)
             {
                 byte[] encoded = GetContents();
-                if (encoded != null)
-                {
-                    asn1Out.WriteEncodingDL(withID, Asn1Tags.Constructed | Asn1Tags.Set, encoded);
-                    return;
-                }
+                if (null != encoded)
+                    return new ConstructedLazyDLEncoding(tagClass, tagNo, encoded);
             }
             else
             {
                 Force();
             }
 
-            base.Encode(asn1Out, withID);
+            return base.GetEncodingImplicit(encoding, tagClass, tagNo);
         }
 
         private void Force()