Skip to content

Commit

Permalink
Shell: Use ps command which works for linux and mac
Browse files Browse the repository at this point in the history
As part of 74d1f1b ps command
has `--sort=-pid` which doesn't work with macOS by default so in this
PR `--sort=-pid` option is removed and reverse sorting against pid is
implemented in `inspectProcessOutputForRecentlyUsedShell`. This way
this code works on mac/linux same way.

fixes: #4537
  • Loading branch information
praveenkumar committed Jan 2, 2025
1 parent 5c6743b commit f937504
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 3 deletions.
11 changes: 9 additions & 2 deletions pkg/os/shell/shell.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,11 @@ package shell
import (
"fmt"
"os"
"sort"
"strconv"
"strings"

"github.com/crc-org/crc/v2/pkg/crc/logging"
crcos "github.com/crc-org/crc/v2/pkg/os"
)

Expand Down Expand Up @@ -174,13 +176,13 @@ func detectShellByInvokingCommand(defaultShell string, command string, args []st
if detectedShell == "" {
return defaultShell
}
logging.Debugf("Detected shell: %s", detectedShell)
return detectedShell
}

// inspectProcessOutputForRecentlyUsedShell inspects output of ps command to detect currently active shell session.
//
// Note : This method assumes that ps command has already sorted the processes by `pid` in reverse order.
// It parses the output into a struct, filters process types by name and returns the first element.
// It parses the output into a struct, filters process types by name then reverse sort it with pid and returns the first element.
//
// It takes one argument:
//
Expand Down Expand Up @@ -222,6 +224,11 @@ func inspectProcessOutputForRecentlyUsedShell(psCommandOutput string) string {
}
}
}
// Reverse sort the processes by PID (higher to lower)
sort.Slice(processOutputs, func(i, j int) bool {
return processOutputs[i].processID > processOutputs[j].processID
})

if len(processOutputs) > 0 {
return processOutputs[0].output
}
Expand Down
2 changes: 1 addition & 1 deletion pkg/os/shell/shell_unix.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ var (

// detect detects user's current shell.
func detect() (string, error) {
detectedShell := detectShellByInvokingCommand("", "ps", []string{"-o", "pid=,comm=", "--sort=-pid"})
detectedShell := detectShellByInvokingCommand("", "ps", []string{"-o", "pid=,comm="})
if detectedShell == "" {
fmt.Printf("The default lines below are for a sh/bash shell, you can specify the shell you're using, with the --shell flag.\n\n")
return "", ErrUnknownShell
Expand Down

0 comments on commit f937504

Please sign in to comment.