[Docs] CLI command to serve docs locally (#6956)
* CLI command to serve docs locally * Document it * Default port * Use `with` and subclass `SimpleHTTPRequestHandler` to set working dir * Apply suggestions from code review Co-Authored-By: skullydazed <skullydazed@users.noreply.github.com> * Update docs/cli.md
This commit is contained in:
10
docs/cli.md
10
docs/cli.md
@ -105,6 +105,16 @@ This command lets you configure the behavior of QMK. For the full `qmk config` d
|
||||
qmk config [-ro] [config_token1] [config_token2] [...] [config_tokenN]
|
||||
```
|
||||
|
||||
## `qmk docs`
|
||||
|
||||
This command starts a local HTTP server which you can use for browsing or improving the docs. Default port is 8936.
|
||||
|
||||
**Usage**:
|
||||
|
||||
```
|
||||
qmk docs [-p PORT]
|
||||
```
|
||||
|
||||
## `qmk doctor`
|
||||
|
||||
This command examines your environment and alerts you to potential build or flash problems.
|
||||
|
@ -5,6 +5,7 @@ We list each subcommand here explicitly because all the reliable ways of searchi
|
||||
from . import cformat
|
||||
from . import compile
|
||||
from . import config
|
||||
from . import docs
|
||||
from . import doctor
|
||||
from . import hello
|
||||
from . import json
|
||||
|
22
lib/python/qmk/cli/docs.py
Normal file
22
lib/python/qmk/cli/docs.py
Normal file
@ -0,0 +1,22 @@
|
||||
"""Serve QMK documentation locally
|
||||
"""
|
||||
import http.server
|
||||
|
||||
from milc import cli
|
||||
|
||||
|
||||
class DocsHandler(http.server.SimpleHTTPRequestHandler):
|
||||
def __init__(self, *args, **kwargs):
|
||||
super().__init__(*args, directory='docs', **kwargs)
|
||||
|
||||
|
||||
@cli.argument('-p', '--port', default=8936, type=int, help='Port number to use.')
|
||||
@cli.subcommand('Run a local webserver for QMK documentation.')
|
||||
def docs(cli):
|
||||
"""Spin up a local HTTPServer instance for the QMK docs.
|
||||
"""
|
||||
with http.server.HTTPServer(('', cli.config.docs.port), DocsHandler) as httpd:
|
||||
cli.log.info("Serving QMK docs at http://localhost:%d/", cli.config.docs.port)
|
||||
cli.log.info("Press Control+C to exit.")
|
||||
|
||||
httpd.serve_forever()
|
Reference in New Issue
Block a user