aboutsummaryrefslogtreecommitdiffstats
path: root/utils
diff options
context:
space:
mode:
authorMaran <maran.hidskes@gmail.com>2014-07-15 18:52:30 +0800
committerMaran <maran.hidskes@gmail.com>2014-07-15 18:52:30 +0800
commitc0ae5c58a6b3d78540ec19b24bd31b6e14e24191 (patch)
tree0b02682a4fa2d9dd2c93026002b22e25118669a8 /utils
parente53acdc2ac45fa8953afc3392ed81653d6f26326 (diff)
downloaddexon-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.go29
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: