feat(qmkasciigen): add flag allow layers

main
sudo pacman -Syu 2023-08-10 17:50:50 +07:00
parent 449b9ebd0c
commit 6d61ef927b
4 changed files with 36 additions and 0 deletions

View File

@ -94,6 +94,7 @@ var mapBindingTiny = []map[string]string{
} }
type DrawConfig struct { type DrawConfig struct {
AllowLayers map[int]struct{}
PrintLayout bool PrintLayout bool
PrintLayer bool PrintLayer bool
} }
@ -155,6 +156,14 @@ func Draw(
// Each keymap has many layers // Each keymap has many layers
layersStr := make([]string, 0, len(keymap.Layers)) layersStr := make([]string, 0, len(keymap.Layers))
for iLayer, layer := range keymap.Layers { for iLayer, layer := range keymap.Layers {
if len(cfg.AllowLayers) > 0 {
// Only check if valid
if _, ok := cfg.AllowLayers[iLayer]; !ok {
// Skip if not in list
continue
}
}
// PreProcess table with space // PreProcess table with space
table := make([][]string, newMaxY+1) table := make([][]string, newMaxY+1)
for i := 0; i <= newMaxY; i++ { for i := 0; i <= newMaxY; i++ {

View File

@ -10,6 +10,8 @@ import (
"net/http" "net/http"
"os" "os"
"strings" "strings"
"github.com/spf13/cast"
) )
const ( const (
@ -30,6 +32,7 @@ var (
flagPrintOutput bool flagPrintOutput bool
flagPrintLayout bool flagPrintLayout bool
flagPrintLayer bool flagPrintLayer bool
flagAllowLayers string
) )
func init() { func init() {
@ -42,6 +45,7 @@ func init() {
flag.BoolVar(&flagPrintOutput, "print-out", false, "Print output") flag.BoolVar(&flagPrintOutput, "print-out", false, "Print output")
flag.BoolVar(&flagPrintLayout, "print-layout", false, "Print layout name") flag.BoolVar(&flagPrintLayout, "print-layout", false, "Print layout name")
flag.BoolVar(&flagPrintLayer, "print-layer", false, "Print layer name") flag.BoolVar(&flagPrintLayer, "print-layer", false, "Print layer name")
flag.StringVar(&flagAllowLayers, "allow-layers", "", "Allow layers to print aka 0 or 0,2,3. Use , to split. Empty mean all")
} }
func main() { func main() {
@ -55,6 +59,19 @@ func main() {
log.Printf("flagPrintOutput: [%v]\n", flagPrintOutput) log.Printf("flagPrintOutput: [%v]\n", flagPrintOutput)
log.Printf("flagPrintLayout: [%v]\n", flagPrintLayout) log.Printf("flagPrintLayout: [%v]\n", flagPrintLayout)
log.Printf("flagPrintLayer: [%v]\n", flagPrintLayer) log.Printf("flagPrintLayer: [%v]\n", flagPrintLayer)
log.Printf("flagAllowLayers: [%s]\n", flagAllowLayers)
}
// 0,2,3 -> [0, 2, 3]
allowLayers := make(map[int]struct{})
for _, l := range strings.Split(flagAllowLayers, ",") {
l = strings.TrimSpace(l)
if l == "" {
continue
}
lInt := cast.ToInt(l)
allowLayers[lInt] = struct{}{}
} }
qmkInfo, err := wrapGetQMKInfo(flagQMKKeyboard, flagQMKInfoFile, flagDebug) qmkInfo, err := wrapGetQMKInfo(flagQMKKeyboard, flagQMKInfoFile, flagDebug)
@ -71,6 +88,7 @@ func main() {
qmkInfo.Layouts, qmkInfo.Layouts,
qmkKeymap, qmkKeymap,
DrawConfig{ DrawConfig{
AllowLayers: allowLayers,
PrintLayout: flagPrintLayout, PrintLayout: flagPrintLayout,
PrintLayer: flagPrintLayer, PrintLayer: flagPrintLayer,
}, },

2
go.mod
View File

@ -1,3 +1,5 @@
module github.com/haunt98/qmk_keymaps module github.com/haunt98/qmk_keymaps
go 1.20 go 1.20
require github.com/spf13/cast v1.5.1

7
go.sum
View File

@ -0,0 +1,7 @@
github.com/frankban/quicktest v1.14.4 h1:g2rn0vABPOOXmZUj+vbmUp0lPoXEMuhTpIluN0XL9UY=
github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38=
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8=
github.com/spf13/cast v1.5.1 h1:R+kOtfhWQE6TVQzY+4D7wJLBgkdVasCEFxSUBYBYIlA=
github.com/spf13/cast v1.5.1/go.mod h1:b9PdjNptOpzXr7Rq1q9gJML/2cdGQAo69NKzQ10KN48=