1
0
mirror of https://github.com/kellyjonbrazil/jc.git synced 2025-06-17 00:07:37 +02:00
Files
jc/docgen.sh

118 lines
2.8 KiB
Bash
Raw Normal View History

2019-11-11 18:30:46 -08:00
#!/bin/bash
# Generate docs.md
2022-01-25 18:42:55 -08:00
# requires pydoc-markdown 4.5.0
2022-01-26 15:01:42 -08:00
readme_config=$(cat <<'EOF'
{
"processors": [
{
"type": "filter"
},
{
"type": "pydocmd"
}
],
"renderer": {
"type": "markdown",
"header_level_by_type": {
"Module": 1,
"Class": 3,
"Method": 3,
"Function": 3,
"Data": 3
}
}
}
EOF
)
2022-01-26 13:03:51 -08:00
toc_config=$(cat <<'EOF'
{
"processors": [
{
2022-01-26 15:01:42 -08:00
"type": "filter"
},
{
"type": "pydocmd"
}
],
"renderer": {
"type": "markdown",
2022-01-26 14:16:04 -08:00
"render_toc": true,
"header_level_by_type": {
"Module": 1,
"Class": 3,
"Method": 3,
"Function": 3,
"Data": 3
}
}
}
EOF
)
2022-01-25 18:38:26 -08:00
2022-01-26 15:01:42 -08:00
parser_config=$(cat <<'EOF'
2022-01-26 13:03:51 -08:00
{
"processors": [
{
"type": "filter",
2022-01-26 15:01:42 -08:00
"expression": "not name == \"info\" and not name.startswith(\"_\") and default()"
2022-01-26 13:03:51 -08:00
},
{
"type": "pydocmd"
}
],
"renderer": {
2022-01-26 14:16:04 -08:00
"type": "markdown",
"header_level_by_type": {
"Module": 1,
"Class": 3,
"Method": 3,
"Function": 3,
"Data": 3
}
2022-01-26 13:03:51 -08:00
}
}
EOF
)
2019-11-11 18:30:46 -08:00
cd jc
2021-04-05 09:42:25 -07:00
echo Building docs for: package
2022-01-26 15:01:42 -08:00
pydoc-markdown -m jc "${readme_config}" > ../docs/readme.md
2022-01-19 22:20:36 -08:00
echo Building docs for: lib
2022-01-26 13:03:51 -08:00
pydoc-markdown -m jc.lib "${toc_config}" > ../docs/lib.md
2022-01-19 22:20:36 -08:00
2021-04-05 09:42:25 -07:00
echo Building docs for: utils
2022-01-26 13:03:51 -08:00
pydoc-markdown -m jc.utils "${toc_config}" > ../docs/utils.md
2022-01-20 09:46:24 -08:00
echo Building docs for: universal parser
2022-01-26 13:03:51 -08:00
pydoc-markdown -m jc.parsers.universal "${toc_config}" > ../docs/parsers/universal.md
2022-01-20 09:46:24 -08:00
# a bit of inception here... jc is being used to help
# automate the generation of its own documentation. :)
# pull jc parser objects into a bash array from jq
2022-01-25 18:42:55 -08:00
# filter out any plugin parsers
parsers=()
while read -r value
do
parsers+=("$value")
2022-01-25 17:07:47 -08:00
done < <(jc -a | jq -c '.parsers[] | select(.plugin != true)')
for parser in "${parsers[@]}"
do
parser_name=$(jq -r '.name' <<< "$parser")
compatible=$(jq -r '.compatible | join(", ")' <<< "$parser")
version=$(jq -r '.version' <<< "$parser")
author=$(jq -r '.author' <<< "$parser")
author_email=$(jq -r '.author_email' <<< "$parser")
echo "Building docs for: ${parser_name}"
echo "[Home](https://kellyjonbrazil.github.io/jc/)" > ../docs/parsers/"${parser_name}".md
2022-01-26 15:01:42 -08:00
pydoc-markdown -m jc.parsers."${parser_name}" "${parser_config}" >> ../docs/parsers/"${parser_name}".md
2022-01-25 19:18:54 -08:00
echo "### Parser Information" >> ../docs/parsers/"${parser_name}".md
echo "Compatibility: ${compatible}" >> ../docs/parsers/"${parser_name}".md
echo >> ../docs/parsers/"${parser_name}".md
echo "Version ${version} by ${author} (${author_email})" >> ../docs/parsers/"${parser_name}".md
done