19import lxml.etree
as ET
23from datetime
import date
25sys.path.insert(0, os.path.abspath(
"../Base/Python"))
26sys.path.insert(0, os.path.abspath(
"./_ext"))
40 "sphinx_markdown_tables",
51 "user_guide/extensions_manager.html":
"extensions.html#extensions-manager",
60autodoc_mock_imports = [
66myst_enable_extensions = [
76myst_heading_anchors = 6
79myst_dmath_allow_labels =
True
84 Given a Slicer source director, extract <major>.<minor> version
85 from top-level `CMakeLists.txt`.
87 Return a dictionary containing `major` and `minor` version components as strings
89 slicer_src_dir = os.path.abspath(slicer_src_dir)
91 part: re.compile(rf
'set\(Slicer_VERSION_{part.upper()} "(\d+)"\)')
92 for part
in [
"major",
"minor"]
97 cmakelists_path = os.path.join(slicer_src_dir,
"CMakeLists.txt")
98 with open(cmakelists_path)
as cmake_file:
99 for line
in cmake_file:
100 for part, pattern
in version_patterns.items():
101 match = pattern.match(line.strip())
102 if match
is not None:
103 version_parts[part] = match.group(1)
104 if len(version_parts) == len(version_patterns ):
107 if len(version_parts) != len(version_patterns):
108 raise ValueError(f
"Failed to extract version from {cmakelists_path}")
115 Determine the Doxygen documentation version to use based on the Slicer version.
117 Return Doxygen version identifier (`v<major>.<minor>` for Stable, `main` for Preview)
120 slicer_repo_dir = os.path.dirname(os.path.dirname(__file__))
124 is_even = int(version_parts[
"minor"]) % 2 == 0
125 return "v{major}.{minor}".format(**version_parts)
if is_even
else "main"
130print(f
"Slicer API documentation URL scheme: {slicerapidocs_url_scheme}")
140 "slicerapidocs": slicerapidocs_url_scheme,
145templates_path = [
"_templates"]
150source_suffix = [
".rst",
".md"]
157copyright = f
"{date.today().year}, Slicer Community"
158author =
"Slicer Community"
172exclude_patterns = [
"_build",
"Thumbs.db",
".DS_Store",
"_moduledescriptions"]
176if os.environ.get(
"EXCLUDE_API_REFERENCE",
"False") ==
"True":
177 print(
"API reference is excluded from documentation.")
178 exclude_patterns.append(
"developer_guide/vtkTeem.rst")
179 exclude_patterns.append(
"developer_guide/vtkAddon.rst")
180 exclude_patterns.append(
"developer_guide/vtkITK.rst")
181 exclude_patterns.append(
"developer_guide/slicer.rst")
182 exclude_patterns.append(
"developer_guide/mrml.rst")
187 "title":
"Page Not Found",
189<h1>Page Not Found</h1>
190<p>Sorry, we couldn't find that page.</p>
191<p>Try using the search box or go to the homepage.</p>
196pygments_style =
"sphinx"
199todo_include_todos =
False
202rst_prolog = open(
"global.rst.in").read()
206html_logo =
"_static/images/3D-Slicer-Mark.png"
213html_theme =
"sphinx_rtd_theme"
219html_theme_options = {
221 "includehidden":
False,
226 "display_github":
True,
230 "github_user":
"slicer",
231 "github_repo":
"slicer",
232 "github_version":
"main",
233 "conf_py_path":
"/Docs/",
239html_static_path = [
"_static"]
250htmlhelp_basename =
"3DSlicerdoc"
274 (master_doc,
"3DSlicer.tex",
"3D Slicer Documentation",
275 "Slicer Community",
"manual"),
284 (master_doc,
"3Dslicer",
"3D Slicer Documentation",
295 (master_doc,
"3DSlicer",
"3D Slicer Documentation",
296 author,
"3DSlicer",
"One line description of project.",
321docsfolder = os.path.dirname(__file__)
325 os.path.join(docsfolder,
"../Modules/CLI"),
326 os.path.join(docsfolder,
"_extracli"),
333 "TestGridTransformRegistration.xml",
334 "DiffusionTensorTest.xml",
338outpath = os.path.join(docsfolder,
"_moduledescriptions")
339os.makedirs(outpath, exist_ok=
True)
340with open(os.path.join(outpath,
"_readme_.txt"),
"w")
as descriptionfile:
341 descriptionfile.write(
"Content of this folder is automatically generated by Docs/conf.py from CLI module descriptor XML files\n")
342 descriptionfile.write(
"during documentation build. The folder can be deleted because it is automatically regenerated when needed.")
345def _generatemd(dom, docsfolder, outpath, xslt, suffix):
346 """Helper function to create markdown file from CLI module description XML file using XSLT"""
347 xsltpath = os.path.join(docsfolder, xslt)
348 transform = ET.XSLT(ET.parse(xsltpath))
349 content = str(transform(dom))
350 with open(os.path.join(outpath, os.path.splitext(name)[0] + suffix +
".md"),
"w", encoding=
"utf8")
as outfile:
351 outfile.write(content)
354for inputpath
in inputpaths:
355 for root, dirs, files
in os.walk(inputpath):
357 if name
in excludenames:
359 if name.endswith(
".xml"):
360 print(f
"Generating CLI module documentation from {name}")
361 dom = ET.parse(os.path.join(root, name))
362 _generatemd(dom, docsfolder, outpath,
"cli_module_overview_to_md.xsl",
"Overview")
363 _generatemd(dom, docsfolder, outpath,
"cli_module_parameters_to_md.xsl",
"Parameters")
_get_apidocs_doxygen_version()
_extract_slicer_xy_version(slicer_src_dir)