import json

def _load_annotation(path):
    all_annotations = None  
    difficulty = []
    with open(path, 'r') as f:
        for line in f:
            if line.strip() == '':
                continue
            line = json.loads(line.strip())
            if "difficulty" in line:
                difficulty.append(line["difficulty"])
            else:
                raise ValueError("No difficulty in annotation file")
    return all_annotations, difficulty

def get_all_environment_configs():
    iter_num = 0
    # initial config
    label_path = "./verl/environments/pddl/test.jsonl"
    game_name = ["gripper", "blockworld", "barman", "tyreworld"]
    env_num_per_task = 20
    Num_Problems = {"barman":20, "blockworld":10,"gripper":20, "tyreworld":10}

    env_configs = []
    iter_num = 0
    _, difficulties = _load_annotation(label_path)
    
    for game_name in game_name:
        num_problems = min(env_num_per_task, Num_Problems[game_name])
        for i in range(num_problems):
            env_configs.append({
                "game_id": f"{game_name}_index_{i}",
                "game_name": game_name,
                "problem_index": i,
                "difficulty": difficulties[iter_num]
            })
            iter_num += 1
        
    return env_configs

if __name__ == "__main__":
    from env import PDDL
    env_configs = get_all_environment_configs()
    for env_config in env_configs:
        try:
            env = PDDL.from_config(env_config)
        except:
            print(env_config)
    breakpoint()