123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using System.IO;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Math;
- namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Bcpg
- {
- /// <remarks>A multiple precision integer</remarks>
- public class MPInteger
- : BcpgObject
- {
- private readonly BigInteger val;
- public MPInteger(
- BcpgInputStream bcpgIn)
- {
- if (bcpgIn == null)
- throw new ArgumentNullException("bcpgIn");
- int length = (bcpgIn.ReadByte() << 8) | bcpgIn.ReadByte();
- byte[] bytes = new byte[(length + 7) / 8];
- bcpgIn.ReadFully(bytes);
- this.val = new BigInteger(1, bytes);
- }
- public MPInteger(
- BigInteger val)
- {
- if (val == null)
- throw new ArgumentNullException("val");
- if (val.SignValue < 0)
- throw new ArgumentException("Values must be positive", "val");
- this.val = val;
- }
- public BigInteger Value
- {
- get { return val; }
- }
- public override void Encode(
- BcpgOutputStream bcpgOut)
- {
- bcpgOut.WriteShort((short) val.BitLength);
- bcpgOut.Write(val.ToByteArrayUnsigned());
- }
- internal static void Encode(
- BcpgOutputStream bcpgOut,
- BigInteger val)
- {
- bcpgOut.WriteShort((short) val.BitLength);
- bcpgOut.Write(val.ToByteArrayUnsigned());
- }
- }
- }
- #pragma warning restore
- #endif
|