mirror of
https://github.com/Jguer/yay
synced 2024-10-31 04:12:51 +00:00
Fix error when cacheHome does not exist
And refactor initYay out into smaller parts
This commit is contained in:
parent
251d31c970
commit
74ef0beaed
2 changed files with 43 additions and 28 deletions
55
cmd.go
55
cmd.go
|
@ -62,14 +62,7 @@ Yay specific options:
|
|||
If no operation is provided -Y will be assumed`)
|
||||
}
|
||||
|
||||
func initYay() (err error) {
|
||||
var configHome string // configHome handles config directory home
|
||||
var cacheHome string // cacheHome handles cache home
|
||||
|
||||
if 0 == os.Geteuid() {
|
||||
fmt.Println("Please avoid running yay as root/sudo.")
|
||||
}
|
||||
|
||||
func initPaths() {
|
||||
if configHome = os.Getenv("XDG_CONFIG_HOME"); configHome != "" {
|
||||
if info, err := os.Stat(configHome); err == nil && info.IsDir() {
|
||||
configHome = configHome + "/yay"
|
||||
|
@ -93,12 +86,9 @@ func initYay() (err error) {
|
|||
configFile = configHome + "/" + configFileName
|
||||
vcsFile = cacheHome + "/" + vcsFileName
|
||||
completionFile = cacheHome + "/" + completionFilePrefix
|
||||
}
|
||||
|
||||
////////////////
|
||||
// yay config //
|
||||
////////////////
|
||||
defaultSettings(&config)
|
||||
|
||||
func initConfig() (err error) {
|
||||
if _, err = os.Stat(configFile); os.IsNotExist(err) {
|
||||
err = os.MkdirAll(filepath.Dir(configFile), 0755)
|
||||
if err != nil {
|
||||
|
@ -124,24 +114,31 @@ func initYay() (err error) {
|
|||
}
|
||||
}
|
||||
|
||||
/////////////////
|
||||
// vcs config //
|
||||
////////////////
|
||||
defaultSettings(&config)
|
||||
return
|
||||
}
|
||||
|
||||
func initVCS() (err error) {
|
||||
if _, err = os.Stat(vcsFile); os.IsNotExist(err) {
|
||||
err = os.MkdirAll(filepath.Dir(vcsFile), 0755)
|
||||
if err != nil {
|
||||
err = fmt.Errorf("Unable to create vcs directory:\n%s\n"+
|
||||
"The error was:\n%s", filepath.Dir(configFile), err)
|
||||
return
|
||||
}
|
||||
} else {
|
||||
vfile, err := os.OpenFile(vcsFile, os.O_RDONLY|os.O_CREATE, 0644)
|
||||
if err == nil {
|
||||
defer vfile.Close()
|
||||
decoder := json.NewDecoder(vfile)
|
||||
_ = decoder.Decode(&savedInfo)
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
func initAlpm() (err error) {
|
||||
/////////////////
|
||||
// alpm config //
|
||||
/////////////////
|
||||
|
||||
var value string
|
||||
var exists bool
|
||||
//var double bool
|
||||
|
@ -199,6 +196,10 @@ func main() {
|
|||
var status int
|
||||
var err error
|
||||
|
||||
if 0 == os.Geteuid() {
|
||||
fmt.Println("Please avoid running yay as root/sudo.")
|
||||
}
|
||||
|
||||
err = cmdArgs.parseCommandLine()
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
|
@ -206,13 +207,23 @@ func main() {
|
|||
goto cleanup
|
||||
}
|
||||
|
||||
err = initYay()
|
||||
initPaths()
|
||||
|
||||
err = initConfig()
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
status = 1
|
||||
goto cleanup
|
||||
}
|
||||
|
||||
err = initVCS()
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
status = 1
|
||||
goto cleanup
|
||||
|
||||
}
|
||||
|
||||
err = initAlpm()
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
|
@ -227,8 +238,6 @@ func main() {
|
|||
goto cleanup
|
||||
}
|
||||
|
||||
//ive used a goto here
|
||||
//i think its the best way to do this sort of thing
|
||||
cleanup:
|
||||
//cleanup
|
||||
//from here on out dont exit if an error occurs
|
||||
|
|
|
@ -55,6 +55,12 @@ const completionFilePrefix string = "aur_"
|
|||
// baseURL givers the AUR default address.
|
||||
const baseURL string = "https://aur.archlinux.org"
|
||||
|
||||
// configHome handles config directory home
|
||||
var configHome string
|
||||
|
||||
// cacheHome handles cache home
|
||||
var cacheHome string
|
||||
|
||||
// savedInfo holds the current vcs info
|
||||
var savedInfo vcsInfo
|
||||
|
||||
|
|
Loading…
Reference in a new issue