aboutsummaryrefslogtreecommitdiff
path: root/main.go
diff options
context:
space:
mode:
authorTulir Asokan <tulir@maunium.net>2020-04-28 22:00:37 +0300
committerTulir Asokan <tulir@maunium.net>2020-04-28 22:00:37 +0300
commitfa04323daffb8bf783ba438065a5ce47b2994bea (patch)
treee1976c16a0bd40e3f3db895cc1d848ea3be97b1a /main.go
parent92d4279b216987ebdfbea4577965ffb192e7726a (diff)
Update mautrix-go and move crypto store to XDG_DATA_HOME
Diffstat (limited to 'main.go')
-rw-r--r--main.go86
1 files changed, 57 insertions, 29 deletions
diff --git a/main.go b/main.go
index 3b4a499..2db06b2 100644
--- a/main.go
+++ b/main.go
@@ -48,24 +48,32 @@ func main() {
debug.Initialize()
defer debug.Recover()
- configDir, err := UserConfigDir()
+ var configDir, dataDir, cacheDir, downloadDir string
+ var err error
+
+ configDir, err = UserConfigDir()
if err != nil {
- fmt.Fprintln(os.Stderr, "Failed to get config directory:", err)
+ _, _ = fmt.Fprintln(os.Stderr, "Failed to get config directory:", err)
os.Exit(3)
}
- cacheDir, err := UserCacheDir()
+ dataDir, err = UserDataDir()
if err != nil {
- fmt.Fprintln(os.Stderr, "Failed to get cache directory:", err)
+ _, _ = fmt.Fprintln(os.Stderr, "Failed to get data directory:", err)
os.Exit(3)
}
- downloadDir, err := UserDownloadDir()
+ cacheDir, err = UserCacheDir()
if err != nil {
- fmt.Fprintln(os.Stderr, "Failed to get download directory:", err)
+ _, _ = fmt.Fprintln(os.Stderr, "Failed to get cache directory:", err)
+ os.Exit(3)
+ }
+ downloadDir, err = UserDownloadDir()
+ if err != nil {
+ _, _ = fmt.Fprintln(os.Stderr, "Failed to get download directory:", err)
os.Exit(3)
}
- gmx := NewGomuks(MainUIProvider, configDir, cacheDir, downloadDir)
+ gmx := NewGomuks(MainUIProvider, configDir, dataDir, cacheDir, downloadDir)
gmx.Start()
// We use os.Exit() everywhere, so exiting by returning from Start() shouldn't happen.
@@ -74,43 +82,63 @@ func main() {
os.Exit(2)
}
+func getRootDir(subdir string) string {
+ rootDir := os.Getenv("GOMUKS_ROOT")
+ if rootDir == "" {
+ return ""
+ }
+ return filepath.Join(rootDir, subdir)
+}
+
func UserCacheDir() (dir string, err error) {
dir = os.Getenv("GOMUKS_CACHE_HOME")
if dir == "" {
+ dir = getRootDir("cache")
+ }
+ if dir == "" {
dir, err = os.UserCacheDir()
dir = filepath.Join(dir, "gomuks")
}
return
}
-func UserDownloadDir() (dir string, err error) {
- dir = os.Getenv("HOME")
- return filepath.Join(dir, "Downloads"), nil
-}
-
-func UserConfigDir() (dir string, err error) {
- dir = os.Getenv("GOMUKS_CONFIG_HOME")
+func UserDataDir() (dir string, err error) {
+ dir = os.Getenv("GOMUKS_DATA_HOME")
if dir != "" {
return
}
- if runtime.GOOS == "windows" {
- dir = os.Getenv("AppData")
- if dir == "" {
- err = errors.New("%AppData% is not defined")
- }
- } else {
- dir = os.Getenv("XDG_CONFIG_HOME")
+ if runtime.GOOS == "windows" || runtime.GOOS == "darwin" {
+ return UserConfigDir()
+ }
+ dir = os.Getenv("XDG_DATA_HOME")
+ if dir == "" {
+ dir = getRootDir("data")
+ }
+ if dir == "" {
+ dir = os.Getenv("HOME")
if dir == "" {
- dir = os.Getenv("HOME")
- if dir == "" {
- err = errors.New("neither $XDG_CONFIG_HOME nor $HOME are defined")
- } else if runtime.GOOS == "darwin" {
- dir = filepath.Join(dir, "Library", "Application Support")
- } else {
- dir = filepath.Join(dir, ".config")
- }
+ return "", errors.New("neither $XDG_CACHE_HOME nor $HOME are defined")
}
+ dir = filepath.Join(dir, ".local", "share")
}
dir = filepath.Join(dir, "gomuks")
return
}
+
+func UserDownloadDir() (dir string, err error) {
+ dir, err = os.UserHomeDir()
+ dir = filepath.Join(dir, "Downloads")
+ return
+}
+
+func UserConfigDir() (dir string, err error) {
+ dir = os.Getenv("GOMUKS_CONFIG_HOME")
+ if dir == "" {
+ dir = getRootDir("cache")
+ }
+ if dir == "" {
+ dir, err = os.UserConfigDir()
+ dir = filepath.Join(dir, "gomuks")
+ }
+ return
+}