2017-01-07 11:31:03 -06:00
|
|
|
// Copyright (c) 2013-2017 The btcsuite developers
|
2013-06-12 16:35:27 -05:00
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
/*
|
2015-01-30 00:03:01 -06:00
|
|
|
Package txscript implements the bitcoin transaction script language.
|
2013-06-12 16:35:27 -05:00
|
|
|
|
|
|
|
A complete description of the script language used by bitcoin can be found at
|
|
|
|
https://en.bitcoin.it/wiki/Script. The following only serves as a quick
|
|
|
|
overview to provide information on how to use the package.
|
|
|
|
|
|
|
|
This package provides data structures and functions to parse and execute
|
|
|
|
bitcoin transaction scripts.
|
|
|
|
|
2022-08-07 23:40:46 -07:00
|
|
|
# Script Overview
|
2013-06-12 16:35:27 -05:00
|
|
|
|
|
|
|
Bitcoin transaction scripts are written in a stack-base, FORTH-like language.
|
|
|
|
|
|
|
|
The bitcoin script language consists of a number of opcodes which fall into
|
|
|
|
several categories such pushing and popping data to and from the stack,
|
|
|
|
performing basic and bitwise arithmetic, conditional branching, comparing
|
|
|
|
hashes, and checking cryptographic signatures. Scripts are processed from left
|
|
|
|
to right and intentionally do not provide loops.
|
|
|
|
|
|
|
|
The vast majority of Bitcoin scripts at the time of this writing are of several
|
|
|
|
standard forms which consist of a spender providing a public key and a signature
|
|
|
|
which proves the spender owns the associated private key. This information
|
|
|
|
is used to prove the the spender is authorized to perform the transaction.
|
|
|
|
|
|
|
|
One benefit of using a scripting language is added flexibility in specifying
|
|
|
|
what conditions must be met in order to spend bitcoins.
|
|
|
|
|
2022-08-07 23:40:46 -07:00
|
|
|
# Errors
|
2013-06-12 16:35:27 -05:00
|
|
|
|
2017-01-07 11:31:03 -06:00
|
|
|
Errors returned by this package are of type txscript.Error. This allows the
|
|
|
|
caller to programmatically determine the specific error by examining the
|
|
|
|
ErrorCode field of the type asserted txscript.Error while still providing rich
|
|
|
|
error messages with contextual information. A convenience function named
|
|
|
|
IsErrorCode is also provided to allow callers to easily check for a specific
|
|
|
|
error code. See ErrorCode in the package documentation for a full list.
|
2013-06-12 16:35:27 -05:00
|
|
|
*/
|
2015-01-30 00:03:01 -06:00
|
|
|
package txscript
|