mirror of
https://github.com/JetSetIlly/Gopher2600.git
synced 2024-05-20 13:48:02 -04:00
fixed JoinPath() in resources packages so that it is safe to call repeatdely
running resources.JoinPath() on the results of a previous call caused the OS/build base path to be prepended again. the function now checks to see if the base path already exists.
This commit is contained in:
parent
fb48996106
commit
a376a59a1d
|
@ -18,27 +18,35 @@ package resources
|
|||
import (
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
|
||||
"github.com/jetsetilly/gopher2600/resources/fs"
|
||||
)
|
||||
|
||||
// JoinPath prepends the supplied path with a with OS/build specific base
|
||||
// paths
|
||||
// paths, if required.
|
||||
//
|
||||
// The function creates all folders necessary to reach the end of sub-path. It
|
||||
// does not otherwise touch or create the file.
|
||||
func JoinPath(path ...string) (string, error) {
|
||||
// join supplied path
|
||||
p := filepath.Join(path...)
|
||||
|
||||
// do not prepend OS/build specific base path if it is already present
|
||||
b, err := baseResourcePath()
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
if !strings.HasPrefix(p, b) {
|
||||
p = filepath.Join(b, filepath.Join(path...))
|
||||
}
|
||||
|
||||
p := filepath.Join(b, filepath.Join(path...))
|
||||
|
||||
// check if path already exists
|
||||
if _, err := os.Stat(p); err == nil {
|
||||
return p, nil
|
||||
}
|
||||
|
||||
// create path if necessary
|
||||
if err := fs.MkdirAll(filepath.Dir(p), 0700); err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue