Skip to content

Commit

Permalink
feat: separate docsgen-config Makefile target
Browse files Browse the repository at this point in the history
still requires compiled binaries to produce the config, separate from
docsgen-cli which does not require them
  • Loading branch information
rvagg committed Jan 6, 2025
1 parent 7fe23b0 commit 14ca842
Show file tree
Hide file tree
Showing 6 changed files with 24 additions and 8 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@ jobs:
- run: git diff --exit-code
- run: make docsgen-cli
- run: git diff --exit-code
- run: make docsgen-config
- run: git diff --exit-code
check-lint:
name: Check (lint-all)
runs-on: ubuntu-latest
Expand Down
10 changes: 7 additions & 3 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -339,7 +339,7 @@ fiximports:

gen: actors-code-gen type-gen cfgdoc-gen docsgen api-gen
$(GOCC) run ./scripts/fiximports
@echo ">>> IF YOU'VE MODIFIED THE CLI OR CONFIG, REMEMBER TO ALSO RUN 'make docsgen-cli'"
@echo ">>> IF YOU'VE MODIFIED THE CLI OR CONFIG, REMEMBER TO ALSO RUN 'make docsgen-cli' and/or 'make docsgen-config'"
.PHONY: gen

jen: gen
Expand All @@ -348,11 +348,15 @@ snap: lotus lotus-miner lotus-worker
snapcraft
# snapcraft upload ./lotus_*.snap

docsgen-cli: lotus lotus-miner lotus-worker
docsgen-cli:
$(GOCC) run ./scripts/docsgen-cli
.PHONY: docsgen-cli

# Compiled lotus and lotus-miner are required to generate the default config files
docsgen-config: lotus lotus-miner
./lotus config default > documentation/en/default-lotus-config.toml
./lotus-miner config default > documentation/en/default-lotus-miner-config.toml
.PHONY: docsgen-cli
.PHONY: docsgen-config

print-%:
@echo $*=$($*)
Expand Down
2 changes: 1 addition & 1 deletion documentation/en/cli-lotus.md
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ COMMANDS:
GLOBAL OPTIONS:
--color use color in display output (default: depends on output being a TTY)
--interactive setting to false will disable interactive functionality of commands (default: true)
--interactive setting to false will disable interactive functionality of commands (default: false)
--force-send if true, will ignore pre-send checks (default: false)
--vv enables very verbose mode, useful for debugging the CLI (default: false)
--help, -h show help
Expand Down
2 changes: 1 addition & 1 deletion documentation/misc/Building_a_network_skeleton.md
Original file line number Diff line number Diff line change
Expand Up @@ -248,7 +248,7 @@ Note: one only needs to update `filecion-ffi`'s dependency on `go-state-types` w
11. Run `make gen`.
12. Run `make docsgen-cli`.
12. Run `make docsgen-cli docsgen-config`.
And you're done! These are all the steps necessary to create a network upgrade skeleton that you will be able to run in a local devnet, and creates a basis where you can start testing new FIPs. When running a local developer network from this Lotus branch, bringing in all it dependencies, you should be able to:
Expand Down
4 changes: 2 additions & 2 deletions documentation/misc/RELEASE_ISSUE_TEMPLATE.md
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@
<!--{{ if contains "Miner" .Type}}-->
- Ensure to update `MinerBuildVersion`
<!--{{ end}}-->
- [ ] Run `make gen && make docsgen-cli` before committing changes.
- [ ] Run `make gen && make docsgen-cli docsgen-config` before committing changes.
- [ ] Update the CHANGELOG
- [ ] Change the `UNRELEASED` section header to `UNRELEASED v{{.Tag}}`
- [ ] Set the `UNRELEASED v{{.Tag}}` section's content to be "_See https://github.com/filecoin-project/lotus/blob/release/v{{.Tag}}/CHANGELOG.md_"
Expand Down Expand Up @@ -118,7 +118,7 @@
<!-- {{if contains "Miner" $.Type}}-->
- Ensure to update `MinerBuildVersion`
<!-- {{end}}-->
- [ ] Run `make gen && make docsgen-cli` to generate documentation
- [ ] Run `make gen && make docsgen-cli docsgen-config` to generate documentation
- [ ] Create a draft PR with title `build: release Lotus {{$.Type}} v{{$.Tag}}{{$tagSuffix}}`
- Link to PR:
- Opening a PR will trigger a CI run that will build assets, create a draft GitHub release, and attach the assets.
Expand Down
12 changes: 11 additions & 1 deletion scripts/docsgen-cli/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,14 +45,24 @@ func main() {
os.Exit(1)
}

fmt.Println("Generating CLI documentation...")
// Some help output is generated based on whether the output is a terminal or not. To make stable
// output text, we set Stdout to not be a terminal while we load the CLI apps and reset it
// before generating the documentation.
_, w, _ := os.Pipe()
stdout := os.Stdout
os.Stdout = w

cliApps := map[string]*cli.App{
"lotus": lotus.App(),
"lotus-worker": worker.App(),
"lotus-miner": miner.App(),
}

w.Close()

Check failure on line 61 in scripts/docsgen-cli/main.go

View workflow job for this annotation

GitHub Actions / Check (lint-all)

Error return value of `w.Close` is not checked (errcheck)
os.Stdout = stdout

fmt.Println("Generating CLI documentation...")

for name, app := range cliApps {
for _, cmd := range app.Commands {
cmd.HelpName = fmt.Sprintf("%s %s", app.HelpName, cmd.Name)
Expand Down

0 comments on commit 14ca842

Please sign in to comment.