|
| 1 | + |
| 2 | +# VARIABLES # |
| 3 | + |
| 4 | +# Define the path of the JSDoc executable: |
| 5 | +JSDOC ?= $(BIN)/jsdoc |
| 6 | + |
| 7 | +# Define the path to the JSDoc configuration file: |
| 8 | +JSDOC_CONF ?= $(CONFIG_DIR)/jsdoc.conf.json |
| 9 | + |
| 10 | +# Define the path to the JSDoc JSON template: |
| 11 | +JSDOC_JSON_TEMPLATE ?= $(ROOT)/tools/docs/jsdoc/templates/json |
| 12 | + |
| 13 | +# Define the output directory for JSDoc: |
| 14 | +JSDOC_OUT ?= $(DOCS_DIR)/jsdoc |
| 15 | + |
| 16 | +# Define the output directory for JSDoc JSON: |
| 17 | +JSDOC_JSON_OUT ?= $(JSDOC_OUT)/json |
| 18 | + |
| 19 | +# Define the output filepath for JSDoc JSON: |
| 20 | +JSDOC_JSON_PATH ?= $(JSDOC_JSON_OUT)/jsdoc.json |
| 21 | + |
| 22 | +# Define the path to the JSDoc HTML template: |
| 23 | +JSDOC_HTML_TEMPLATE ?= templates/default |
| 24 | + |
| 25 | +# Define the output directory for JSDoc HTML documentation: |
| 26 | +JSDOC_HTML_OUT ?= $(JSDOC_OUT)/static |
| 27 | + |
| 28 | +# Define the output filepath for HTML documentation: |
| 29 | +JSDOC_HTML_PATH ?= $(JSDOC_HTML_OUT)/index.html |
| 30 | + |
| 31 | +# Define command-line options to be used when invoking the JSDoc executable to generate HTML documentation: |
| 32 | +JSDOC_HTML_FLAGS ?= --template $(JSDOC_HTML_TEMPLATE) \ |
| 33 | + --configure $(JSDOC_CONF) \ |
| 34 | + --encoding utf8 \ |
| 35 | + --destination $(JSDOC_HTML_OUT) \ |
| 36 | + --verbose |
| 37 | + |
| 38 | +# Define command-line options to be used when invoking the JSDoc executable to generate JSDoc JSON: |
| 39 | +JSDOC_JSON_FLAGS ?= --template $(JSDOC_JSON_TEMPLATE) \ |
| 40 | + --configure $(JSDOC_CONF) \ |
| 41 | + --encoding utf8 \ |
| 42 | + --destination console |
| 43 | + |
| 44 | + |
| 45 | +# TARGETS # |
| 46 | + |
| 47 | +# Generate JSDoc HTML documentation. |
| 48 | +# |
| 49 | +# This target generates source HTML documentation from [JSDoc][1]-style comments. |
| 50 | +# |
| 51 | +# To install JSDoc: |
| 52 | +# $ npm install jsdoc |
| 53 | +# |
| 54 | +# [1] http://usejsdoc.org/ |
| 55 | + |
| 56 | +docs-src: docs-jsdoc |
| 57 | + |
| 58 | +docs-jsdoc: node_modules |
| 59 | + -rm -rf $(JSDOC_HTML_OUT) |
| 60 | + mkdir -p $(JSDOC_HTML_OUT) |
| 61 | + $(JSDOC) $(JSDOC_HTML_FLAGS) $(SOURCES) |
| 62 | + |
| 63 | + |
| 64 | +# Generate JSDoc JSON. |
| 65 | +# |
| 66 | +# This target generates JSDoc JSON from [JSDoc][1]-style comments. |
| 67 | +# |
| 68 | +# To install JSDoc: |
| 69 | +# $ npm install jsdoc |
| 70 | +# |
| 71 | +# [1] http://usejsdoc.org/ |
| 72 | + |
| 73 | +jsdoc-json: node_modules |
| 74 | + -rm -f $(JSDOC_JSON_PATH) |
| 75 | + mkdir -p $(JSDOC_JSON_OUT) |
| 76 | + $(JSDOC) $(JSDOC_JSON_FLAGS) $(SOURCES) > $(JSDOC_JSON_PATH) |
| 77 | + |
| 78 | + |
| 79 | +# View HTML documentation. |
| 80 | +# |
| 81 | +# This target opens JSDoc HTML documentation in a local web browser. |
| 82 | + |
| 83 | +view-src-docs: |
| 84 | + $(OPEN) $(JSDOC_HTML_PATH) |
| 85 | + |
| 86 | + |
| 87 | +# Remove a JSDoc output directory. |
| 88 | +# |
| 89 | +# This target cleans up a JSDoc output directory by removing it entirely. |
| 90 | + |
| 91 | +clean-jsdoc: |
| 92 | + -rm -rf $(JSDOC_OUT) |
| 93 | + |
| 94 | + |
| 95 | +.PHONY: docs-src docs-jsdoc jsdoc-json view-src-docs clean-jsdoc |
| 96 | + |
0 commit comments