| Total Complexity | 3 | 
| Total Lines | 37 | 
| Duplicated Lines | 0 % | 
| Changes | 0 | ||
| 1 | import json  | 
            ||
| 2 | import logging  | 
            ||
| 3 | from typing import Any, Protocol  | 
            ||
| 4 | |||
| 5 | from software_patterns import Proxy  | 
            ||
| 6 | |||
| 7 | __all__ = ['FFProbeProxy']  | 
            ||
| 8 | |||
| 9 | |||
| 10 | logger = logging.getLogger(__name__)  | 
            ||
| 11 | |||
| 12 | |||
| 13 | class CLIResult(Protocol):  | 
            ||
| 14 | exit_code: int  | 
            ||
| 15 | stdout: str  | 
            ||
| 16 | stderr: str  | 
            ||
| 17 | |||
| 18 | |||
| 19 | class FFMpegSubjectType(Protocol):  | 
            ||
| 20 | def __init__(self, ffmpeg_binary: str):  | 
            ||
| 21 | ...  | 
            ||
| 22 | |||
| 23 | def __call__(self, *ffmpeg_cli_args, **subprocess_settings) -> CLIResult:  | 
            ||
| 24 | ...  | 
            ||
| 25 | |||
| 26 | |||
| 27 | class FFMPEGProxy(Proxy[FFMpegSubjectType]):  | 
            ||
| 28 | """Proxy class for the ffmpeg CLI."""  | 
            ||
| 29 | |||
| 30 | def __call__(self, *ffmpeg_cli_args: str, **subprocess_settings: Any) -> CLIResult:  | 
            ||
| 31 | logger.error(  | 
            ||
| 32 | "Running ffmpeg: %s", json.dumps(list(ffmpeg_cli_args), indent=4, sort_keys=True)  | 
            ||
| 33 | )  | 
            ||
| 34 | res = self._proxy_subject(*ffmpeg_cli_args, **subprocess_settings)  | 
            ||
| 35 |         # logger.info("FFMPEG:\n%s", res.stderr) | 
            ||
| 36 | return res  | 
            ||
| 37 |