Support include syntax for markdown
What does this MR do and why?
Adds a new markdown syntax to allow for the transclusion/including of another file or url.
::include{file=FILE_OR_URL}
The ::include
must be on it's own line, staring in column one. Trailing spaces are not allowed.
This feature is modeled on our implementation of the Asciidoc include support. The same ApplicationSetings
are also used, wiki_asciidoc_allow_uri_includes
and asciidoc_max_includes
.
-
This is only supported in repository files, either a project's repository or a wiki's repository.
-
Files are specified relative to their position in a repository. So if you're editing the
doc/README.md
file and wish to include theexamples/code.md
file, then you would use::include{file=../examples/code.md}
-
URLs are only supported when the
ApplicationSetting.wiki_asciidoc_allow_uri_includes
is set totrue
. That value defaults tofalse
, and is alsofalse
on gitlab.com. -
You can specify multiple includes (up to
asciidoc_max_includes
), with each include on it's own line. At this time we do not support transitive dependencies, meaning includes inside of an include.
Current Asciidoc documentation:
- https://docs.gitlab.com/ee/user/asciidoc.html#includes
- https://docs.gitlab.com/ee/administration/wikis/index.html#allow-uri-includes-for-asciidoc
MR acceptance checklist
Please evaluate this MR against the MR acceptance checklist. It helps you analyze changes to reduce risks in quality, performance, reliability, security, and maintainability.
How to set up and validate locally
-
Enable the
markdown_include_directive
feature flag from the Rails console. -
In either a project's repository or a wiki, create the following files:
doc/README.md (if creating in the wiki, don't add the
.md
, it's done automatically)Below is a code example: ::include{file=../examples/code.md}
examples/code.md (if creating in the wiki, don't add the
.md
, it's done automatically)```ruby # A code example def call ... end ```
-
When you view the
doc/README.md
file, you should see the code example included. -
Try various syntax permutations - only a strict
::include{file=FILE_OR_URL}
should be recognized. -
Add the include 33 times to a file. Only the first 32 should be expanded.
-
If a file does not exist, then an error will appear inline.
-
Add the following include and see it NOT included (just the link should be visible)
::include{file=https://gitlab.com/gitlab-org/gitlab/-/raw/master/MAINTENANCE.md}
-
Now jump into the Rails console and enable
wiki_asciidoc_allow_uri_includes
:ApplicationSetting.first.update!(wiki_asciidoc_allow_uri_includes: true)
-
The URL should now be included. You may need to edit the
doc/README.md
file in order to force the caching to be invalidated.
Related to #195798 (closed)