aboutsummaryrefslogtreecommitdiffstats
path: root/ethutil/common.go
diff options
context:
space:
mode:
authorJeffrey Wilcke <jeffrey@ethereum.org>2015-02-26 17:59:07 +0800
committerJeffrey Wilcke <jeffrey@ethereum.org>2015-02-26 17:59:07 +0800
commit5b202a158adedfea4d0be734e473bccdf103d987 (patch)
tree4e4ac05bb15d2ee2d035695d67f04ee4b4974df7 /ethutil/common.go
parent46ce66a82905185b2b42803d58f5d8f00431e03c (diff)
parent57cea0c623ed808ad134bd62610afb6b842f5d0d (diff)
downloaddexon-5b202a158adedfea4d0be734e473bccdf103d987.tar.gz
dexon-5b202a158adedfea4d0be734e473bccdf103d987.tar.zst
dexon-5b202a158adedfea4d0be734e473bccdf103d987.zip
Merge pull request #391 from tgerring/osext
Cleanup DefaultAssetPath
Diffstat (limited to 'ethutil/common.go')
-rw-r--r--ethutil/common.go29
1 files changed, 29 insertions, 0 deletions
diff --git a/ethutil/common.go b/ethutil/common.go
index efc519732..c4e7415dc 100644
--- a/ethutil/common.go
+++ b/ethutil/common.go
@@ -3,12 +3,41 @@ package ethutil
import (
"fmt"
"math/big"
+ "os"
"os/user"
"path"
+ "path/filepath"
"runtime"
"time"
+
+ "github.com/kardianos/osext"
)
+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", "cmd", "mist") {
+ 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/mist"
+ case "windows":
+ assetPath = "./assets"
+ default:
+ assetPath = "."
+ }
+ }
+ return assetPath
+}
+
func DefaultDataDir() string {
usr, _ := user.Current()
if runtime.GOOS == "darwin" {