

def print_dialogue(debug,system,prompt,pred,val):
    if debug:
        print(f"[SYSTEM] {system}", flush=True)
        print(f"[USER] {prompt}", flush=True)
        print(f"[PRED] {pred}", flush=True)
        print(f"[PARSED] {val}", flush=True)

def query_llm_sub(raw_hist, llm, template, debug=False):
    system = template.get_system_text()
    prompt = template.get_main_prompt(raw_hist)
    pred = llm.predict(system,prompt)
    val = template.parse_output(pred)
    print_dialogue(debug, system, prompt, pred, val)
    return(val)

def query_llm(raw_hist, llm, template, debug=False):
    val  = query_llm_sub(raw_hist, llm, template, debug=debug)
    reverted = False
    failed = False
    if val is None and template.cot:
        ## Try again without CoT
        print("[Debug] invalid parse, trying no-CoT", flush=True)
        reverted = True
        template.cot = False
        val = query_llm_sub(raw_hist, llm, template, debug=debug)
        template.cot = True
    if val is None and template.dist:
        ## Try again without dist
        print("[Debug] invalid parse, trying unique", flush=True)
        revert = True
        template.dist = False
        val = query_llm_sub(raw_hist, llm, template, debug=debug)
        template.dist = True
    if val is None:
        print("[Debug] invalid parse, failing", flush=True)
        failed = True
    return (val, reverted, failed)
