Skip to content

Commit

Permalink
Merge pull request #225 from carapace-sh/zsh-source-user-rc
Browse files Browse the repository at this point in the history
zsh: source .zshrc for custom `fpath` directories
  • Loading branch information
rsteube authored Dec 6, 2024
2 parents 4ad49d2 + 3692bd3 commit a950ca3
Showing 1 changed file with 30 additions and 3 deletions.
33 changes: 30 additions & 3 deletions pkg/bridges/zsh.go
Original file line number Diff line number Diff line change
@@ -1,13 +1,16 @@
package bridges

import (
"bytes"
"fmt"
"os"
"runtime"
"sort"
"strings"

"github.com/carapace-sh/carapace"
"github.com/carapace-sh/carapace/pkg/execlog"
"github.com/carapace-sh/carapace/pkg/xdg"
)

func Zsh() []string {
Expand All @@ -20,11 +23,23 @@ func Zsh() []string {
}

return cache("zsh", func() ([]string, error) {
out, err := execlog.Command("zsh", "--no-rcs", "-c", "printf '%s\n' $fpath").Output()
if err != nil {
script := "printf '%s\n' $fpath"
if path, err := zshrc(); err == nil {
script = fmt.Sprintf("source %v;%v", path, script)
}

var stdout, stderr bytes.Buffer
cmd := execlog.Command("zsh", "--no-rcs", "-e", "-c", script)
cmd.Stdout = &stdout
cmd.Stderr = &stderr

if err := cmd.Run(); err != nil {
if stderr.Len() > 0 {
carapace.LOG.Println(stderr.String())
}
return nil, err
}
lines := strings.Split(string(out), "\n")
lines := strings.Split(stdout.String(), "\n")

unique := make(map[string]bool)
for _, line := range lines {
Expand All @@ -49,3 +64,15 @@ func Zsh() []string {
return completers, nil
})
}

func zshrc() (string, error) {
configDir, err := xdg.UserConfigDir()
if err != nil {
return "", err
}
path := configDir + "/carapace/bridge/zsh/.zshrc"
if _, err := os.Stat(path); err != nil {
return "", err
}
return path, nil
}

0 comments on commit a950ca3

Please sign in to comment.