"""
Ape Agent Scaffold - Main Entry Point.

Usage:
    python -m ape.scaffolds.ape_agent.main <tasks_file> [--config <yaml>] [--orchestrator_id <id>] [--max_tasks <n>] [key=value ...]

Configuration examples (use Python literal syntax):
    llm_config.temperature=0.7
    llm_config.streaming=False
    llm_config.max_tokens=8000
    task_config.enabled_tools='["Read","Write"]'

Configuration priority: CLI overrides > YAML > Pydantic defaults
"""

import argparse
import asyncio
from pathlib import Path
from typing import Optional, Dict, Any, TYPE_CHECKING

from .config import ApeAgentConfig
from ape.utils import load_yaml, parse_cli_args, deep_merge, create_logger
from ape.orchestration.orchestrator import run_orchestrator_from_file

if TYPE_CHECKING:
    import logging


def create_argument_parser() -> argparse.ArgumentParser:
    """Create command-line argument parser with minimal arguments."""
    parser = argparse.ArgumentParser(
        description="Ape Agent Scaffold",
        formatter_class=argparse.RawDescriptionHelpFormatter
    )

    parser.add_argument('tasks_file', type=Path, help='Path to tasks JSONL file')
    parser.add_argument('--config', type=Path, default=None, help='Path to YAML configuration file')
    parser.add_argument('--orchestrator_id', type=str, default=None, help='Orchestrator ID')
    parser.add_argument('--max_tasks', type=int, default=None, help='Maximum number of tasks')

    return parser


def main(
    tasks_file: Path,
    config_path: Optional[Path] = None,
    orchestrator_id: Optional[str] = None,
    max_tasks: Optional[int] = None,
    cli_overrides: Optional[Dict[str, Any]] = None,
    logger: Optional['logging.LoggerAdapter'] = None
) -> None:
    """Ape Agent Scaffold entry point."""
    if logger is None:
        logger = create_logger()

    # Build configuration: YAML + CLI overrides
    config_dict = load_yaml(config_path) if config_path else {}
    if cli_overrides:
        config_dict = deep_merge(config_dict, cli_overrides)

    # Extract task_config overrides
    task_config_overrides = config_dict.pop('task_config', {})
    # Persist task_config_overrides for runtime task rebuild
    config_dict["task_config_overrides"] = task_config_overrides

    # Create scaffold configuration
    scaffold_config = ApeAgentConfig.model_validate(config_dict)

    logger.info(f"Starting Ape Agent scaffold | tasks: {tasks_file}")

    asyncio.run(run_orchestrator_from_file(
        tasks_file=tasks_file,
        config=scaffold_config,
        orchestrator_id=orchestrator_id,
        max_tasks=max_tasks,
        task_config_overrides=task_config_overrides,
        logger=logger
    ))


if __name__ == '__main__':
    console_logger = create_logger()
    parser = create_argument_parser()
    args, remaining_args = parser.parse_known_args()

    main(
        tasks_file=args.tasks_file,
        config_path=args.config,
        orchestrator_id=args.orchestrator_id,
        max_tasks=args.max_tasks,
        cli_overrides=parse_cli_args(remaining_args),
        logger=console_logger
    )
