pycoze 0.1.161__py3-none-any.whl → 0.1.163__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,5 +1,5 @@
1
1
  from .agent import run_agent
2
2
  from .assistant import Runnable
3
- from .chat import INPUT_MESSAGE, CHAT_DATA, clear_chat_data, output, info
3
+ from .chat import INPUT_MESSAGE, INTERRUPT_MESSAGE, CHAT_DATA, clear_chat_data, output, info
4
4
 
5
- __all__ = [run_agent, Runnable, INPUT_MESSAGE, output]
5
+ __all__ = [run_agent, Runnable, INPUT_MESSAGE, INTERRUPT_MESSAGE, CHAT_DATA, clear_chat_data, output, info]
pycoze/bot/agent/chat.py CHANGED
@@ -3,12 +3,13 @@ from langchain_core.messages import AIMessage
3
3
 
4
4
 
5
5
  INPUT_MESSAGE = "INPUT_MESSAGE=>"
6
+ INTERRUPT_MESSAGE = "INTERRUPT_MESSAGE=>"
6
7
  _OUTPUT_MESSAGE = "OUTPUT_MESSAGE=>"
7
8
  _INFOMATION_MESSAGE = "INFOMATION_MESSAGE=>"
8
9
  _LOG = "LOG=>"
9
10
 
10
11
 
11
- CHAT_DATA = {"output":"","info":""}
12
+ CHAT_DATA = {"output":"", "info":""}
12
13
 
13
14
 
14
15
  def log(content, *args, end="\n", **kwargs):
@@ -16,13 +17,13 @@ def log(content, *args, end="\n", **kwargs):
16
17
 
17
18
 
18
19
  def clear_chat_data():
19
- CHAT_DATA = {"output":"","info":""}
20
+ CHAT_DATA = {"output":"", "info":""}
20
21
 
21
22
 
22
23
  def output(role, content):
23
24
  assert role == "assistant"
24
- print(_OUTPUT_MESSAGE + json.dumps({"role": role, "content": content}))
25
25
  CHAT_DATA["output"] = content
26
+ print(_OUTPUT_MESSAGE + json.dumps({"role": role, "content": content}))
26
27
 
27
28
  def info(role, content):
28
29
  CHAT_DATA["info"] += content
pycoze/bot/agent_chat.py CHANGED
@@ -32,7 +32,7 @@ def load_abilities(bot_setting_file: str):
32
32
  return abilities
33
33
 
34
34
 
35
- def agent_chat(bot_setting_file, history):
35
+ async def agent_chat(bot_setting_file, history, should_exit):
36
36
  role_setting = load_role_setting(bot_setting_file)
37
37
  abilities = load_abilities(bot_setting_file)
38
38
 
@@ -75,5 +75,20 @@ def agent_chat(bot_setting_file, history):
75
75
  assistant_message=prompt,
76
76
  tool_compatibility_mode=cfg["toolCompatibilityMode"],
77
77
  )
78
- result = asyncio.run(run_agent(agent, history, cfg["toolCompatibilityMode"]))
79
- output("assistant", result)
78
+
79
+ async def run_agent_with_exit_check():
80
+ result = await run_agent(agent, history, cfg["toolCompatibilityMode"])
81
+ if not should_exit.is_set():
82
+ output("assistant", result)
83
+
84
+ task = asyncio.create_task(run_agent_with_exit_check())
85
+
86
+ while not task.done():
87
+ if should_exit.is_set():
88
+ task.cancel()
89
+ try:
90
+ await task
91
+ except asyncio.CancelledError:
92
+ pass
93
+ break
94
+ await asyncio.sleep(0.1)
pycoze/bot/bot.py CHANGED
@@ -1,27 +1,82 @@
1
1
  from langchain_core.messages import HumanMessage, AIMessage
2
- from .agent import INPUT_MESSAGE, output, CHAT_DATA, clear_chat_data
2
+ from .agent import INPUT_MESSAGE, INTERRUPT_MESSAGE, output, CHAT_DATA, clear_chat_data
3
3
  from .agent_chat import agent_chat
4
4
  import json
5
5
  import threading
6
+ import queue
7
+ import time
6
8
 
7
9
 
10
+ class PeekableQueue(queue.Queue):
11
+ def peek(self):
12
+ with self.mutex:
13
+ if self.empty():
14
+ return None
15
+ return self.queue[0]
16
+
17
+
8
18
  def chat(bot_setting_file: str):
9
19
  history = []
10
- while True:
11
- input_text = input()
12
- if not input_text.startswith(INPUT_MESSAGE):
13
- raise ValueError("Invalid message")
14
- message = json.loads(input_text[len(INPUT_MESSAGE) :])
15
- history.append(HumanMessage(message["content"]))
16
- clear_chat_data()
17
- agent_chat_thread = threading.Thread(target=agent_chat, args=(bot_setting_file, history))
18
- agent_chat_thread.start()
19
- agent_chat_thread.join()
20
- history.append(AIMessage(content=CHAT_DATA["output"]))
20
+ input_queue = PeekableQueue()
21
+
22
+ def input_thread(input_queue: PeekableQueue):
23
+ while True:
24
+ input_text = input()
25
+ if input_text == INTERRUPT_MESSAGE:
26
+ break
27
+ if not input_text.startswith(INPUT_MESSAGE):
28
+ raise ValueError("Invalid message")
29
+ input_queue.put(input_text)
30
+
31
+ input_thread_instance = threading.Thread(target=input_thread, args=(input_queue,))
32
+ input_thread_instance.start()
33
+
34
+ try:
35
+ while True:
36
+ if not input_queue.empty():
37
+ input_text = input_queue.get()
38
+ if input_text == INTERRUPT_MESSAGE:
39
+ continue
40
+ try:
41
+ message = json.loads(input_text[len(INPUT_MESSAGE):])
42
+ history.append(HumanMessage(message["content"]))
43
+ clear_chat_data()
44
+
45
+ # 为每个线程创建一个独立的退出标志
46
+ should_exit = threading.Event()
47
+ agent_chat_thread = threading.Thread(target=asyncio.run, args=(agent_chat(bot_setting_file, history, should_exit),))
48
+ agent_chat_thread.start()
49
+
50
+ next_input_text = ""
51
+ while agent_chat_thread.is_alive():
52
+ if not input_queue.empty():
53
+ next_input_text = input_queue.peek()
54
+ if next_input_text == INTERRUPT_MESSAGE:
55
+ should_exit.set() # 设置退出标志
56
+ history.append(AIMessage(content=CHAT_DATA["info"]))
57
+ break
58
+ time.sleep(0.1) # 每隔 0.1 秒检查一次
59
+ if next_input_text != INTERRUPT_MESSAGE:
60
+ history.append(AIMessage(content=CHAT_DATA["output"]))
61
+ except json.JSONDecodeError:
62
+ print("Invalid JSON format in input message.")
63
+ except KeyError:
64
+ print("Missing 'content' key in input message.")
65
+ except Exception as e:
66
+ print(f"An error occurred: {e}")
67
+ finally:
68
+ input_thread_instance.join()
69
+
21
70
 
22
71
 
23
72
  def get_chat_response(bot_setting_file: str, input_text: str):
24
73
  history = [HumanMessage(input_text)]
25
74
  clear_chat_data()
26
- agent_chat(bot_setting_file, history)
27
- return CHAT_DATA["output"]
75
+
76
+ # 为每个线程创建一个独立的退出标志
77
+ should_exit = threading.Event()
78
+
79
+ # 使用 asyncio.run 来运行异步函数,并等待其完成
80
+ asyncio.run(agent_chat(bot_setting_file, history, should_exit))
81
+
82
+ return CHAT_DATA["output"]
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pycoze
3
- Version: 0.1.161
3
+ Version: 0.1.163
4
4
  Summary: Package for pycoze only!
5
5
  Author: Yuan Jie Xiong
6
6
  Author-email: aiqqqqqqq@qq.com
@@ -2,12 +2,12 @@ pycoze/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
2
  pycoze/ai/__init__.py,sha256=odM2lgYSnApxw4AzLV_5AyaxL5_MLfydOSB1VmLGFyA,75
3
3
  pycoze/ai/vram_reserve.py,sha256=QbqaA8qv87cnEpOVDMygi0BNMxuhLYwj1UKfR_D5BD4,4340
4
4
  pycoze/bot/__init__.py,sha256=6HHMxDQVOyZM9dtSjQm9tjGnhj4h7CixD0JOvEwTi48,41
5
- pycoze/bot/agent_chat.py,sha256=7duMif9tz5ewZJgbHsg8oGKY4vtiDUZ9MGtVQsY_HRw,2851
6
- pycoze/bot/bot.py,sha256=HiH8cT0pUEr8otiukYvUCWQzeEGpclFGhfcWSsZvBdg,993
7
- pycoze/bot/agent/__init__.py,sha256=FG5TAjc-P-yk2bS_lSyM-znvHLc5m_KkQHWbyCDiogI,192
5
+ pycoze/bot/agent_chat.py,sha256=ZNSbXOmsAgd77DcDmhylMAbEFxZCM09kE8kPJ1uuvcY,3282
6
+ pycoze/bot/bot.py,sha256=bKJgA3LyulMAJY7V34jlTbzfXRNuYcEc3E4hFXr2aME,3221
7
+ pycoze/bot/agent/__init__.py,sha256=3wE8_FFQS8j2BY-g9Cr-onV0POEvDRZaw_NCzpqrNus,265
8
8
  pycoze/bot/agent/agent.py,sha256=Aue8nWeW_I7e1jo4o7cUjFFjrsV9NtVUiTX3EQYHmbA,3507
9
9
  pycoze/bot/agent/assistant.py,sha256=3iLxnRvf_ia0cP-FHK5Fv4ylltlnzPq1KscRCFYqjkc,1147
10
- pycoze/bot/agent/chat.py,sha256=_gjdzlBUFCkvmNh-6nYoaOLcmhujcW-Vva6rbixWCb4,702
10
+ pycoze/bot/agent/chat.py,sha256=07WZEbre5LibRCuoFel7fWGQ9Yc7YFUrSuOWF9YkT24,746
11
11
  pycoze/bot/agent/agent_types/__init__.py,sha256=zmU2Kmrv5mCdfg-QlPn2H6pWxbGeq8s7YTqLhpzJC6k,179
12
12
  pycoze/bot/agent/agent_types/const.py,sha256=BfUKPrhAHREoMLHuFNG2bCIEkC1-f7K0LEqNg4RwiRE,70
13
13
  pycoze/bot/agent/agent_types/openai_func_call_agent.py,sha256=SnEm5MODHn2uMsaMNqgzULM_91vqLHC0TU6ovwCOqLU,6675
@@ -23,8 +23,8 @@ pycoze/ui/ui_def.py,sha256=UhhU_yB3GV9ISbvTWT48hsHPHI250BhMILh6bu5Uioo,4206
23
23
  pycoze/utils/__init__.py,sha256=ET0W5wzq4zlY3dr1wHVbbeRKlKdC_zqHt9b0jZyHohw,94
24
24
  pycoze/utils/arg.py,sha256=orLVEGw3x2f3l7bZDbBPkkdDPSdqXo-_Rs-4ZhzmrEw,984
25
25
  pycoze/utils/text_or_file.py,sha256=gpxZVWt2DW6YiEg_MnMuwg36VNf3TX383QD_1oZNB0Y,551
26
- pycoze-0.1.161.dist-info/LICENSE,sha256=QStd_Qsd0-kAam_-sOesCIp_uKrGWeoKwt9M49NVkNU,1090
27
- pycoze-0.1.161.dist-info/METADATA,sha256=-6Wvyq5tBGXKanIppP-0yKZOZamz7429lkcBO-r6MAQ,726
28
- pycoze-0.1.161.dist-info/WHEEL,sha256=bFJAMchF8aTQGUgMZzHJyDDMPTO3ToJ7x23SLJa1SVo,92
29
- pycoze-0.1.161.dist-info/top_level.txt,sha256=76dPeDhKvOCleL3ZC5gl1-y4vdS1tT_U1hxWVAn7sFo,7
30
- pycoze-0.1.161.dist-info/RECORD,,
26
+ pycoze-0.1.163.dist-info/LICENSE,sha256=QStd_Qsd0-kAam_-sOesCIp_uKrGWeoKwt9M49NVkNU,1090
27
+ pycoze-0.1.163.dist-info/METADATA,sha256=4cOMkFtdFTivaZgSqRzEJk7jIWhhiZo40bIFn75C-wY,726
28
+ pycoze-0.1.163.dist-info/WHEEL,sha256=bFJAMchF8aTQGUgMZzHJyDDMPTO3ToJ7x23SLJa1SVo,92
29
+ pycoze-0.1.163.dist-info/top_level.txt,sha256=76dPeDhKvOCleL3ZC5gl1-y4vdS1tT_U1hxWVAn7sFo,7
30
+ pycoze-0.1.163.dist-info/RECORD,,