diff --git a/docs/conf.py b/docs/conf.py
index 9646fc0..14eb543 100644
--- a/docs/conf.py
+++ b/docs/conf.py
@@ -14,7 +14,7 @@
# https://www.sphinx-doc.org/en/master/usage/configuration.html#general-configuration
extensions = [
- 'sphinx.ext.autodoc',
+ 'sphinx.ext.autodoc','sphinx.ext.autosectionlabel'
]
templates_path = ['_templates']
@@ -41,3 +41,7 @@
# test the path; not strictly needed
import markdown2canvas
+
+rst_prolog = """
+.. |markdowndefaults| replace:: :attr:`markdown2canvas.translation_functions.default_markdown_extensions`
+"""
diff --git a/docs/tutorials/markdown_python_extensions.rst b/docs/tutorials/markdown_python_extensions.rst
new file mode 100644
index 0000000..4ee56cb
--- /dev/null
+++ b/docs/tutorials/markdown_python_extensions.rst
@@ -0,0 +1,74 @@
+
+
+Customize translation from Markdown to HTML via extensions to `markdown`
+============================================================================
+
+
+This library, `markdown2canvas`, essentially acts as a wrapper around a translation function `markdown2canvas.translation_functions.markdown2html`, or just `markdown2html` for short. The `markdown2html` function uses the Python library `markdown` (`link to library `_) to translate. You can customize the behaviour of this translation using "extensions" to the `markdown` library.
+
+
+Background
+------------
+
+Before I tell you how to use your own custom set of extensions to `markdown`, here's a brief rundown of how `markdown2canvas` works when you publish a page or assignment to Canvas:
+
+#. :doc:`The style is applied `.
+
+ #. The markdown header and footer from the used style are assembled around your `source.md`.
+ #. The html header and footer from the used style are assembled around that.
+
+#. :doc:`Replacements are done `.
+#. Emoji shortcodes are emojified
+#. The markdown is translated to HTML. THIS IS THE STEP YOU CAN CUSTOMIZE.
+#. :doc:`Links to existing content are implemented <../making_links_to_existing_content>`, further modifying the HTML.
+#. Local files and images which are linked-to in the source are uploaded (if necessary), and the HTML is adjusted to use the Canvas links to that content.
+#. Content properties are set from `meta.json`.
+#. The content is placed in modules as described in `meta.json`.
+
+This tutorial is about customizing the first translation to HTML, by using `markdown` extensions.
+
+
+Provided default `markdown` extensions
+--------------------------------------------
+
+This library provides a decent set of default extensions, chosen for
+
+* Syntax highlighting of code
+* Translating markdown tables
+* Trying to make sure that markdown inside of HTML is translated, too
+
+The specific default list is |markdowndefaults|.
+
+
+
+Specifying your own list of extensions
+-----------------------------------------
+
+You may wish to use your own set of extensions. Easy! Just specify the list in your `defaults.json` file.
+
+#. Edit `_course_metadata/defaults.json`.
+#. Add a key-value pair.
+
+ * Key: `markdown_extensions`
+ * Value: A list of strings which are names of extensions.
+
+
+
+
+Where to find more extensions
+----------------------------------
+
+I have found `the official `markdown` Extensions documentation ` to be very helpful.
+
+Cruise the list, find one that you need, and try it out by:
+
+* Add it to the list of extensions you are using
+* Publish the content to a test or sandbox course on Canvas
+* Check it out! Did it do what you needed?
+
+
+Limitations
+---------------
+
+ℹ️ Known limitation: This system is missing methods for you writing your own extensions to `markdown`. I do not know what happens if your list of extensions includes references to your own, but I suspect errors because they'll be strings, not Python modules, classes, or functions.
+