diff --git a/src/sage_docbuild/ext/multidocs.py b/src/sage_docbuild/ext/multidocs.py index e844b9a6671..f91c7753ca3 100644 --- a/src/sage_docbuild/ext/multidocs.py +++ b/src/sage_docbuild/ext/multidocs.py @@ -226,7 +226,7 @@ def citation_dir(app: Sphinx) -> Path: if dirs[0] == '/': dirs.pop(0) tail = dirs[1:] - citedir = (sage_doc / "inventory").joinpath(*tail) + citedir = (sage_doc / "inventory").joinpath(*tail) else: citedir = outdir / "inventory" os.makedirs(citedir, exist_ok=True) @@ -303,6 +303,10 @@ def copy_static_files(self): shutil.rmtree(static_dir) except OSError: os.unlink(static_dir) + # This ensures that the symlink we are creating points to an + # existing directory. See trac #33608. + os.makedirs(os.path.join(app.builder.outdir, master_static_dir), + exist_ok=True) os.symlink(master_static_dir, static_dir) app.builder.copy_static_files = link_static_files @@ -313,10 +317,9 @@ def copy_static_files(self): app.emit('env-check-consistency', app.env) - def setup(app: Sphinx): app.add_config_value('multidocs_is_master', True, True) app.add_config_value('multidocs_subdoc_list', [], True) app.add_config_value('multidoc_first_pass', 0, False) # 1 = deactivate the loading of the inventory app.connect('builder-inited', init_subdoc) - return {'parallel_read_safe': True} + return {'parallel_read_safe': True}