wip: add --walk flag to gfrun to accept directory

This commit is contained in:
Hayden 2022-08-14 16:49:20 -08:00
parent dac1c40ee5
commit a41f215785
2 changed files with 65 additions and 19 deletions

View File

@ -82,7 +82,7 @@ jobs:
chmod +x "${GITHUB_WORKSPACE}/.local/bin/gfmrun" chmod +x "${GITHUB_WORKSPACE}/.local/bin/gfmrun"
- name: gfmrun - name: gfmrun
run: go run internal/build/build.go gfmrun docs/v2/manual.md run: go run internal/build/build.go gfmrun --walk docs/v2/
- name: diff check - name: diff check
run: | run: |

View File

@ -61,6 +61,13 @@ func main() {
}, },
{ {
Name: "gfmrun", Name: "gfmrun",
Flags: []cli.Flag{
&cli.BoolFlag{
Name: "walk",
Value: false,
Usage: "Walk the specified directory and perform validation on all markdown files",
},
},
Action: GfmrunActionFunc, Action: GfmrunActionFunc,
}, },
{ {
@ -220,13 +227,43 @@ func GfmrunActionFunc(cCtx *cli.Context) error {
filename = "README.md" filename = "README.md"
} }
file, err := os.Open(filename) walk := cCtx.Bool("walk")
sources := []string{}
if walk {
// Walk the directory and find all markdown files.
err := filepath.Walk(top, func(path string, info os.FileInfo, err error) error {
if err != nil {
return err
}
if info.IsDir() {
return nil
}
if filepath.Ext(path) != ".md" {
return nil
}
sources = append(sources, path)
return nil
})
if err != nil {
return err
}
} else {
sources = append(sources, filename)
}
var counter int
for _, src := range sources {
file, err := os.Open(src)
if err != nil { if err != nil {
return err return err
} }
defer file.Close() defer file.Close()
var counter int
scanner := bufio.NewScanner(file) scanner := bufio.NewScanner(file)
for scanner.Scan() { for scanner.Scan() {
if strings.Contains(scanner.Text(), "package main") { if strings.Contains(scanner.Text(), "package main") {
@ -243,8 +280,17 @@ func GfmrunActionFunc(cCtx *cli.Context) error {
if err != nil { if err != nil {
return err return err
} }
}
if err := runCmd("gfmrun", "-c", fmt.Sprint(counter), "-s", filename); err != nil { gfmArgs := []string{
"--count",
fmt.Sprint(counter),
}
for _, src := range sources {
gfmArgs = append(gfmArgs, "--sources", src)
}
if err := runCmd("gfmrun", gfmArgs...); err != nil {
return err return err
} }