mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-01-24 05:36:19 +02:00
1dd7307fde
more and more move rebase commit refreshing into existing abstraction and more and more WIP and more handling clicks properly fix merge conflicts update cheatsheet lots more preparation to start moving things into controllers WIP better typing expand on remotes controller moving more code into controllers
67 lines
2.0 KiB
Go
67 lines
2.0 KiB
Go
package gui
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/commands/oscommands"
|
|
"github.com/jesseduffield/lazygit/pkg/gui/style"
|
|
"github.com/jesseduffield/lazygit/pkg/gui/types"
|
|
)
|
|
|
|
// Currently there is a bug where if we switch to a subprocess from within
|
|
// WithWaitingStatus we get stuck there and can't return to lazygit. We could
|
|
// fix this bug, or just stop running subprocesses from within there, given that
|
|
// we don't need to see a loading status if we're in a subprocess.
|
|
// TODO: work out if we actually need to use a shell command here
|
|
func (gui *Gui) withGpgHandling(cmdObj oscommands.ICmdObj, waitingStatus string, onSuccess func() error) error {
|
|
gui.LogCommand(cmdObj.ToString(), true)
|
|
|
|
useSubprocess := gui.git.Config.UsingGpg()
|
|
if useSubprocess {
|
|
success, err := gui.runSubprocessWithSuspense(gui.OSCommand.Cmd.NewShell(cmdObj.ToString()))
|
|
if success && onSuccess != nil {
|
|
if err := onSuccess(); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
if err := gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC}); err != nil {
|
|
return err
|
|
}
|
|
|
|
return err
|
|
} else {
|
|
return gui.RunAndStream(cmdObj, waitingStatus, onSuccess)
|
|
}
|
|
}
|
|
|
|
func (gui *Gui) RunAndStream(cmdObj oscommands.ICmdObj, waitingStatus string, onSuccess func() error) error {
|
|
return gui.c.WithWaitingStatus(waitingStatus, func() error {
|
|
cmdObj := gui.OSCommand.Cmd.NewShell(cmdObj.ToString())
|
|
cmdObj.AddEnvVars("TERM=dumb")
|
|
cmdWriter := gui.getCmdWriter()
|
|
cmd := cmdObj.GetCmd()
|
|
cmd.Stdout = cmdWriter
|
|
cmd.Stderr = cmdWriter
|
|
|
|
if err := cmd.Run(); err != nil {
|
|
if _, err := cmd.Stdout.Write([]byte(fmt.Sprintf("%s\n", style.FgRed.Sprint(err.Error())))); err != nil {
|
|
gui.c.Log.Error(err)
|
|
}
|
|
_ = gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
|
|
return gui.c.Error(
|
|
fmt.Errorf(
|
|
gui.c.Tr.GitCommandFailed, gui.c.UserConfig.Keybinding.Universal.ExtrasMenu,
|
|
),
|
|
)
|
|
}
|
|
|
|
if onSuccess != nil {
|
|
if err := onSuccess(); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
|
|
})
|
|
}
|