summary refs log tree commit diff
diff options
context:
space:
mode:
authorPeter Dettman <peter.dettman@bouncycastle.org>2023-04-13 15:31:14 +0700
committerPeter Dettman <peter.dettman@bouncycastle.org>2023-04-13 15:31:14 +0700
commit8f5512b04798e1a527bdb479dc2b0885f9a6ca7c (patch)
tree445cb195b93afd9f6c9766c8e17308c139931f6a
parentFix ParallelHash copy constructor (diff)
downloadBouncyCastle.NET-ed25519-8f5512b04798e1a527bdb479dc2b0885f9a6ca7c.tar.xz
Asn1OctetString constructor from Span<byte> (copying)
-rw-r--r--crypto/src/asn1/Asn1OctetString.cs7
-rw-r--r--crypto/src/asn1/BerOctetString.cs8
-rw-r--r--crypto/src/asn1/DerOctetString.cs7
3 files changed, 22 insertions, 0 deletions
diff --git a/crypto/src/asn1/Asn1OctetString.cs b/crypto/src/asn1/Asn1OctetString.cs
index e52e50759..d8a7bf27a 100644
--- a/crypto/src/asn1/Asn1OctetString.cs
+++ b/crypto/src/asn1/Asn1OctetString.cs
@@ -88,6 +88,13 @@ namespace Org.BouncyCastle.Asn1
 			this.contents = contents;
         }
 
+#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
+        internal Asn1OctetString(ReadOnlySpan<byte> contents)
+        {
+            this.contents = contents.ToArray();
+        }
+#endif
+
         public Stream GetOctetStream()
 		{
 			return new MemoryStream(contents, false);
diff --git a/crypto/src/asn1/BerOctetString.cs b/crypto/src/asn1/BerOctetString.cs
index 10d8d6db6..fd6b85be2 100644
--- a/crypto/src/asn1/BerOctetString.cs
+++ b/crypto/src/asn1/BerOctetString.cs
@@ -67,6 +67,14 @@ namespace Org.BouncyCastle.Asn1
         {
         }
 
+#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
+        internal BerOctetString(ReadOnlySpan<byte> contents)
+            : base(contents)
+        {
+            this.elements = null;
+        }
+#endif
+
         private BerOctetString(byte[] contents, Asn1OctetString[] elements)
             : base(contents)
         {
diff --git a/crypto/src/asn1/DerOctetString.cs b/crypto/src/asn1/DerOctetString.cs
index 3680a6fd4..7ea9940b3 100644
--- a/crypto/src/asn1/DerOctetString.cs
+++ b/crypto/src/asn1/DerOctetString.cs
@@ -21,6 +21,13 @@ namespace Org.BouncyCastle.Asn1
         {
         }
 
+#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
+        internal DerOctetString(ReadOnlySpan<byte> contents)
+            : base(contents)
+        {
+        }
+#endif
+
         internal override IAsn1Encoding GetEncoding(int encoding)
         {
             return new PrimitiveEncoding(Asn1Tags.Universal, Asn1Tags.OctetString, contents);