X-Git-Url: https://git.novaco.in/?a=blobdiff_plain;f=Novacoin%2FCTxOut.cs;h=eb24845cbd503f15d2c0b6714fdb512a496ba074;hb=be9d844557911f95165d2c9875c4f5b2822cfc92;hp=3e3d4c18bf4fd0c5c299da3ee595afb67408e9f1;hpb=12a559c6cb61ae1c22e2859742ea0edd552eca07;p=NovacoinLibrary.git diff --git a/Novacoin/CTxOut.cs b/Novacoin/CTxOut.cs index 3e3d4c1..eb24845 100644 --- a/Novacoin/CTxOut.cs +++ b/Novacoin/CTxOut.cs @@ -1,6 +1,25 @@ -using System; +/** + * Novacoin classes library + * Copyright (C) 2015 Alex D. (balthazar.ad@gmail.com) + + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + */ + +using System; using System.Text; using System.Collections.Generic; +using System.IO; namespace Novacoin { @@ -12,7 +31,7 @@ namespace Novacoin /// /// Input value. /// - public long nValue = -1; + public ulong nValue = ulong.MaxValue; /// /// Second half of script which contains spending instructions. @@ -34,7 +53,7 @@ namespace Novacoin /// public CTxOut() { - scriptPubKey = new CScript(); + SetEmpty(); } /// @@ -42,19 +61,19 @@ namespace Novacoin /// /// Reference to byte sequence /// Outputs array - public static CTxOut[] ReadTxOutList(ref WrappedList wBytes) + public static CTxOut[] ReadTxOutList(ref ByteQueue wBytes) { - int nOutputs = (int)VarInt.ReadVarInt(ref wBytes); - CTxOut[] vout =new CTxOut[nOutputs]; + int nOutputs = (int)wBytes.GetVarInt(); + var vout =new CTxOut[nOutputs]; for (int nIndex = 0; nIndex < nOutputs; nIndex++) { // Fill outputs array vout[nIndex] = new CTxOut(); - vout[nIndex].nValue = BitConverter.ToUInt32(wBytes.GetItems(8), 0); + vout[nIndex].nValue = BitConverter.ToUInt64(wBytes.Get(8), 0); - int nScriptPKLen = (int)VarInt.ReadVarInt(ref wBytes); - vout[nIndex].scriptPubKey = new CScript(wBytes.GetItems(nScriptPKLen)); + int nScriptPKLen = (int)wBytes.GetVarInt(); + vout[nIndex].scriptPubKey = new CScript(wBytes.Get(nScriptPKLen)); } return vout; @@ -64,38 +83,43 @@ namespace Novacoin /// Get raw bytes representation of our output. /// /// Byte sequence. - public IList Bytes + public static implicit operator byte[] (CTxOut output) { - get - { - List resultBytes = new List(); + var stream = new MemoryStream(); + var writer = new BinaryWriter(stream); - resultBytes.AddRange(BitConverter.GetBytes(nValue)); // txout value + writer.Write(output.nValue); // txout value + writer.Write(VarInt.EncodeVarInt(output.scriptPubKey.Size)); // scriptPubKey length + writer.Write(output.scriptPubKey); // scriptPubKey - List s = new List(scriptPubKey.Bytes); + var resultBytes = stream.ToArray(); - resultBytes.AddRange(VarInt.EncodeVarInt(s.Count)); // scriptPubKey length - resultBytes.AddRange(s); // scriptPubKey + writer.Close(); - return resultBytes; - } + return resultBytes; } + /// + /// Null prevouts have -1 value + /// public void SetNull() { - nValue = -1; - scriptPubKey.SetNullDestination(); + nValue = ulong.MaxValue; + scriptPubKey = new CScript(); } + /// + /// Empty outputs have zero value and empty scriptPubKey + /// public void SetEmpty() { nValue = 0; - scriptPubKey.SetNullDestination(); + scriptPubKey = new CScript(); } public bool IsNull { - get { return (nValue == -1); } + get { return (nValue == ulong.MaxValue); } } public bool IsEmpty @@ -103,9 +127,21 @@ namespace Novacoin get { return nValue == 0 && scriptPubKey.IsNull; } } - public override string ToString () + /// + /// Serialized size + /// + public int Size + { + get + { + var nScriptSize = scriptPubKey.Size; + return 8 + VarInt.GetEncodedSize(nScriptSize) + nScriptSize; + } + } + + public override string ToString () { - StringBuilder sb = new StringBuilder (); + var sb = new StringBuilder (); sb.AppendFormat ("CTxOut(nValue={0}, scriptPubKey={1})", nValue, scriptPubKey.ToString()); return sb.ToString ();