Files
dnd/cmd/dndcheck/main.go

72 lines
1.1 KiB
Go
Raw Normal View History

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