grokkit/cmd/root.go
Greg Gauthier b8482b6fb0
Some checks failed
CI / Test (push) Successful in 26s
CI / Lint (push) Successful in 20s
CI / Build (push) Successful in 14s
Release / Create Release (push) Failing after 10s
feat(release): add automated release workflow and install script
- Embed version info in binaries via ldflags
- Create multi-platform builds, archives, and checksums
- Add Gitea release creation and asset upload in CI
- Introduce GoReleaser config for standardized builds
- Add version command and install script for easy deployment
- Update README with pre-built installation instructions
2026-03-01 23:25:31 +00:00

67 lines
1.8 KiB
Go

package cmd
import (
"os"
"fmt"
"github.com/spf13/cobra"
"gmgauthier.com/grokkit/config"
"gmgauthier.com/grokkit/internal/logger"
"gmgauthier.com/grokkit/internal/version"
)
var rootCmd = &cobra.Command{
Use: "grokkit",
Short: "Personal Grok / xAI command-line toolkit",
Long: `A fast, native Go CLI for Grok. Chat, edit files, and supercharge your git workflow.`,
PersistentPreRun: func(cmd *cobra.Command, args []string) {
config.Load()
// Determine log level: flag > config > default
logLevel := config.GetLogLevel()
if debug, _ := cmd.Flags().GetBool("debug"); debug {
logLevel = "debug"
}
if verbose, _ := cmd.Flags().GetBool("verbose"); verbose {
logLevel = "info"
}
_ = logger.Init(logLevel) // Logging is optional, don't fail if it errors
logger.Info("grokkit starting", "command", cmd.Name(), "log_level", logLevel)
},
}
func Execute() {
if err := rootCmd.Execute(); err != nil {
os.Exit(1)
}
}
var versionCmd = &cobra.Command{
Use: "version",
Short: "Print the version information",
Run: func(cmd *cobra.Command, args []string) {
fmt.Printf("grokkit version %s (commit %s)\\n", version.Version, version.Commit)
},
}
func init() {
rootCmd.AddCommand(chatCmd)
rootCmd.AddCommand(editCmd)
rootCmd.AddCommand(reviewCmd)
rootCmd.AddCommand(commitMsgCmd)
rootCmd.AddCommand(commitCmd)
rootCmd.AddCommand(prDescribeCmd)
rootCmd.AddCommand(historyCmd)
rootCmd.AddCommand(agentCmd)
rootCmd.AddCommand(completionCmd)
rootCmd.AddCommand(versionCmd)
// Add model flag to all commands
rootCmd.PersistentFlags().StringP("model", "m", "", "Grok model to use (overrides config)")
// Add logging flags
rootCmd.PersistentFlags().Bool("debug", false, "Enable debug logging (logs to stderr and file)")
rootCmd.PersistentFlags().BoolP("verbose", "v", false, "Enable verbose logging")
}