import glob
import logging
import os
import sys
from argparse import Namespace

sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))

from agentreview import const
from agentreview.arguments import parse_args
from agentreview.experiment_config import all_settings
from agentreview.environments import PaperReview
from agentreview.paper_review_settings import get_experiment_settings
from agentreview.paper_review_arena import PaperReviewArena
from agentreview.utility.experiment_utils import initialize_players
from agentreview.utility.utils import project_setup, get_paper_decision_mapping

# Configure logging
logging.basicConfig(
    level=logging.DEBUG,
    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
    handlers=[logging.StreamHandler(sys.stdout)]
)

logger = logging.getLogger(__name__)

def main(args: Namespace):
    """
    Main routine for paper review and rebuttals:

    * Phase 1: Reviewer Assessment (reviewers write reviews)
    * Phase 2: Author-Reviewer Discussion (authors write rebuttals)
    * Phase 3: Reviewer-AC Discussion
    * Phase 4: Meta-Review Compilation (ACs write meta-reviews)

    Args:
        args (Namespace): Parsed arguments for configuring the review process.
    """
    args.task = "paper_review"

    paper_path = args.paper_path
    paper_id = os.path.basename(paper_path).split(".pdf")[0]

    print(const.AGENTREVIEW_LOGO)

    # Ground-truth decision used to categorize paper quality
    paper_decision = "ai_paper"

    experiment_setting = get_experiment_settings(
        paper_id=paper_id,
        paper_decision=paper_decision,
        setting=all_settings[args.experiment_name],
    )

    logger.info("Experiment started!")
    logger.info(f"Paper ID: {paper_id} (Decision in {args.conference}: {paper_decision})")

    players = initialize_players(experiment_setting=experiment_setting, args=args)
    player_names = [player.name for player in players]

    env = PaperReview(
        player_names=player_names,
        paper_decision=paper_decision,
        paper_id=paper_id,
        args=args,
        experiment_setting=experiment_setting
    )

    arena = PaperReviewArena(
        players=players,
        environment=env,
        args=args,
        global_prompt=const.GLOBAL_PROMPT
    )

    arena.launch_cli(interactive=False)
    logger.info("Done!")


if __name__ == "__main__":
    project_setup()
    main(parse_args())