-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathconfigdir.go
82 lines (68 loc) · 2.29 KB
/
configdir.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package configdir
import (
"os"
"path/filepath"
)
// VERSION is the semantic version number of the configdir library.
const VERSION = "0.1.0"
func init() {
findPaths()
}
// Refresh will rediscover the config paths, checking current environment
// variables again.
//
// This function is automatically called when the program initializes. If you
// change the environment variables at run-time, though, you may call the
// Refresh() function to reevaluate the config paths.
func Refresh() {
findPaths()
}
// SystemConfig returns the system-wide configuration paths, with optional path
// components added to the end for vendor/application-specific settings.
func SystemConfig(folder ...string) []string {
if len(folder) == 0 {
return systemConfig
}
var paths []string
for _, root := range systemConfig {
p := append([]string{root}, filepath.Join(folder...))
paths = append(paths, filepath.Join(p...))
}
return paths
}
// LocalConfig returns the local user configuration path, with optional
// path components added to the end for vendor/application-specific settings.
func LocalConfig(folder ...string) string {
if len(folder) == 0 {
return localConfig
}
return filepath.Join(localConfig, filepath.Join(folder...))
}
// LocalCache returns the local user cache folder, with optional path
// components added to the end for vendor/application-specific settings.
func LocalCache(folder ...string) string {
if len(folder) == 0 {
return localCache
}
return filepath.Join(localCache, filepath.Join(folder...))
}
// DefaultFileMode controls the default permissions on any paths created by
// using MakePath.
var DefaultFileMode = os.FileMode(0755)
// MakePath ensures that the full path you wanted, including vendor or
// application-specific components, exists. You can give this the output of
// any of the config path functions (SystemConfig, LocalConfig or LocalCache).
//
// In the event that the path function gives multiple answers, e.g. for
// SystemConfig, MakePath() will only attempt to create the sub-folders on
// the *first* path found. If this isn't what you want, you may want to just
// use the os.MkdirAll() functionality directly.
func MakePath(paths ...string) error {
if len(paths) >= 1 {
err := os.MkdirAll(paths[0], DefaultFileMode)
if err != nil {
return err
}
}
return nil
}