wip: add --walk flag to gfrun to accept directory
This commit is contained in:
parent
dac1c40ee5
commit
a41f215785
2
.github/workflows/cli.yml
vendored
2
.github/workflows/cli.yml
vendored
@ -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: |
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user