config.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. // Copyright 2016 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package params
  17. import (
  18. "math/big"
  19. "github.com/ethereum/go-ethereum/common"
  20. )
  21. // ChainConfig is the core config which determines the blockchain settings.
  22. //
  23. // ChainConfig is stored in the database on a per block basis. This means
  24. // that any network, identified by its genesis block, can have its own
  25. // set of configuration options.
  26. type ChainConfig struct {
  27. ChainId *big.Int `json:"chainId"` // Chain id identifies the current chain and is used for replay protection
  28. HomesteadBlock *big.Int `json:"homesteadBlock"` // Homestead switch block (nil = no fork, 0 = already homestead)
  29. DAOForkBlock *big.Int `json:"daoForkBlock"` // TheDAO hard-fork switch block (nil = no fork)
  30. DAOForkSupport bool `json:"daoForkSupport"` // Whether the nodes supports or opposes the DAO hard-fork
  31. // EIP150 implements the Gas price changes (https://github.com/ethereum/EIPs/issues/150)
  32. EIP150Block *big.Int `json:"eip150Block"` // EIP150 HF block (nil = no fork)
  33. EIP150Hash common.Hash `json:"eip150Hash"` // EIP150 HF hash (fast sync aid)
  34. EIP155Block *big.Int `json:"eip155Block"` // EIP155 HF block
  35. EIP158Block *big.Int `json:"eip158Block"` // EIP158 HF block
  36. }
  37. var (
  38. TestChainConfig = &ChainConfig{big.NewInt(1), new(big.Int), new(big.Int), true, new(big.Int), common.Hash{}, new(big.Int), new(big.Int)}
  39. TestRules = TestChainConfig.Rules(new(big.Int))
  40. )
  41. // IsHomestead returns whether num is either equal to the homestead block or greater.
  42. func (c *ChainConfig) IsHomestead(num *big.Int) bool {
  43. if c.HomesteadBlock == nil || num == nil {
  44. return false
  45. }
  46. return num.Cmp(c.HomesteadBlock) >= 0
  47. }
  48. // GasTable returns the gas table corresponding to the current phase (homestead or homestead reprice).
  49. //
  50. // The returned GasTable's fields shouldn't, under any circumstances, be changed.
  51. func (c *ChainConfig) GasTable(num *big.Int) GasTable {
  52. if num == nil {
  53. return GasTableHomestead
  54. }
  55. switch {
  56. case c.EIP158Block != nil && num.Cmp(c.EIP158Block) >= 0:
  57. return GasTableEIP158
  58. case c.EIP150Block != nil && num.Cmp(c.EIP150Block) >= 0:
  59. return GasTableHomesteadGasRepriceFork
  60. default:
  61. return GasTableHomestead
  62. }
  63. }
  64. func (c *ChainConfig) IsEIP150(num *big.Int) bool {
  65. if c.EIP150Block == nil || num == nil {
  66. return false
  67. }
  68. return num.Cmp(c.EIP150Block) >= 0
  69. }
  70. func (c *ChainConfig) IsEIP155(num *big.Int) bool {
  71. if c.EIP155Block == nil || num == nil {
  72. return false
  73. }
  74. return num.Cmp(c.EIP155Block) >= 0
  75. }
  76. func (c *ChainConfig) IsEIP158(num *big.Int) bool {
  77. if c.EIP158Block == nil || num == nil {
  78. return false
  79. }
  80. return num.Cmp(c.EIP158Block) >= 0
  81. }
  82. // Rules wraps ChainConfig and is merely syntatic sugar or can be used for functions
  83. // that do not have or require information about the block.
  84. //
  85. // Rules is a one time interface meaning that it shouldn't be used in between transition
  86. // phases.
  87. type Rules struct {
  88. ChainId *big.Int
  89. IsHomestead, IsEIP150, IsEIP155, IsEIP158 bool
  90. }
  91. func (c *ChainConfig) Rules(num *big.Int) Rules {
  92. return Rules{ChainId: new(big.Int).Set(c.ChainId), IsHomestead: c.IsHomestead(num), IsEIP150: c.IsEIP150(num), IsEIP155: c.IsEIP155(num), IsEIP158: c.IsEIP158(num)}
  93. }