"""
Helpers for ensuring the repo root is on sys.path when running scripts.
"""

import sys
from pathlib import Path
from typing import Optional


def add_repo_root(start_file: str, package_dir_name: str = "concept_synth") -> Optional[str]:
    """
    Add the repo root (parent of package_dir_name) to sys.path.
    Returns the repo root string if found.
    """
    path = Path(start_file).resolve()
    for parent in [path] + list(path.parents):
        if parent.name == package_dir_name:
            repo_root = parent.parent
            repo_root_str = str(repo_root)
            if repo_root_str not in sys.path:
                sys.path.insert(0, repo_root_str)
            return repo_root_str
    return None
