pycoze 0.1.161__py3-none-any.whl → 0.1.163__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- pycoze/bot/agent/__init__.py +2 -2
- pycoze/bot/agent/chat.py +4 -3
- pycoze/bot/agent_chat.py +18 -3
- pycoze/bot/bot.py +69 -14
- {pycoze-0.1.161.dist-info → pycoze-0.1.163.dist-info}/METADATA +1 -1
- {pycoze-0.1.161.dist-info → pycoze-0.1.163.dist-info}/RECORD +9 -9
- {pycoze-0.1.161.dist-info → pycoze-0.1.163.dist-info}/LICENSE +0 -0
- {pycoze-0.1.161.dist-info → pycoze-0.1.163.dist-info}/WHEEL +0 -0
- {pycoze-0.1.161.dist-info → pycoze-0.1.163.dist-info}/top_level.txt +0 -0
pycoze/bot/agent/__init__.py
CHANGED
@@ -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
|
-
|
79
|
-
|
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
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
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
|
-
|
27
|
-
|
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"]
|
@@ -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=
|
6
|
-
pycoze/bot/bot.py,sha256=
|
7
|
-
pycoze/bot/agent/__init__.py,sha256=
|
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=
|
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.
|
27
|
-
pycoze-0.1.
|
28
|
-
pycoze-0.1.
|
29
|
-
pycoze-0.1.
|
30
|
-
pycoze-0.1.
|
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,,
|
File without changes
|
File without changes
|
File without changes
|