1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
# BSD 3-Clause License; see https://github.com/scikit-hep/awkward/blob/main/LICENSE
from __future__ import annotations
import os
import yaml
CURRENT_DIR = os.path.dirname(os.path.realpath(__file__))
def indent_code(code, indent):
finalcode = ""
for line in code.splitlines():
finalcode += " " * indent + line + "\n"
return finalcode
def genkerneldocs():
prefix = """Kernel interface and specification
----------------------------------
All array manipulation that is not performed by NumPy/CuPy/etc. is executed in Awkward Array's low-level "kernels." These functions communicate entirely by side-effects, manipulating already-allocated arrays, and therefore can be implemented with a pure C interface. They're called "kernels" because their signatures are similar to GPU kernels, to make them easier to port to GPUs and similar devices.
All of the kernel functions that Awkward Array uses are documented below. These are internal details of Awkward Array, subject to change at any time, not a public API. The reason that we are documenting the API is to ensure compatibility between the primary CPU-bound kernels and their equivalents, ported to GPUs (and similar devices). The definitions below are expressed in Python code, but the implementations used by Awkward Array are compiled.
"""
generated_dir = os.path.join(CURRENT_DIR, "..", "docs", "reference", "generated")
os.makedirs(generated_dir, exist_ok=True)
with open(os.path.join(CURRENT_DIR, "..", "kernel-specification.yml")) as specfile:
with open(
os.path.join(
generated_dir,
"kernels.rst",
),
"w",
) as outfile:
outfile.write(prefix)
indspec = yaml.safe_load(specfile)["kernels"]
for spec in indspec:
outfile.write(spec["name"] + "\n")
print("Generating doc for " + spec["name"])
outfile.write(
"========================================================================\n"
)
for childfunc in spec["specializations"]:
outfile.write(".. py:function:: " + childfunc["name"])
outfile.write("(")
for i in range(len(childfunc["args"])):
if i != 0:
outfile.write(
", "
+ childfunc["args"][i]["name"]
+ ": "
+ childfunc["args"][i]["type"]
)
else:
outfile.write(
childfunc["args"][i]["name"]
+ ": "
+ childfunc["args"][i]["type"]
)
outfile.write(")\n")
outfile.write(".. code-block:: python\n\n")
# Remove conditional at the end of dev
if "def" in spec["definition"]:
outfile.write(
indent_code(
spec["definition"],
4,
)
+ "\n\n"
)
if __name__ == "__main__":
genkerneldocs()
|