import subprocess

from jaxltl import DEPENDENCIES_DIR

RABINIZER_PATH = DEPENDENCIES_DIR / "rabinizer4/bin/ltl2ldba"


def run_rabinizer(formula: str) -> str:
    """Convert an LTL formula to a LDBA in the HOA format."""
    # -p: parallel processing
    # -d: construct a non-generalised Buechi automaton
    # -e: keep generated epsilon transitions
    command = [RABINIZER_PATH, "-i", formula, "-p", "-d", "-e"]
    run = subprocess.run(command, capture_output=True, text=True, check=False)
    if run.stderr != "":
        raise RuntimeError(
            f"Rabinizer call `{' '.join(command)}` resulted in an error.\nError: {run.stderr}."
        )
    return run.stdout


if __name__ == "__main__":
    f = "FG a"
    ldba = run_rabinizer(f)
    print(ldba)
