2014-02-25 11:20:24 +01:00
|
|
|
package ethutil
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"math/big"
|
|
|
|
)
|
|
|
|
|
2014-04-27 17:15:44 +02:00
|
|
|
// The different number of units
|
2014-02-25 11:20:24 +01:00
|
|
|
var (
|
2014-06-06 12:12:27 +02:00
|
|
|
Douglas = BigPow(10, 42)
|
|
|
|
Einstein = BigPow(10, 21)
|
|
|
|
Ether = BigPow(10, 18)
|
|
|
|
Finney = BigPow(10, 15)
|
|
|
|
Szabo = BigPow(10, 12)
|
|
|
|
Shannon = BigPow(10, 9)
|
|
|
|
Babbage = BigPow(10, 6)
|
|
|
|
Ada = BigPow(10, 3)
|
|
|
|
Wei = big.NewInt(1)
|
2014-02-25 11:20:24 +01:00
|
|
|
)
|
|
|
|
|
2014-04-27 17:15:44 +02:00
|
|
|
// Currency to string
|
|
|
|
//
|
|
|
|
// Returns a string representing a human readable format
|
2014-02-25 11:20:24 +01:00
|
|
|
func CurrencyToString(num *big.Int) string {
|
|
|
|
switch {
|
2014-06-06 12:12:27 +02:00
|
|
|
case num.Cmp(Douglas) >= 0:
|
|
|
|
return fmt.Sprintf("%v Douglas", new(big.Int).Div(num, Douglas))
|
|
|
|
case num.Cmp(Einstein) >= 0:
|
|
|
|
return fmt.Sprintf("%v Einstein", new(big.Int).Div(num, Einstein))
|
2014-02-25 11:20:24 +01:00
|
|
|
case num.Cmp(Ether) >= 0:
|
|
|
|
return fmt.Sprintf("%v Ether", new(big.Int).Div(num, Ether))
|
|
|
|
case num.Cmp(Finney) >= 0:
|
|
|
|
return fmt.Sprintf("%v Finney", new(big.Int).Div(num, Finney))
|
|
|
|
case num.Cmp(Szabo) >= 0:
|
|
|
|
return fmt.Sprintf("%v Szabo", new(big.Int).Div(num, Szabo))
|
2014-05-20 14:53:34 +02:00
|
|
|
case num.Cmp(Shannon) >= 0:
|
|
|
|
return fmt.Sprintf("%v Shannon", new(big.Int).Div(num, Shannon))
|
|
|
|
case num.Cmp(Babbage) >= 0:
|
|
|
|
return fmt.Sprintf("%v Babbage", new(big.Int).Div(num, Babbage))
|
|
|
|
case num.Cmp(Ada) >= 0:
|
|
|
|
return fmt.Sprintf("%v Ada", new(big.Int).Div(num, Ada))
|
2014-02-25 11:20:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return fmt.Sprintf("%v Wei", num)
|
|
|
|
}
|
2014-03-21 18:22:47 +01:00
|
|
|
|
2014-04-27 17:15:44 +02:00
|
|
|
// Common big integers often used
|
2014-03-21 18:22:47 +01:00
|
|
|
var (
|
|
|
|
Big1 = big.NewInt(1)
|
2014-03-24 13:20:34 +01:00
|
|
|
Big2 = big.NewInt(1)
|
2014-03-21 18:22:47 +01:00
|
|
|
Big0 = big.NewInt(0)
|
2014-04-27 16:50:44 +02:00
|
|
|
Big32 = big.NewInt(32)
|
2014-03-21 18:22:47 +01:00
|
|
|
Big256 = big.NewInt(0xff)
|
|
|
|
)
|
2014-04-27 16:50:44 +02:00
|
|
|
|
2014-04-27 17:15:44 +02:00
|
|
|
// Creates an ethereum address given the bytes and the nonce
|
2014-04-27 16:50:44 +02:00
|
|
|
func CreateAddress(b []byte, nonce *big.Int) []byte {
|
|
|
|
addrBytes := append(b, nonce.Bytes()...)
|
|
|
|
|
|
|
|
return Sha3Bin(addrBytes)[12:]
|
|
|
|
}
|