♻️ Move convids cmd code to internal App
This commit is contained in:
parent
64b2242567
commit
ac0baba3a8
4 changed files with 99 additions and 42 deletions
|
|
@ -4,58 +4,21 @@ import (
|
|||
"fmt"
|
||||
"os"
|
||||
|
||||
"codeberg.org/danjones000/utils/chill"
|
||||
c "codeberg.org/danjones000/utils/cli/context"
|
||||
e "codeberg.org/danjones000/utils/cli/err"
|
||||
"codeberg.org/danjones000/utils/cli/spin"
|
||||
"codeberg.org/danjones000/utils/convids"
|
||||
ccli "codeberg.org/danjones000/utils/internal/cli/convids"
|
||||
)
|
||||
|
||||
const dataPath = "shows.yml"
|
||||
|
||||
func main() {
|
||||
flags, err := ccli.ParseFlags(os.Args[0], os.Args[1:])
|
||||
e.HandleErr(err)
|
||||
if *ccli.Help {
|
||||
flags.Usage()
|
||||
}
|
||||
|
||||
ctx, done := c.SelfCancelingContextFromBackground()
|
||||
defer done()
|
||||
|
||||
var walker convids.ShowWalker
|
||||
if *ccli.DryRun {
|
||||
walker = convids.DryRun(os.Stdout)
|
||||
} else {
|
||||
gs := convids.GetShow(ctx)
|
||||
|
||||
walker = func(s *convids.Show, path string) error {
|
||||
ct := chill.Chill(ctx)
|
||||
msg := fmt.Sprintf("Waiting for CPU to cool, for %s", path)
|
||||
sp := spin.Spin(ct, msg)
|
||||
err := sp.Wait()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return gs(s, path)
|
||||
}
|
||||
}
|
||||
|
||||
data, err := convids.NewData(dataPath)
|
||||
app, err := ccli.NewApp(ctx, os.Args[0], os.Args[1:], dataPath, os.Stdout, os.Stdin, os.Stderr)
|
||||
e.HandleErr(err)
|
||||
|
||||
groupPrinter := convids.PrintGroupName(os.Stdout)
|
||||
|
||||
if *ccli.Loop {
|
||||
fmt.Println("looping")
|
||||
for err == nil {
|
||||
err = convids.WalkFiles(data, false, groupPrinter, walker)
|
||||
fmt.Println(err)
|
||||
}
|
||||
} else {
|
||||
err = convids.WalkFiles(data, false, groupPrinter, walker)
|
||||
}
|
||||
err = app.Run(ctx)
|
||||
e.HandleErr(err)
|
||||
|
||||
fmt.Println("Done!")
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue