2015-02-06 04:36:42 +01:00
|
|
|
// Package chaincfg defines chain configuration parameters.
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
|
|
|
// In addition to the main Bitcoin network, which is intended for the transfer
|
|
|
|
// of monetary value, there also exists two currently active standard networks:
|
|
|
|
// regression test and testnet (version 3). These networks are incompatible
|
|
|
|
// with each other (each sharing a different genesis block) and software should
|
|
|
|
// handle errors where input intended for one network is used on an application
|
|
|
|
// instance running on a different network.
|
|
|
|
//
|
2015-02-06 04:36:42 +01:00
|
|
|
// For library packages, chaincfg provides the ability to lookup chain
|
|
|
|
// parameters and encoding magics when passed a *Params. Older APIs not updated
|
|
|
|
// to the new convention of passing a *Params may lookup the parameters for a
|
2015-02-05 19:58:30 +01:00
|
|
|
// wire.BitcoinNet using ParamsForNet, but be aware that this usage is
|
2015-02-06 04:36:42 +01:00
|
|
|
// deprecated and will be removed from chaincfg in the future.
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
|
|
|
// For main packages, a (typically global) var may be assigned the address of
|
|
|
|
// one of the standard Param vars for use as the application's "active" network.
|
|
|
|
// When a network parameter is needed, it may then be looked up through this
|
|
|
|
// variable (either directly, or hidden in a library call).
|
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// package main
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// import (
|
|
|
|
// "flag"
|
|
|
|
// "fmt"
|
|
|
|
// "log"
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// "github.com/btcsuite/btcd/btcutil"
|
|
|
|
// "github.com/btcsuite/btcd/chaincfg"
|
|
|
|
// )
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// var testnet = flag.Bool("testnet", false, "operate on the testnet Bitcoin network")
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// // By default (without -testnet), use mainnet.
|
|
|
|
// var chainParams = &chaincfg.MainNetParams
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// func main() {
|
|
|
|
// flag.Parse()
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// // Modify active network parameters if operating on testnet.
|
|
|
|
// if *testnet {
|
|
|
|
// chainParams = &chaincfg.TestNet3Params
|
|
|
|
// }
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// // later...
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
2023-05-16 06:05:07 +02:00
|
|
|
// // Create and print new payment address, specific to the active network.
|
|
|
|
// pubKeyHash := make([]byte, 20)
|
|
|
|
// addr, err := btcutil.NewAddressPubKeyHash(pubKeyHash, chainParams)
|
|
|
|
// if err != nil {
|
|
|
|
// log.Fatal(err)
|
|
|
|
// }
|
|
|
|
// fmt.Println(addr)
|
|
|
|
// }
|
2014-05-22 19:45:08 +02:00
|
|
|
//
|
|
|
|
// If an application does not use one of the three standard Bitcoin networks,
|
|
|
|
// a new Params struct may be created which defines the parameters for the
|
|
|
|
// non-standard network. As a general rule of thumb, all network parameters
|
|
|
|
// should be unique to the network, but parameter collisions can still occur
|
|
|
|
// (unfortunately, this is the case with regtest and testnet3 sharing magics).
|
2015-02-06 04:36:42 +01:00
|
|
|
package chaincfg
|