import queue
import threading
import traceback
import time
from call_openai import OpenAIApiProxy
from diskcache import Cache
import re
import json

model = "gpt-4-1106-preview"
max_tries = 10
max_size = 1024 * 1024 * 1000 * 1000  # 1000 GB
cache = Cache("./cache", size_limit=max_size)


class Consumer:
    def __init__(self):
        pass
    def stage_1_process_data(buffer: queue.Queue, lock, target_file, is_while):
        #while not buffer.empty():
        pattern = r"\[(\d+)\]"

        while 1:
            if not is_while:
                if buffer.empty():
                    break
            print('----consumer--')
            eval_prompt, items, pbar = buffer.get()
            try:
                now_try = 0
                while now_try < max_tries:
                    print('now_try:', now_try)
                    try:
                        cache_key = eval_prompt
                        if cache_key in cache and len(cache[cache_key].split('the score is')) == 2:
                            print('match_key')
                            resp_content = cache[cache_key]
                        else:
                            proxy = OpenAIApiProxy()
                            resp = proxy.call(model, eval_prompt)
                            resp_content = resp["choices"][0]["message"]["content"].strip()
                            #with lock:
                            #    cache[cache_key] = resp_content

                        #print('costumer_res:', resp_content)
                        #print('costumer_items:', items)
                        #if len(resp_content.split('the score is')) != 2:
                        #    break
                        score_res = resp_content.split('the score is')[1]
                        match = re.search(pattern, score_res)
                        score = match.group(1)
                        if score not in ['1', '2', '3', '4', '5']:
                            cache[cache_key] = ''
                            now_try += 1
                            continue
                        items['stage_1_score'] = score
                        items['stage_1_judge'] = resp_content
                        with lock:
                            target_file.write(json.dumps(items, ensure_ascii=False) + '\n')
                            target_file.flush()
                            print('--wirte')
                            cache[cache_key] = resp_content
                        break
                    except Exception as e:
                        now_try += 1
                        cache[cache_key] = ''
                        continue
                        #break
                    now_try += 1
            except Exception as e:
                print(e)
                #traceback.print_exc()
                #time.sleep(1)
                print(f'{threading.current_thread().name} Error {data[0]}')
            #finally:
                #buffer.task_done()
            pbar.update(1)
            

        print(f'{threading.current_thread().name} {buffer.qsize()} Exit')
