https://github.com/ETCBC/shebanq
Raw File
Tip revision: 25e30accad6990bc0fd9831e5e75801a5994e25f authored by Dirk Roorda on 20 October 2021, 14:17:43 UTC
docs
Tip revision: 25e30ac
build.py
import sys
import os
from subprocess import run
from textwrap import dedent


ORG = "etcbc"
REPO = "shebanq"
PKG = "shebanq"

TEST_SRC = "ftests/"
TEST_DST = "docs/tests/bymodule"

PY_SRC = "modules/"
PY_DST = "docs/server/bymodule"

JS_SRC = "static/js/app"
JS_DST = "docs/client/bymodule"

HELP = """
python3 build.py command

command:

-h
--help


jdocs  : build jsdocs
docs   : serve docs locally (after building them, including js docs)
mdocs  : build docs (excluding jsdocs)
mkdocs : build docs (including jsdocs)
sdocs  : ship docs (after building them, including js docs)
test   : run tests
ship   : build for shipping

For g and ship you need to pass a commit message.
"""


def console(*args):
    sys.stderr.write(" ".join(args) + "\n")
    sys.stderr.flush()


def readArgs():
    args = sys.argv[1:]
    if not len(args) or args[0] in {"-h", "--help", "help"}:
        console(HELP)
        return (False, None, [])
    arg = args[0]
    if arg not in {
        "jdocs",
        "docs",
        "mdocs",
        "mkdocs",
        "sdocs",
        "clean",
        "test",
        "ship",
    }:
        console(HELP)
        return (False, None, [])
    if arg in {"ship"}:
        if len(args) < 2:
            console("Provide a commit message")
            return (False, None, [])
        return (arg, args[1], args[2:])
    elif arg in {"test"}:
        return (arg, None, args[1:])
    return (arg, None, [])


def commit(task, msg):
    run(["git", "add", "--all", "."])
    run(["git", "commit", "-m", msg])
    run(["git", "push", "origin", "master"])


def serveDocs():
    run(["mkdocs", "serve"])


def makeDocs():
    run(["mkdocs", "build"])


def shipDocs():
    run(["mkdocs", "gh-deploy"])


def runTests(args):
    run(["pytest", *args], cwd="ftests")


def makeTestDocs():
    pyFiles = sorted(
        pyFile.removesuffix(".py")
        for pyFile in os.listdir(TEST_SRC)
        if pyFile.endswith(".py")
    )
    console(f"update references for {len(pyFiles)} test scripts")
    for pyFile in pyFiles:
        with open(f"{TEST_DST}/{pyFile}.md", "w") as fh:
            fh.write(
                dedent(
                    f"""
                ## ::: ftests.{pyFile}

                ---

                """
                )
            )


def makePyDocs():
    pyFiles = sorted(
        pyFile.removesuffix(".py")
        for pyFile in os.listdir(PY_SRC)
        if pyFile.endswith(".py")
    )
    console(f"update references for {len(pyFiles)} python modules")
    for pyFile in pyFiles:
        with open(f"{PY_DST}/{pyFile}.md", "w") as fh:
            fh.write(
                dedent(
                    f"""
                ## ::: {pyFile}

                ---

                """
                )
            )


def makeJsDocs():
    jsFiles = sorted(jsFile for jsFile in os.listdir(JS_SRC) if jsFile.endswith(".js"))
    console(f"update jsdocs for {len(jsFiles)} modules")
    for jsFile in jsFiles:
        outFile = f"{jsFile.removesuffix('js')}md"
        run(f"jsdoc2md {JS_SRC}/{jsFile} > {JS_DST}/{outFile}", shell=True)


def main():
    (task, msg, remaining) = readArgs()
    if not task:
        return
    elif task == "jdocs":
        makeJsDocs()
    elif task == "docs":
        makeJsDocs()
        makePyDocs()
        makeTestDocs()
        serveDocs()
    elif task == "mdocs":
        makeDocs()
    elif task == "mkdocs":
        makeJsDocs()
        makePyDocs()
        makeTestDocs()
        makeDocs()
    elif task == "sdocs":
        makeJsDocs()
        makePyDocs()
        makeTestDocs()
        shipDocs()
    elif task == "test":
        runTests(remaining)
    elif task == "ship":
        makeJsDocs()
        makePyDocs()
        makeTestDocs()
        shipDocs()
        commit(task, msg)


main()
back to top