summaryrefslogtreecommitdiff
path: root/internal/appconfig
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-02-11 20:48:01 +0200
committerPaul Buetow <paul@buetow.org>2026-02-11 20:48:01 +0200
commit8312a19b4e1f9849aae9912433824b19e03a8daf (patch)
tree8ca381d8a6549e94b15a5c65f688a353f0da98ca /internal/appconfig
parent97b8887fb3448fd08524111d98425859bec8789f (diff)
refactor: consolidate cache and state into .local/hexai directory
Move all cache and state files under ~/.local/hexai/ with subdirectories: - ~/.local/hexai/cache/ (was ~/.cache/hexai/) - ~/.local/hexai/state/ (was ~/.local/state/hexai/) - ~/.local/hexai/data/ (was ~/.local/share/hexai/) This centralizes all non-config hexai files under a single .local/hexai directory, making it easier to manage and back up user data. Amp-Thread-ID: https://ampcode.com/threads/T-019c4e03-73db-70a2-ae27-3e1cc31d59c3 Co-authored-by: Amp <amp@ampcode.com>
Diffstat (limited to 'internal/appconfig')
-rw-r--r--internal/appconfig/config.go6
-rw-r--r--internal/appconfig/config_test.go8
2 files changed, 7 insertions, 7 deletions
diff --git a/internal/appconfig/config.go b/internal/appconfig/config.go
index 859b2c1..8ae9597 100644
--- a/internal/appconfig/config.go
+++ b/internal/appconfig/config.go
@@ -1284,7 +1284,7 @@ func ConfigPath() (string, error) {
return configPath, nil
}
-// StateDir returns the XDG state directory for hexai (~/.local/state/hexai by default).
+// StateDir returns the XDG state directory for hexai (~/.local/hexai/state by default).
// Creates the directory if it doesn't exist. This is used for persistent state data
// like logs and history that should survive reboots.
func StateDir() (string, error) {
@@ -1294,10 +1294,10 @@ func StateDir() (string, error) {
if err != nil {
return "", fmt.Errorf("cannot find user home directory: %v", err)
}
- stateHome = filepath.Join(home, ".local", "state")
+ stateHome = filepath.Join(home, ".local", "hexai")
}
- stateDir := filepath.Join(stateHome, "hexai")
+ stateDir := filepath.Join(stateHome, "state")
if err := os.MkdirAll(stateDir, 0o755); err != nil {
return "", fmt.Errorf("cannot create state directory: %v", err)
}
diff --git a/internal/appconfig/config_test.go b/internal/appconfig/config_test.go
index ed7254c..cf9a725 100644
--- a/internal/appconfig/config_test.go
+++ b/internal/appconfig/config_test.go
@@ -321,7 +321,7 @@ func TestStateDir_XDG(t *testing.T) {
if err != nil {
t.Fatalf("StateDir: %v", err)
}
- expected := filepath.Join(dir, "hexai")
+ expected := filepath.Join(dir, "state")
if stateDir != expected {
t.Fatalf("expected %q, got %q", expected, stateDir)
}
@@ -337,9 +337,9 @@ func TestStateDir_Default(t *testing.T) {
if err != nil {
t.Fatalf("StateDir: %v", err)
}
- // Should default to ~/.local/state/hexai
- if !strings.Contains(stateDir, ".local/state/hexai") {
- t.Fatalf("expected path to contain .local/state/hexai, got %q", stateDir)
+ // Should default to ~/.local/hexai/state
+ if !strings.Contains(stateDir, ".local/hexai/state") {
+ t.Fatalf("expected path to contain .local/hexai/state, got %q", stateDir)
}
// Verify directory was created
if _, err := os.Stat(stateDir); err != nil {