mirror of https://github.com/xrehpicx/pee.git
Compare commits
7 Commits
v0.0.4-scr
...
main
Author | SHA1 | Date |
---|---|---|
|
11794e59a2 | |
|
0a8342592c | |
|
c2bf3fb9cb | |
|
b3bf15bc29 | |
|
0f3dfb20cc | |
|
6a4ac440b0 | |
|
cdeaed61f7 |
|
@ -11,7 +11,7 @@ Creating tmux sessions with preconfigured panes layouts and commands. inspired f
|
|||
|
||||
#### Installation
|
||||
```bash
|
||||
go install github.com/xrehpicx/pee@latest
|
||||
go install github.com/xrehpicx/pee.git@latest
|
||||
```
|
||||
|
||||
#### Initialize a project
|
||||
|
|
|
@ -30,6 +30,7 @@ type Configuration struct {
|
|||
LastOpened time.Time
|
||||
Attach bool `yaml:"attach"`
|
||||
StartupWindow string `yaml:"startup_window"`
|
||||
StartupPane int `yaml:"startup_pane"`
|
||||
}
|
||||
|
||||
var configDir string
|
||||
|
|
|
@ -26,7 +26,8 @@ func CreateTmuxSession(config *projectconfig.Configuration) error {
|
|||
log.Debug("Ran command", "command", switchSessionCmd.String())
|
||||
} else {
|
||||
// If it doesn't exist, create the session
|
||||
createSessionCmd := exec.Command("tmux", "new-session", "-d", "-s", sessionName)
|
||||
createSessionCmd := exec.Command("tmux", "new-session", "-d", "-s", sessionName, "-c", config.WorkingDir)
|
||||
// createSessionCmd := exec.Command("tmux", "new-session", "-d", "-s", sessionName)
|
||||
if err := createSessionCmd.Run(); err != nil {
|
||||
return err
|
||||
}
|
||||
|
@ -76,6 +77,13 @@ func CreateTmuxSession(config *projectconfig.Configuration) error {
|
|||
}
|
||||
log.Debug("Ran command", "command", selectPaneCmd.String())
|
||||
|
||||
// Change the working directory
|
||||
changeDirCmd := exec.Command("tmux", "send-keys", "-t", paneName, "cd "+config.WorkingDir, "Enter")
|
||||
if err := changeDirCmd.Run(); err != nil {
|
||||
return err
|
||||
}
|
||||
log.Debug("Ran command", "command", changeDirCmd.String())
|
||||
|
||||
// Send commands to the pane
|
||||
sendCommandsCmd := exec.Command("tmux", "send-keys", "-t", paneName, strings.Join(pane.ShellCommand, " && "), "Enter")
|
||||
if err := sendCommandsCmd.Run(); err != nil {
|
||||
|
@ -109,6 +117,16 @@ func CreateTmuxSession(config *projectconfig.Configuration) error {
|
|||
}
|
||||
log.Debug("Ran command", "command", selectWindowCmd.String())
|
||||
|
||||
// Select initial pane
|
||||
if config.StartupPane > 0 {
|
||||
defaultPane := fmt.Sprintf("%s:%d.%d", sessionName, config.StartupPane, 1)
|
||||
selectPaneCmd := exec.Command("tmux", "select-pane", "-t", defaultPane)
|
||||
if err := selectPaneCmd.Run(); err != nil {
|
||||
return err
|
||||
}
|
||||
log.Debug("Ran command", "command", selectPaneCmd.String())
|
||||
}
|
||||
|
||||
if config.Attach {
|
||||
switchSessionCmd := exec.Command("tmux", "switch-client", "-t", sessionName)
|
||||
if err := switchSessionCmd.Run(); err != nil {
|
||||
|
@ -174,6 +192,13 @@ func createWindow(config *projectconfig.Configuration, sessionName string, index
|
|||
}
|
||||
log.Debug("Ran command", "command", selectPaneCmd.String())
|
||||
|
||||
// Change the working directory for the pane
|
||||
changeDirCmd := exec.Command("tmux", "send-keys", "-t", paneName, "cd "+config.WorkingDir, "Enter")
|
||||
if err := changeDirCmd.Run(); err != nil {
|
||||
return err
|
||||
}
|
||||
log.Debug("Ran command", "command", changeDirCmd.String())
|
||||
|
||||
// Send commands to the pane
|
||||
sendCommandsCmd := exec.Command("tmux", "send-keys", "-t", paneName, strings.Join(pane.ShellCommand, " && "), "Enter")
|
||||
if err := sendCommandsCmd.Run(); err != nil {
|
||||
|
@ -193,3 +218,12 @@ func createWindow(config *projectconfig.Configuration, sessionName string, index
|
|||
|
||||
return nil
|
||||
}
|
||||
|
||||
func KillTmuxSession(sessionName string) error {
|
||||
killSessionCmd := exec.Command("tmux", "kill-session", "-t", sessionName)
|
||||
if err := killSessionCmd.Run(); err != nil {
|
||||
return err
|
||||
}
|
||||
log.Debug("Ran command", "command", killSessionCmd.String())
|
||||
return nil
|
||||
}
|
||||
|
|
|
@ -16,6 +16,24 @@ var RootCmd = &cobra.Command{
|
|||
},
|
||||
}
|
||||
|
||||
var KillTmuxSessionCmd = &cobra.Command{
|
||||
Use: "kill",
|
||||
Args: cobra.ExactArgs(1),
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
sessionName := args[0]
|
||||
err := controller.KillTmuxSession(sessionName)
|
||||
if err != nil {
|
||||
log.Error(err)
|
||||
return
|
||||
}
|
||||
log.Debug("Killed tmux session", "name", sessionName)
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
RootCmd.AddCommand(KillTmuxSessionCmd)
|
||||
}
|
||||
|
||||
func ExecuteProjectEnv(projectName string) {
|
||||
config, err := projectconfig.GetProjectConfig(projectName)
|
||||
if err != nil {
|
||||
|
|
|
@ -92,15 +92,19 @@ func Table(columns []table.Column, rows []table.Row) (table.Row, string) {
|
|||
)
|
||||
|
||||
s := table.DefaultStyles()
|
||||
|
||||
// rounded borders
|
||||
s.Header = s.Header.
|
||||
BorderStyle(lipgloss.NormalBorder()).
|
||||
BorderForeground(lipgloss.Color("240")).
|
||||
BorderBottom(true).
|
||||
Bold(false)
|
||||
|
||||
s.Selected = s.Selected.
|
||||
Foreground(lipgloss.Color("229")).
|
||||
Background(lipgloss.Color("57")).
|
||||
Background(lipgloss.Color("240")).
|
||||
Bold(false)
|
||||
|
||||
t.SetStyles(s)
|
||||
|
||||
m := model{t, "", help.New(), keys}
|
||||
|
|
Loading…
Reference in New Issue