diff options
author | zelig <viktor.tron@gmail.com> | 2014-08-12 20:56:10 +0800 |
---|---|---|
committer | zelig <viktor.tron@gmail.com> | 2014-08-12 20:56:10 +0800 |
commit | e85f3972b9b4648666c6b50fff04938e3206ff96 (patch) | |
tree | f70f6d8d0179709ee01eef19c9708197b89248ae /ethcrypto/mnemonic.go | |
parent | a760ce05b948e89bc564af20599dcf95698ac0eb (diff) | |
download | go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.tar go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.tar.gz go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.tar.bz2 go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.tar.lz go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.tar.xz go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.tar.zst go-tangerine-e85f3972b9b4648666c6b50fff04938e3206ff96.zip |
inline mnemonic wordlist to support binary builds without extra asset
Diffstat (limited to 'ethcrypto/mnemonic.go')
-rw-r--r-- | ethcrypto/mnemonic.go | 40 |
1 files changed, 6 insertions, 34 deletions
diff --git a/ethcrypto/mnemonic.go b/ethcrypto/mnemonic.go index 2d3ac85a3..5fb620219 100644 --- a/ethcrypto/mnemonic.go +++ b/ethcrypto/mnemonic.go @@ -2,37 +2,9 @@ package ethcrypto import ( "fmt" - "io/ioutil" - "os" - "path" - "path/filepath" "strconv" - "strings" ) -func InitWords(wordsPath string) { - filename := path.Join(wordsPath, "mnemonic.words.lst") - if _, err := os.Stat(filename); os.IsNotExist(err) { - dir := path.Join(os.Getenv("GOPATH"), "src", "github.com", "ethereum", "eth-go", "ethcrypto") - filename = path.Join(dir, "mnemonic.words.lst") - if _, err := os.Stat(filename); os.IsNotExist(err) { - dir, err := filepath.Abs(filepath.Dir(os.Args[0])) - if err != nil { - panic(fmt.Errorf("problem getting current folder: ", err)) - } - filename = path.Join(dir, "mnemonic.words.lst") - } - } - - content, err := ioutil.ReadFile(filename) - if err != nil { - panic(fmt.Errorf("All options for finding the mnemonic word list file 'mnemonic.words.lst' failed: ", err)) - } - words = strings.Split(string(content), "\n") -} - -var words []string - // TODO: See if we can refactor this into a shared util lib if we need it multiple times func IndexOf(slice []string, value string) int64 { for p, v := range slice { @@ -45,7 +17,7 @@ func IndexOf(slice []string, value string) int64 { func MnemonicEncode(message string) []string { var out []string - n := int64(len(words)) + n := int64(len(MnemonicWords)) for i := 0; i < len(message); i += (len(message) / 8) { x := message[i : i+8] @@ -53,22 +25,22 @@ func MnemonicEncode(message string) []string { w1 := (bit % n) w2 := ((bit / n) + w1) % n w3 := ((bit / n / n) + w2) % n - out = append(out, words[w1], words[w2], words[w3]) + out = append(out, MnemonicWords[w1], MnemonicWords[w2], MnemonicWords[w3]) } return out } func MnemonicDecode(wordsar []string) string { var out string - n := int64(len(words)) + n := int64(len(MnemonicWords)) for i := 0; i < len(wordsar); i += 3 { word1 := wordsar[i] word2 := wordsar[i+1] word3 := wordsar[i+2] - w1 := IndexOf(words, word1) - w2 := IndexOf(words, word2) - w3 := IndexOf(words, word3) + w1 := IndexOf(MnemonicWords, word1) + w2 := IndexOf(MnemonicWords, word2) + w3 := IndexOf(MnemonicWords, word3) y := (w2 - w1) % n z := (w3 - w2) % n |