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.
- 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
|