using System;
using System.Text;
using System.Collections.Generic;
+using System.Diagnostics.Contracts;
namespace Novacoin
{
/// <summary>
/// Previous block hash.
/// </summary>
- public Hash256 prevHash = new Hash256();
+ public ScryptHash256 prevHash = new ScryptHash256();
/// <summary>
/// Merkle root hash.
public CBlockHeader(CBlockHeader h)
{
nVersion = h.nVersion;
- prevHash = new Hash256(h.prevHash);
+ prevHash = new ScryptHash256(h.prevHash);
merkleRoot = new Hash256(h.merkleRoot);
nTime = h.nTime;
nBits = h.nBits;
public CBlockHeader(byte[] bytes)
{
+ Contract.Requires<ArgumentException>(bytes.Length == 80, "Any valid block header is exactly 80 bytes long.");
+
nVersion = BitConverter.ToUInt32(bytes, 0);
- prevHash = new Hash256(bytes, 4);
+ prevHash = new ScryptHash256(bytes, 4);
merkleRoot = new Hash256(bytes, 36);
nTime = BitConverter.ToUInt32(bytes, 68);
nBits = BitConverter.ToUInt32(bytes, 72);
/// Convert current block header instance into sequence of bytes
/// </summary>
/// <returns>Byte sequence</returns>
- public byte[] Bytes
+ public static implicit operator byte[] (CBlockHeader h)
{
- get
- {
- var r = new List<byte>();
-
- r.AddRange(BitConverter.GetBytes(nVersion));
- r.AddRange(prevHash.hashBytes);
- r.AddRange(merkleRoot.hashBytes);
- r.AddRange(BitConverter.GetBytes(nTime));
- r.AddRange(BitConverter.GetBytes(nBits));
- r.AddRange(BitConverter.GetBytes(nNonce));
-
- return r.ToArray();
- }
+ var r = new List<byte>();
+
+ r.AddRange(BitConverter.GetBytes(h.nVersion));
+ r.AddRange((byte[])h.prevHash);
+ r.AddRange((byte[])h.merkleRoot);
+ r.AddRange(BitConverter.GetBytes(h.nTime));
+ r.AddRange(BitConverter.GetBytes(h.nBits));
+ r.AddRange(BitConverter.GetBytes(h.nNonce));
+
+ return r.ToArray();
}
public ScryptHash256 Hash
{
get {
- return ScryptHash256.Compute256(Bytes);
+ return ScryptHash256.Compute256(this);
}
}