2015-02-06 18:18:49 +00:00
|
|
|
package homedir
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"runtime"
|
2015-03-10 13:55:55 +00:00
|
|
|
|
|
|
|
"github.com/docker/libcontainer/user"
|
2015-02-06 18:18:49 +00:00
|
|
|
)
|
|
|
|
|
2015-02-06 22:17:34 +00:00
|
|
|
// Key returns the env var name for the user's home dir based on
|
|
|
|
// the platform being run on
|
|
|
|
func Key() string {
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
return "USERPROFILE"
|
|
|
|
}
|
|
|
|
return "HOME"
|
|
|
|
}
|
|
|
|
|
2015-02-06 18:18:49 +00:00
|
|
|
// Get returns the home directory of the current user with the help of
|
|
|
|
// environment variables depending on the target operating system.
|
|
|
|
// Returned path should be used with "path/filepath" to form new paths.
|
|
|
|
func Get() string {
|
2015-03-10 13:55:55 +00:00
|
|
|
home := os.Getenv(Key())
|
|
|
|
if home == "" && runtime.GOOS != "windows" {
|
|
|
|
if u, err := user.CurrentUser(); err == nil {
|
|
|
|
return u.Home
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return home
|
2015-02-06 18:18:49 +00:00
|
|
|
}
|
2015-02-19 06:53:04 +00:00
|
|
|
|
|
|
|
// GetShortcutString returns the string that is shortcut to user's home directory
|
|
|
|
// in the native shell of the platform running on.
|
|
|
|
func GetShortcutString() string {
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
return "%USERPROFILE%" // be careful while using in format functions
|
|
|
|
}
|
|
|
|
return "~"
|
|
|
|
}
|