
from tasks.checks.pour_liquid import (
    check_grasp_container_success,
    check_pour_success,
    check_release_container_success,
)
from exceptions import SubtaskSkip

def run_task(env, task, provider=None, subtask_results=None, max_repairs=5, **kwargs):
    if subtask_results is None:
        subtask_results = []

    print("[PourLiquid] Starting task")

    # Get positions
    beaker_pos = env.get_obj_pos("beaker")
    mug_pos = env.get_obj_pos("mug")

    print(f"[PourLiquid] Beaker position: {beaker_pos}")
    print(f"[PourLiquid] Mug position: {mug_pos}")

    # Step 1: Grasp beaker
    print("\n[PourLiquid] Step 1: Grasping beaker")
    try:
        result = provider.execute_subtask(
            subtask_name="grasp_container",
            env=env,
            obj_name="beaker",
            check_func=lambda e, o, t: check_grasp_container_success(e, o),
            max_repairs=max_repairs,
        )
        subtask_results.append(result)
    except SubtaskSkip as e:
        print("[PourLiquid] Skipping grasp_container")
        if e.result is not None:
            subtask_results.append(e.result)

    # Step 2: Pour into mug
    print("\n[PourLiquid] Step 2: Pouring into mug")
    try:
        result = provider.execute_subtask(
            subtask_name="pour_into_container",
            env=env,
            target_name="mug",
            check_func=lambda e, o, t: check_pour_success(e, task),
            max_repairs=max_repairs,
            target_pos=mug_pos,
        )
        subtask_results.append(result)
    except SubtaskSkip as e:
        print("[PourLiquid] Skipping pour_into_container")
        if e.result is not None:
            subtask_results.append(e.result)

    # Step 3: Release beaker back to original position
    print("\n[PourLiquid] Step 3: Releasing beaker")
    try:
        result = provider.execute_subtask(
            subtask_name="release_container",
            env=env,
            obj_name="beaker",
            check_func=lambda e, o, t: check_release_container_success(e, o),
            max_repairs=max_repairs,
            original_pos=beaker_pos,
        )
        subtask_results.append(result)
    except SubtaskSkip as e:
        print("[PourLiquid] Skipping release_container")
        if e.result is not None:
            subtask_results.append(e.result)

    # Check result
    result = env.check_result()
    print(f"\n[PourLiquid] Task completed with result: {result}")
    return result
