From a8bc7e74ad6f551bd767d68a1a85fee4e023e963 2014-10-10 20:04:17 From: Thomas Kluyver Date: 2014-10-10 20:04:17 Subject: [PATCH] Generate documentation of line & cell magics --- diff --git a/docs/Makefile b/docs/Makefile index 39e29f7..f3df6e9 100644 --- a/docs/Makefile +++ b/docs/Makefile @@ -42,6 +42,7 @@ clean: clean_api -rm -rf build/* dist/* -cd $(SRCDIR)/config/options; cat generated | xargs -r rm -f -rm -rf $(SRCDIR)/config/options/generated + -rm -f $(SRCDIR)/interactive/magics-generated.txt pdf: latex cd build/latex && make all-pdf @@ -58,8 +59,8 @@ dist: html cp -al build/html . @echo "Build finished. Final docs are in html/" -html: api autoconfig -html_noapi: clean_api autoconfig +html: api autoconfig automagic +html_noapi: clean_api autoconfig automagic html html_noapi: mkdir -p build/html build/doctrees @@ -67,6 +68,12 @@ html html_noapi: @echo @echo "Build finished. The HTML pages are in build/html." +automagic: source/interactive/magics-generated.txt + +source/interactive/magics-generated.txt: + python autogen_magics.py + @echo "Created docs for line & cell magics" + autoconfig: source/config/options/generated source/config/options/generated: diff --git a/docs/autogen_magics.py b/docs/autogen_magics.py new file mode 100644 index 0000000..50c9dac --- /dev/null +++ b/docs/autogen_magics.py @@ -0,0 +1,45 @@ +from IPython.core.alias import Alias +from IPython.core.interactiveshell import InteractiveShell +from IPython.utils.text import dedent, indent + +shell = InteractiveShell.instance() +magic_docs = shell.magics_manager.lsmagic_docs() + +def isalias(name): + return isinstance(shell.magics_manager.magics['line'], Alias) + +line_magics = magic_docs['line'] +cell_magics = magic_docs['cell'] + +output = [ +"Line magics", +"===========", +"", +] + +for name, docstring in sorted(line_magics.items()): + if isalias(name): + # Aliases are magics, but shouldn't be documented here + continue + output.extend([".. magic:: %{}".format(name), + "", + indent(dedent(docstring)), + ""]) + +output.extend([ +"Cell magics" +"===========" +"", +]) + +for name, docstring in sorted(cell_magics.items()): + if docstring == line_magics.get(name, 'QQQP'): + # Don't redocument line magics that double as cell magics + continue + output.extend([".. cellmagic:: %%{}".format(name), + "", + indent(dedent(docstring)), + ""]) + +with open("source/interactive/magics-generated.txt", "w") as f: + f.write("\n".join(output)) \ No newline at end of file diff --git a/docs/source/interactive/index.rst b/docs/source/interactive/index.rst index 9a4ecdf..f238298 100644 --- a/docs/source/interactive/index.rst +++ b/docs/source/interactive/index.rst @@ -8,6 +8,7 @@ Using IPython for interactive work tutorial tips reference + magics shell qtconsole diff --git a/docs/source/interactive/magics.rst b/docs/source/interactive/magics.rst new file mode 100644 index 0000000..1a24289 --- /dev/null +++ b/docs/source/interactive/magics.rst @@ -0,0 +1,5 @@ +======================= +Built-in magic commands +======================= + +.. include:: magics-generated.txt diff --git a/docs/sphinxext/magics.py b/docs/sphinxext/magics.py index 401ca0c..6a47b50 100644 --- a/docs/sphinxext/magics.py +++ b/docs/sphinxext/magics.py @@ -20,5 +20,5 @@ def parse_cell_magic(env, sig, signode): def setup(app): - app.add_object_type('magic', 'magic', '%%%s (magic command)', parse_magic) - app.add_object_type('cellmagic', 'cellmagic', '%%%%%s (cell magic)', parse_cell_magic) + app.add_object_type('magic', 'magic', 'pair: %s; magic command', parse_magic) + app.add_object_type('cellmagic', 'cellmagic', 'pair: %s; cell magic', parse_cell_magic)