btcd/txscript
Dave Collins fdc2bc867b
txscript: Significantly improve errors.
This converts the majority of script errors from generic errors created
via errors.New and fmt.Errorf to use a concrete type that implements the
error interface with an error code and description.

This allows callers to programmatically detect the type of error via
type assertions and an error code while still allowing the errors to
provide more context.

For example, instead of just having an error the reads "disabled opcode"
as would happen prior to these changes when a disabled opcode is
encountered, the error will now read "attempt to execute disabled opcode
OP_FOO".

While it was previously possible to programmatically detect many errors
due to them being exported, they provided no additional context and
there were also various instances that were just returning errors
created on the spot which callers could not reliably detect without
resorting to looking at the actual error message, which is nearly always
bad practice.

Also, while here, export the MaxStackSize and MaxScriptSize constants
since they can be useful for consumers of the package and perform some
minor cleanup of some of the tests.
2017-01-12 13:12:39 -06:00
..
data txscript: Implement CheckSequenceVerify (BIP0112) 2016-10-19 12:06:44 -04:00
consensus.go txscript: Implement CheckSequenceVerify (BIP0112) 2016-10-19 12:06:44 -04:00
doc.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
engine_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
engine.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
error_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
error.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
example_test.go wire: Make NewMsgTx accept the tx version. 2016-10-27 14:09:29 -05:00
log_test.go txscript: Consolidate tests into txscript package. 2016-10-20 09:28:33 -05:00
log.go Relicense to the btcsuite developers. 2015-05-01 12:00:56 -05:00
opcode_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
opcode.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
README.md txscript: Fix typo in README 2016-01-29 12:39:11 -08:00
reference_test.go wire: Make NewMsgTx accept the tx version. 2016-10-27 14:09:29 -05:00
script_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
script.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptbuilder_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptbuilder.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptnum_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptnum.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
sigcache_test.go chainhash: Abstract hash logic to new package. (#729) 2016-08-08 14:04:33 -05:00
sigcache.go chainhash: Abstract hash logic to new package. (#729) 2016-08-08 14:04:33 -05:00
sign_test.go wire: Make NewMsgTx accept the tx version. 2016-10-27 14:09:29 -05:00
sign.go Unassign some TODO's 2016-11-15 17:47:33 -06:00
stack_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
stack.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
standard_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
standard.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00

txscript

[Build Status] (https://travis-ci.org/btcsuite/btcd) ![ISC License] (http://img.shields.io/badge/license-ISC-blue.svg) [GoDoc] (http://godoc.org/github.com/btcsuite/btcd/txscript)

Package txscript implements the bitcoin transaction script language. There is a comprehensive test suite.

This package has intentionally been designed so it can be used as a standalone package for any projects needing to use or validate bitcoin transaction scripts.

Bitcoin Scripts

Bitcoin provides a stack-based, FORTH-like language for the scripts in the bitcoin transactions. This language is not turing complete although it is still fairly powerful. A description of the language can be found at https://en.bitcoin.it/wiki/Script

Installation and Updating

$ go get -u github.com/btcsuite/btcd/txscript

Examples

GPG Verification Key

All official release tags are signed by Conformal so users can ensure the code has not been tampered with and is coming from the btcsuite developers. To verify the signature perform the following:

  • Download the public key from the Conformal website at https://opensource.conformal.com/GIT-GPG-KEY-conformal.txt

  • Import the public key into your GPG keyring:

    gpg --import GIT-GPG-KEY-conformal.txt
    
  • Verify the release tag with the following command where TAG_NAME is a placeholder for the specific tag:

    git tag -v TAG_NAME
    

License

Package txscript is licensed under the copyfree ISC License.