package main import ( "flag" "fmt" "os" "github.com/n-peugnet/dna-backup/logger" "github.com/n-peugnet/dna-backup/repo" ) type command struct { Flag *flag.FlagSet Run func([]string) error Usage string Help string } const ( name = "dna-backup" baseUsage = " [] [--] " ) var ( logLevel int format string ) var commit = command{flag.NewFlagSet("commit", flag.ExitOnError), commitMain, "[] [--] ", "Create a new version of folder into repo ", } var restore = command{flag.NewFlagSet("restore", flag.ExitOnError), restoreMain, "[] [--] ", "Restore the last version from repo into folder ", } var subcommands = map[string]command{ commit.Flag.Name(): commit, restore.Flag.Name(): restore, } func init() { // init default help message flag.Usage = func() { fmt.Fprintf(flag.CommandLine.Output(), "usage: %s %s\n\ncommands:\n", name, baseUsage) for _, s := range subcommands { fmt.Printf(" %s %s\n", s.Flag.Name(), s.Help) } os.Exit(1) } // setup subcommands for _, s := range subcommands { s.Flag.IntVar(&logLevel, "v", 3, "log verbosity level (0-4)") } } func main() { flag.Parse() args := flag.Args() if len(args) < 1 { flag.Usage() } cmd, exists := subcommands[args[0]] if !exists { fmt.Fprintf(flag.CommandLine.Output(), "error: unknown command %s\n\n", args[0]) flag.Usage() } cmd.Flag.Usage = func() { fmt.Fprintf(cmd.Flag.Output(), "usage: %s %s %s\n\noptions:\n", name, cmd.Flag.Name(), cmd.Usage) cmd.Flag.PrintDefaults() os.Exit(1) } cmd.Flag.Parse(args[1:]) logger.Init(logLevel) if err := cmd.Run(cmd.Flag.Args()); err != nil { fmt.Fprintf(cmd.Flag.Output(), "error: %s\n\n", err) cmd.Flag.Usage() } } func commitMain(args []string) error { if len(args) != 2 { return fmt.Errorf("wrong number of args") } source := args[0] dest := args[1] repo := repo.NewRepo(dest) repo.Commit(source) return nil } func restoreMain(args []string) error { if len(args) != 2 { return fmt.Errorf("wrong number args") } source := args[0] dest := args[1] repo := repo.NewRepo(source) repo.Restore(dest) return nil }