| .. | ||
| chainhash | ||
| doc.go | ||
| generatesubsidytables.go | ||
| go.mod | ||
| go.sum | ||
| init_test.go | ||
| init.go | ||
| mainnetparams_test.go | ||
| mainnetparams.go | ||
| params.go | ||
| README.md | ||
| regnetparams_test.go | ||
| regnetparams.go | ||
| simnetparams_test.go | ||
| simnetparams.go | ||
| subsidy.go | ||
| subsidydefinitions.go | ||
| subsidytables.go | ||
| testnetparams_test.go | ||
| testnetparams.go | ||
chaincfg
Package chaincfg defines chain configuration parameters for the four standard Decred networks.
Although this package was primarily written for dcrd, it has intentionally been designed so it can be used as a standalone package for any projects needing to use parameters for the standard Decred networks or for projects needing to define their own network.
Sample Use
package main
import (
"flag"
"fmt"
"log"
"github.com/decred/dcrd/chaincfg/v3"
"github.com/decred/dcrd/txscript/v4/stdaddr"
)
func main() {
var testnet = flag.Bool("testnet", false, "operate on the test network")
flag.Parse()
// By default (without -testnet), use mainnet.
var chainParams = chaincfg.MainNetParams()
// Modify active network parameters if operating on testnet.
if *testnet {
chainParams = chaincfg.TestNet3Params()
}
// later...
// Create and print new payment address, specific to the active network.
pubKeyHash := make([]byte, 20)
addr, err := stdaddr.NewAddressPubKeyHashEcdsaSecp256k1V0(pubKeyHash,
chainParams)
if err != nil {
log.Fatal(err)
}
fmt.Println(addr)
}
Installation and Updating
This package is part of the github.com/decred/dcrd/chaincfg/v3 module. Use
the standard go tooling for working with modules to incorporate it.
License
Package chaincfg is licensed under the copyfree ISC License.