From 567e5b51d32450999935bcf3af143248888e12e9 Mon Sep 17 00:00:00 2001 From: Fuwn Date: Mon, 26 Jan 2026 05:13:25 +0000 Subject: feat: Initial commit --- cmd/mugi/main.go | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 cmd/mugi/main.go (limited to 'cmd') diff --git a/cmd/mugi/main.go b/cmd/mugi/main.go new file mode 100644 index 0000000..6caed07 --- /dev/null +++ b/cmd/mugi/main.go @@ -0,0 +1,50 @@ +package main + +import ( + "fmt" + "os" + + "github.com/ebisu/mugi/internal/cli" + "github.com/ebisu/mugi/internal/config" + "github.com/ebisu/mugi/internal/ui" +) + +const version = "0.1.0" + +func main() { + if err := run(); err != nil { + fmt.Fprintln(os.Stderr, err) + os.Exit(1) + } +} + +func run() error { + cmd, err := cli.Parse(os.Args[1:]) + if err != nil { + return err + } + + if cmd.Help { + fmt.Println(cli.Usage()) + + return nil + } + + if cmd.Version { + fmt.Printf("mugi %s\n", version) + + return nil + } + + cfg, err := config.Load(cmd.ConfigPath) + if err != nil { + return fmt.Errorf("config: %w", err) + } + + tasks := ui.BuildTasks(cfg, cmd.Repo, cmd.Remotes) + if len(tasks) == 0 { + return fmt.Errorf("no matching repositories or remotes found") + } + + return ui.Run(cmd.Operation, tasks, cmd.Verbose) +} -- cgit v1.2.3