Files
dnd/cmd/dndcheck/main.go
2023-05-14 18:01:39 -07:00

79 lines
1.3 KiB
Go

package main
import (
"flag"
"io/fs"
"os"
"strings"
"github.com/firestuff/dnd/internal"
"github.com/samber/lo"
"golang.org/x/exp/slog"
)
var mapSigs = map[string]string{
"./*.jpg;./*.psd;Objects/*.png": "patreon-drmapzo-diamond",
"./*.jpg;./*.png;./*.psd;Objects/*.png": "patreon-drmapzo-diamond",
"./*.jpg;./*.webp;Objects/*.png": "patreon-morvoldpress-tier2",
}
func main() {
l := slog.New(slog.NewTextHandler(os.Stderr, nil))
root := flag.String("root", "", "root directory to validate")
flag.Parse()
if *root == "" {
l.Error("please specify --root")
os.Exit(1)
}
rootFS := os.DirFS(*root)
l.Info("validating...",
"root", *root,
)
ok := validateMaps(l, lo.Must(fs.Sub(rootFS, "Maps")))
if !ok {
os.Exit(1)
}
}
func validateMaps(l *slog.Logger, mapsFS fs.FS) bool {
entries := lo.Must(mapsFS.(fs.ReadDirFS).ReadDir("."))
for _, entry := range entries {
if strings.HasPrefix(entry.Name(), ".") {
continue
}
ok := validateMap(
l.With("map", entry.Name()),
lo.Must(fs.Sub(mapsFS, entry.Name())),
)
if !ok {
return false
}
}
return true
}
func validateMap(l *slog.Logger, mapFS fs.FS) bool {
sig := internal.DirSig(mapFS)
t := mapSigs[sig]
if t == "" {
l.Error("unrecognized signature",
"signature", sig,
)
return false
}
l.Info("valid map",
"source", t,
)
return true
}