2019-05-17 06:28:50 +03:00
|
|
|
// Copyright (c) 2014-present, b3log.org
|
2014-12-18 10:20:36 +03:00
|
|
|
//
|
2014-11-12 18:13:14 +03:00
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
2014-12-18 10:20:36 +03:00
|
|
|
//
|
2018-03-12 07:28:33 +03:00
|
|
|
// https://www.apache.org/licenses/LICENSE-2.0
|
2014-12-18 10:20:36 +03:00
|
|
|
//
|
2014-11-12 18:13:14 +03:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2014-10-26 10:41:34 +03:00
|
|
|
package util
|
|
|
|
|
|
|
|
import (
|
2015-02-16 05:06:17 +03:00
|
|
|
"bytes"
|
|
|
|
"errors"
|
2014-10-28 09:38:27 +03:00
|
|
|
"os"
|
|
|
|
"os/exec"
|
2015-02-16 05:15:09 +03:00
|
|
|
"os/user"
|
2014-10-28 09:38:27 +03:00
|
|
|
"path/filepath"
|
2014-10-26 10:41:34 +03:00
|
|
|
"runtime"
|
2015-02-16 05:06:17 +03:00
|
|
|
"strings"
|
2014-10-26 10:41:34 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
type myos struct{}
|
|
|
|
|
2014-10-29 13:15:18 +03:00
|
|
|
// OS utilities.
|
2014-10-26 10:41:34 +03:00
|
|
|
var OS = myos{}
|
|
|
|
|
2014-10-29 13:15:18 +03:00
|
|
|
// IsWindows determines whether current OS is Windows.
|
2014-10-26 10:41:34 +03:00
|
|
|
func (*myos) IsWindows() bool {
|
|
|
|
return "windows" == runtime.GOOS
|
|
|
|
}
|
2014-10-28 09:38:27 +03:00
|
|
|
|
2014-10-29 13:15:18 +03:00
|
|
|
// Pwd gets the path of current working directory.
|
2014-10-28 09:38:27 +03:00
|
|
|
func (*myos) Pwd() string {
|
|
|
|
file, _ := exec.LookPath(os.Args[0])
|
|
|
|
pwd, _ := filepath.Abs(file)
|
|
|
|
|
|
|
|
return filepath.Dir(pwd)
|
|
|
|
}
|
2015-02-16 05:06:17 +03:00
|
|
|
|
|
|
|
// Home returns the home directory for the executing user.
|
|
|
|
//
|
|
|
|
// This uses an OS-specific method for discovering the home directory.
|
|
|
|
// An error is returned if a home directory cannot be detected.
|
|
|
|
func (*myos) Home() (string, error) {
|
2015-02-16 05:15:09 +03:00
|
|
|
user, err := user.Current()
|
|
|
|
if nil == err {
|
|
|
|
return user.HomeDir, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// cross compile support
|
2015-02-16 09:06:57 +03:00
|
|
|
|
2015-02-16 05:06:17 +03:00
|
|
|
if OS.IsWindows() {
|
|
|
|
return homeWindows()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unix-like system, so just assume Unix
|
|
|
|
return homeUnix()
|
|
|
|
}
|
|
|
|
|
|
|
|
func homeUnix() (string, error) {
|
|
|
|
// First prefer the HOME environmental variable
|
|
|
|
if home := os.Getenv("HOME"); home != "" {
|
|
|
|
return home, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// If that fails, try the shell
|
|
|
|
var stdout bytes.Buffer
|
|
|
|
cmd := exec.Command("sh", "-c", "eval echo ~$USER")
|
|
|
|
cmd.Stdout = &stdout
|
|
|
|
if err := cmd.Run(); err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
|
|
|
|
result := strings.TrimSpace(stdout.String())
|
|
|
|
if result == "" {
|
|
|
|
return "", errors.New("blank output when reading home directory")
|
|
|
|
}
|
|
|
|
|
|
|
|
return result, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func homeWindows() (string, error) {
|
|
|
|
drive := os.Getenv("HOMEDRIVE")
|
|
|
|
path := os.Getenv("HOMEPATH")
|
|
|
|
home := drive + path
|
|
|
|
if drive == "" || path == "" {
|
|
|
|
home = os.Getenv("USERPROFILE")
|
|
|
|
}
|
|
|
|
if home == "" {
|
|
|
|
return "", errors.New("HOMEDRIVE, HOMEPATH, and USERPROFILE are blank")
|
|
|
|
}
|
|
|
|
|
|
|
|
return home, nil
|
|
|
|
}
|