# Ultralytics YOLO 🚀, AGPL-3.0 license """ This Python script is designed to automate the building and post-processing of MkDocs documentation, particularly for projects with multilingual content. It streamlines the workflow for generating localized versions of the documentation and updating HTML links to ensure they are correctly formatted. Key Features: - Automated building of MkDocs documentation: The script compiles both the main documentation and any localized versions specified in separate MkDocs configuration files. - Post-processing of generated HTML files: After the documentation is built, the script updates all HTML files to remove the '.md' extension from internal links. This ensures that links in the built HTML documentation correctly point to other HTML pages rather than Markdown files, which is crucial for proper navigation within the web-based documentation. Usage: - Run the script from the root directory of your MkDocs project. - Ensure that MkDocs is installed and that all MkDocs configuration files (main and localized versions) are present in the project directory. - The script first builds the documentation using MkDocs, then scans the generated HTML files in the 'site' directory to update the internal links. - It's ideal for projects where the documentation is written in Markdown and needs to be served as a static website. Note: - This script is built to be run in an environment where Python and MkDocs are installed and properly configured. """ import os import re import shutil import subprocess from pathlib import Path from tqdm import tqdm os.environ["JUPYTER_PLATFORM_DIRS"] = "1" # fix DeprecationWarning: Jupyter is migrating to use standard platformdirs DOCS = Path(__file__).parent.resolve() SITE = DOCS.parent / "site" def build_docs(clone_repos=True): """Build docs using mkdocs.""" if SITE.exists(): print(f"Removing existing {SITE}") shutil.rmtree(SITE) # Get hub-sdk repo if clone_repos: repo = "https://github.com/ultralytics/hub-sdk" local_dir = DOCS.parent / Path(repo).name if not local_dir.exists(): os.system(f"git clone {repo} {local_dir}") os.system(f"git -C {local_dir} pull") # update repo shutil.rmtree(DOCS / "en/hub/sdk", ignore_errors=True) # delete if exists shutil.copytree(local_dir / "docs", DOCS / "en/hub/sdk") # for docs shutil.rmtree(DOCS.parent / "hub_sdk", ignore_errors=True) # delete if exists shutil.copytree(local_dir / "hub_sdk", DOCS.parent / "hub_sdk") # for mkdocstrings print(f"Cloned/Updated {repo} in {local_dir}") # Build the main documentation print(f"Building docs from {DOCS}") subprocess.run(f"mkdocs build -f {DOCS.parent}/mkdocs.yml --strict", check=True, shell=True) print(f"Site built at {SITE}") def update_page_title(file_path: Path, new_title: str): """Update the title of an HTML file.""" # Read the content of the file with open(file_path, encoding="utf-8") as file: content = file.read() # Replace the existing title with the new title updated_content = re.sub(r"