19import lxml.etree
as ET
23from datetime
import date
25sys.path.insert(0, os.path.abspath(
"../Base/Python"))
40 "sphinx_markdown_tables",
52autodoc_mock_imports = [
58myst_enable_extensions = [
68myst_heading_anchors = 6
71myst_dmath_allow_labels =
True
76 Given a Slicer source director, extract <major>.<minor> version
77 from top-level `CMakeLists.txt`.
79 Return a dictionary containing `major` and `minor` version components as strings
81 slicer_src_dir = os.path.abspath(slicer_src_dir)
83 part: re.compile(rf
'set\(Slicer_VERSION_{part.upper()} "(\d+)"\)')
84 for part
in [
"major",
"minor"]
89 cmakelists_path = os.path.join(slicer_src_dir,
"CMakeLists.txt")
90 with open(cmakelists_path)
as cmake_file:
91 for line
in cmake_file:
92 for part, pattern
in version_patterns.items():
93 match = pattern.match(line.strip())
95 version_parts[part] = match.group(1)
96 if len(version_parts) == len(version_patterns ):
99 if len(version_parts) != len(version_patterns):
100 raise ValueError(f
"Failed to extract version from {cmakelists_path}")
107 Determine the Doxygen documentation version to use based on the Slicer version.
109 Return Doxygen version identifier (`v<major>.<minor>` for Stable, `main` for Preview)
112 slicer_repo_dir = os.path.dirname(os.path.dirname(__file__))
116 is_even = int(version_parts[
"minor"]) % 2 == 0
117 return "v{major}.{minor}".format(**version_parts)
if is_even
else "main"
122print(f
"Slicer API documentation URL scheme: {slicerapidocs_url_scheme}")
132 "slicerapidocs": slicerapidocs_url_scheme,
137templates_path = [
"_templates"]
142source_suffix = [
".rst",
".md"]
149copyright = f
"{date.today().year}, Slicer Community"
150author =
"Slicer Community"
164exclude_patterns = [
"_build",
"Thumbs.db",
".DS_Store",
"_moduledescriptions"]
168if os.environ.get(
"EXCLUDE_API_REFERENCE",
"False") ==
"True":
169 print(
"API reference is excluded from documentation.")
170 exclude_patterns.append(
"developer_guide/vtkTeem.rst")
171 exclude_patterns.append(
"developer_guide/vtkAddon.rst")
172 exclude_patterns.append(
"developer_guide/vtkITK.rst")
173 exclude_patterns.append(
"developer_guide/slicer.rst")
174 exclude_patterns.append(
"developer_guide/mrml.rst")
179 "title":
"Page Not Found",
181<h1>Page Not Found</h1>
182<p>Sorry, we couldn't find that page.</p>
183<p>Try using the search box or go to the homepage.</p>
188pygments_style =
"sphinx"
191todo_include_todos =
False
194rst_prolog = open(
"global.rst.in").read()
198html_logo =
"_static/images/3D-Slicer-Mark.png"
205html_theme =
"sphinx_rtd_theme"
211html_theme_options = {
213 "includehidden":
False,
218 "display_github":
True,
222 "github_user":
"slicer",
223 "github_repo":
"slicer",
224 "github_version":
"main",
225 "conf_py_path":
"/Docs/",
231html_static_path = [
"_static"]
242htmlhelp_basename =
"3DSlicerdoc"
266 (master_doc,
"3DSlicer.tex",
"3D Slicer Documentation",
267 "Slicer Community",
"manual"),
276 (master_doc,
"3Dslicer",
"3D Slicer Documentation",
287 (master_doc,
"3DSlicer",
"3D Slicer Documentation",
288 author,
"3DSlicer",
"One line description of project.",
313docsfolder = os.path.dirname(__file__)
317 os.path.join(docsfolder,
"../Modules/CLI"),
318 os.path.join(docsfolder,
"_extracli"),
325 "TestGridTransformRegistration.xml",
326 "DiffusionTensorTest.xml",
330outpath = os.path.join(docsfolder,
"_moduledescriptions")
331os.makedirs(outpath, exist_ok=
True)
332with open(os.path.join(outpath,
"_readme_.txt"),
"w")
as descriptionfile:
333 descriptionfile.write(
"Content of this folder is automatically generated by Docs/conf.py from CLI module descriptor XML files\n")
334 descriptionfile.write(
"during documentation build. The folder can be deleted because it is automatically regenerated when needed.")
337def _generatemd(dom, docsfolder, outpath, xslt, suffix):
338 """Helper function to create markdown file from CLI module description XML file using XSLT"""
339 xsltpath = os.path.join(docsfolder, xslt)
340 transform = ET.XSLT(ET.parse(xsltpath))
341 content = str(transform(dom))
342 with open(os.path.join(outpath, os.path.splitext(name)[0] + suffix +
".md"),
"w", encoding=
"utf8")
as outfile:
343 outfile.write(content)
346for inputpath
in inputpaths:
347 for root, dirs, files
in os.walk(inputpath):
349 if name
in excludenames:
351 if name.endswith(
".xml"):
352 print(f
"Generating CLI module documentation from {name}")
353 dom = ET.parse(os.path.join(root, name))
354 _generatemd(dom, docsfolder, outpath,
"cli_module_overview_to_md.xsl",
"Overview")
355 _generatemd(dom, docsfolder, outpath,
"cli_module_parameters_to_md.xsl",
"Parameters")
_get_apidocs_doxygen_version()
_extract_slicer_xy_version(slicer_src_dir)