diff options
author | Maran <maran.hidskes@gmail.com> | 2014-07-15 18:52:30 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-07-15 18:52:30 +0800 |
commit | c0ae5c58a6b3d78540ec19b24bd31b6e14e24191 (patch) | |
tree | 0b02682a4fa2d9dd2c93026002b22e25118669a8 /utils | |
parent | e53acdc2ac45fa8953afc3392ed81653d6f26326 (diff) | |
download | dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.tar dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.tar.gz dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.tar.bz2 dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.tar.lz dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.tar.xz dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.tar.zst dexon-c0ae5c58a6b3d78540ec19b24bd31b6e14e24191.zip |
Rewrote mnemonic word loading to facilitate deployable builds.
Diffstat (limited to 'utils')
-rw-r--r-- | utils/cmd.go | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/utils/cmd.go b/utils/cmd.go index 889726b04..fac164b47 100644 --- a/utils/cmd.go +++ b/utils/cmd.go @@ -1,6 +1,7 @@ package utils import ( + "bitbucket.org/kardianos/osext" "fmt" "github.com/ethereum/eth-go" "github.com/ethereum/eth-go/ethcrypto" @@ -16,6 +17,8 @@ import ( "os" "os/signal" "path" + "path/filepath" + "runtime" "time" ) @@ -164,7 +167,33 @@ func NewKeyManager(KeyStore string, Datadir string, db ethutil.Database) *ethcry return keyManager } +func DefaultAssetPath() string { + var assetPath string + // If the current working directory is the go-ethereum dir + // assume a debug build and use the source directory as + // asset directory. + pwd, _ := os.Getwd() + if pwd == path.Join(os.Getenv("GOPATH"), "src", "github.com", "ethereum", "go-ethereum", "ethereal") { + assetPath = path.Join(pwd, "assets") + } else { + switch runtime.GOOS { + case "darwin": + // Get Binary Directory + exedir, _ := osext.ExecutableFolder() + assetPath = filepath.Join(exedir, "../Resources") + case "linux": + assetPath = "/usr/share/ethereal" + case "windows": + assetPath = "./assets" + default: + assetPath = "." + } + } + return assetPath +} func KeyTasks(keyManager *ethcrypto.KeyManager, KeyRing string, GenAddr bool, SecretFile string, ExportDir string, NonInteractive bool) { + ethcrypto.InitWords(DefaultAssetPath()) // Init mnemonic word list + var err error switch { case GenAddr: |