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
|
|
|
}
|