mirror of
https://gitea.com/gitea/tea.git
synced 2026-04-26 02:03:30 +02:00
## Summary - Extract duplicate \`getReleaseByTag\` into shared \`cmd/releases/utils.go\` - Replace \`log.Fatal\` calls with proper error returns in config and login commands; \`GetLoginByToken\`/\`GetLoginsByHost\`/\`GetLoginByHost\` now return errors - Remove dead \`portChan\` channel in \`modules/auth/oauth.go\` - Fix YAML integer detection to use \`strconv.ParseInt\` (correctly handles negatives and large ints) - Fix \`path.go\` error handling to use \`errors.As\` + \`syscall.ENOTDIR\` instead of string comparison - Extract repeated credential helper key into local variable in \`SetupHelper\` - Use existing \`isRemoteDeleted()\` in \`pull_clean.go\` instead of duplicating the logic - Fix ~30 error message casing violations to follow Go conventions - Use \`fmt.Errorf\` consistently instead of string concatenation in \`generic.go\` Reviewed-on: https://gitea.com/gitea/tea/pulls/947 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: Bo-Yi Wu (吳柏毅) <appleboy.tw@gmail.com> Co-authored-by: Nicolas <bircni@icloud.com> Co-committed-by: Nicolas <bircni@icloud.com>
73 lines
1.6 KiB
Go
73 lines
1.6 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package utils
|
|
|
|
import (
|
|
"errors"
|
|
"os"
|
|
"os/user"
|
|
"path/filepath"
|
|
"strings"
|
|
"syscall"
|
|
)
|
|
|
|
// PathExists returns whether the given file or directory exists or not
|
|
func PathExists(path string) (bool, error) {
|
|
_, err := os.Stat(path)
|
|
if err == nil {
|
|
return true, nil
|
|
}
|
|
if os.IsNotExist(err) {
|
|
return false, nil
|
|
}
|
|
return true, err
|
|
}
|
|
|
|
// FileExist returns whether the given file exists or not
|
|
func FileExist(fileName string) (bool, error) {
|
|
return exists(fileName, false)
|
|
}
|
|
|
|
// DirExists returns whether the given file exists or not
|
|
func DirExists(path string) (bool, error) {
|
|
return exists(path, true)
|
|
}
|
|
|
|
func exists(path string, expectDir bool) (bool, error) {
|
|
f, err := os.Stat(path)
|
|
if err != nil {
|
|
if errors.Is(err, os.ErrNotExist) {
|
|
return false, nil
|
|
}
|
|
var pathErr *os.PathError
|
|
if errors.As(err, &pathErr) && errors.Is(pathErr.Err, syscall.ENOTDIR) {
|
|
// a middle segment of path is a file, cannot traverse
|
|
return false, nil
|
|
}
|
|
return false, err
|
|
}
|
|
isDir := f.IsDir()
|
|
if isDir && !expectDir {
|
|
return false, errors.New("a directory with the same name exists")
|
|
} else if !isDir && expectDir {
|
|
return false, errors.New("a file with the same name exists")
|
|
}
|
|
return true, nil
|
|
}
|
|
|
|
// AbsPathWithExpansion expand path beginning with "~/" to absolute path
|
|
func AbsPathWithExpansion(p string) (string, error) {
|
|
u, err := user.Current()
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
if p == "~" {
|
|
return u.HomeDir, nil
|
|
}
|
|
if strings.HasPrefix(p, "~/") {
|
|
return filepath.Join(u.HomeDir, p[2:]), nil
|
|
}
|
|
return filepath.Abs(p)
|
|
}
|