X-Git-Url: https://git.novaco.in/?a=blobdiff_plain;f=Novacoin%2FCTxIn.cs;h=067ad4639dabd9b3c46f9df6287e8c30473c4bce;hb=be9d844557911f95165d2c9875c4f5b2822cfc92;hp=bc80f0f0ec55a4809b1d43fe3a23a31886dc0749;hpb=4fa8ff7d27f5eedaae8781f136be633e5fbeca4e;p=NovacoinLibrary.git diff --git a/Novacoin/CTxIn.cs b/Novacoin/CTxIn.cs index bc80f0f..067ad46 100644 --- a/Novacoin/CTxIn.cs +++ b/Novacoin/CTxIn.cs @@ -1,13 +1,50 @@ -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 { - /// - /// Transaction input. - /// - public class CTxIn + [Serializable] + public class TxInConstructorException : Exception + { + public TxInConstructorException() + { + } + + public TxInConstructorException(string message) + : base(message) + { + } + + public TxInConstructorException(string message, Exception inner) + : base(message, inner) + { + } + } + + /// + /// Transaction input. + /// + public class CTxIn { /// /// Previous input data @@ -22,7 +59,7 @@ namespace Novacoin /// /// Transaction variant number, irrelevant if nLockTime isn't specified. Its value is 0xffffffff by default. /// - public uint nSequence = 0xffffffff; + public uint nSequence = uint.MaxValue; /// /// Initialize new CTxIn instance as copy of another one. @@ -49,47 +86,63 @@ namespace Novacoin /// /// Reference to byte sequence /// Inputs array - public static CTxIn[] ReadTxInList(ref WrappedList wBytes) + public static CTxIn[] ReadTxInList(ref ByteQueue wBytes) { - CTxIn[] vin; - - // Get amount - int nInputs = (int)VarInt.ReadVarInt(ref wBytes); - vin = new CTxIn[nInputs]; - - for (int nIndex = 0; nIndex < nInputs; nIndex++) + try + { + // Get amount + int nInputs = (int)wBytes.GetVarInt(); + var vin = new CTxIn[nInputs]; + + for (int nIndex = 0; nIndex < nInputs; nIndex++) + { + // Fill inputs array + vin[nIndex] = new CTxIn(); + vin[nIndex].prevout = new COutPoint(wBytes.Get(36)); + vin[nIndex].scriptSig = new CScript(wBytes.Get((int)wBytes.GetVarInt())); + vin[nIndex].nSequence = BitConverter.ToUInt32(wBytes.Get(4), 0); + } + + // Return inputs array + return vin; + } + catch (Exception e) { - // Fill inputs array - vin[nIndex] = new CTxIn(); - vin[nIndex].prevout = new COutPoint(wBytes.GetItems(36)); - vin[nIndex].scriptSig = new CScript(wBytes.GetItems((int)VarInt.ReadVarInt(ref wBytes))); - vin[nIndex].nSequence = BitConverter.ToUInt32(wBytes.GetItems(4), 0); + throw new TxInConstructorException("Desirealization failed.", e); } + } + + /// + /// Serialized size + /// + public int Size + { + get { + int nSize = 40; // COutPoint, nSequence + nSize += VarInt.GetEncodedSize(scriptSig.Size); + nSize += scriptSig.Size; - // Return inputs array - return vin; + return nSize; + } } /// /// Get raw bytes representation of our input. /// /// Byte sequence. - public IList Bytes + public static implicit operator byte[] (CTxIn input) { - get - { - List inputBytes = new List(); - - inputBytes.AddRange(prevout.Bytes); // prevout + var stream = new MemoryStream(); + var writer = new BinaryWriter(stream); - List s = new List(scriptSig.Bytes); + writer.Write(input.prevout); // prevout + writer.Write(VarInt.EncodeVarInt(input.scriptSig.Size)); // scriptSig length + writer.Write(input.scriptSig); // scriptSig + writer.Write(input.nSequence); // nSequence - inputBytes.AddRange(VarInt.EncodeVarInt(s.Count)); // scriptSig length - inputBytes.AddRange(s); // scriptSig - inputBytes.AddRange(BitConverter.GetBytes(nSequence)); // Sequence - - return inputBytes; - } + var inputBytes = stream.ToArray(); + writer.Close(); + return inputBytes; } public bool IsFinal @@ -105,7 +158,7 @@ namespace Novacoin if(prevout.IsNull) { - sb.AppendFormat(", coinbase={0}", Interop.ToHex(scriptSig.Bytes)); + sb.AppendFormat(", coinbase={0}", Interop.ToHex((byte[])scriptSig)); } else { @@ -125,4 +178,3 @@ namespace Novacoin } } -