#!/bin/bash
# OpenHands Framework Evaluation Script
# Run evaluation using OpenHands with specified LLM backend

TASK_DIR="${1:-.}"  # Task directory (default: current directory)
CONFIG_FILE="${2:-./openhands_config.toml}"  # Config file
SDK_SCRIPT="${3:-./openhands_sdk.py}"  # SDK script

# Check if task directory exists
if [ ! -d "$TASK_DIR" ]; then
    echo "Error: Task directory not found: $TASK_DIR"
    exit 1
fi

# Check if config file exists
if [ ! -f "$CONFIG_FILE" ]; then
    echo "Error: Config file not found: $CONFIG_FILE"
    exit 1
fi

# Check if SDK script exists
if [ ! -f "$SDK_SCRIPT" ]; then
    echo "Error: SDK script not found: $SDK_SCRIPT"
    exit 1
fi

# Get absolute paths
TASK_DIR="$(cd "$TASK_DIR" && pwd)"
SDK_SCRIPT="$(realpath "$SDK_SCRIPT")"

echo "=========================================="
echo "OpenHands Framework Evaluation"
echo "=========================================="
echo "Task directory: $TASK_DIR"
echo "Config file: $CONFIG_FILE"
echo "SDK script: $SDK_SCRIPT"
echo ""

# Check environment variables
if [ -z "$LLM_API_KEY" ]; then
    echo "Warning: LLM_API_KEY not set"
    echo "Please set API key: export LLM_API_KEY=your-api-key"
fi

# Set trajectory path
TRAJECTORY_DIR="$TASK_DIR/trajectory"
mkdir -p "$TRAJECTORY_DIR"
export TRAJECTORY_PATH="$TRAJECTORY_DIR/trajectory.jsonl"
export STATS_PATH="$TRAJECTORY_DIR/stats.json"

echo "Trajectory will be saved to: $TRAJECTORY_PATH"
echo "Statistics will be saved to: $STATS_PATH"
echo ""

# Run OpenHands SDK
cd "$TASK_DIR" || exit 1
python "$SDK_SCRIPT"

EXIT_CODE=$?

echo ""
echo "=========================================="
if [ $EXIT_CODE -eq 0 ]; then
    echo "✅ Evaluation completed successfully"
    if [ -f "$TASK_DIR/result.txt" ]; then
        echo "Result: $(cat $TASK_DIR/result.txt)"
    else
        echo "Warning: result.txt not found"
    fi
    
    if [ -f "$STATS_PATH" ]; then
        echo ""
        echo "Statistics:"
        python -m json.tool "$STATS_PATH" 2>/dev/null | grep -E '"total_tokens"|"duration_seconds"|"interaction_rounds"' || cat "$STATS_PATH"
    fi
else
    echo "❌ Evaluation failed (exit code: $EXIT_CODE)"
fi
echo "=========================================="

exit $EXIT_CODE

