using System; using Org.BouncyCastle.Math; namespace Org.BouncyCastle.Crypto.Parameters { public class DsaPrivateKeyParameters : DsaKeyParameters { private readonly BigInteger x; public DsaPrivateKeyParameters( BigInteger x, DsaParameters parameters) : base(true, parameters) { if (x == null) throw new ArgumentNullException("x"); this.x = x; } public BigInteger X { get { return x; } } public override bool Equals( object obj) { if (obj == this) return true; DsaPrivateKeyParameters other = obj as DsaPrivateKeyParameters; if (other == null) return false; return Equals(other); } protected bool Equals( DsaPrivateKeyParameters other) { return x.Equals(other.x) && base.Equals(other); } public override int GetHashCode() { return x.GetHashCode() ^ base.GetHashCode(); } } }