pycoze 0.1.200__py3-none-any.whl → 0.1.201__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/bot.py +42 -24
- {pycoze-0.1.200.dist-info → pycoze-0.1.201.dist-info}/METADATA +1 -1
- {pycoze-0.1.200.dist-info → pycoze-0.1.201.dist-info}/RECORD +6 -6
- {pycoze-0.1.200.dist-info → pycoze-0.1.201.dist-info}/LICENSE +0 -0
- {pycoze-0.1.200.dist-info → pycoze-0.1.201.dist-info}/WHEEL +0 -0
- {pycoze-0.1.200.dist-info → pycoze-0.1.201.dist-info}/top_level.txt +0 -0
pycoze/bot/bot.py
CHANGED
@@ -6,42 +6,62 @@ import threading
|
|
6
6
|
import queue
|
7
7
|
import time
|
8
8
|
import asyncio
|
9
|
+
import multiprocessing
|
10
|
+
from multiprocessing import Queue, Event
|
9
11
|
|
10
|
-
|
11
|
-
class PeekableQueue
|
12
|
+
# 假设 PeekableQueue 类已经定义好了,如果没有,请自行实现或使用其他方式
|
13
|
+
class PeekableQueue:
|
14
|
+
def __init__(self, maxsize=0):
|
15
|
+
self.queue = Queue(maxsize=maxsize)
|
16
|
+
|
17
|
+
def put(self, item):
|
18
|
+
self.queue.put(item)
|
19
|
+
|
20
|
+
def get(self):
|
21
|
+
return self.queue.get()
|
22
|
+
|
12
23
|
def peek(self):
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
return
|
17
|
-
|
24
|
+
with self.queue.mutex:
|
25
|
+
if self.queue.empty():
|
26
|
+
return None
|
27
|
+
return self.queue.queue[0]
|
28
|
+
|
29
|
+
def empty(self):
|
30
|
+
return self.queue.empty()
|
18
31
|
|
19
|
-
|
32
|
+
def input_process(input_queue: Queue, interrupt_event: Event):
|
33
|
+
while not interrupt_event.is_set():
|
34
|
+
input_text = input()
|
35
|
+
if input_text == INTERRUPT_MESSAGE or input_text.startswith(INPUT_MESSAGE):
|
36
|
+
input_queue.put(input_text)
|
37
|
+
else:
|
38
|
+
raise ValueError("Invalid message")
|
39
|
+
|
40
|
+
async def handle_input_queue(input_queue: Queue, should_exit: asyncio.Event, history):
|
20
41
|
while not should_exit.is_set():
|
21
|
-
|
42
|
+
try:
|
22
43
|
next_input_text = input_queue.get_nowait()
|
23
44
|
if next_input_text == INTERRUPT_MESSAGE:
|
24
45
|
history.append(AIMessage(content=CHAT_DATA["info"]))
|
25
46
|
should_exit.set() # 设置退出标志
|
26
47
|
break
|
48
|
+
except queue.Empty:
|
49
|
+
pass
|
27
50
|
await asyncio.sleep(0.1) # 非阻塞地等待一段时间
|
28
51
|
|
29
52
|
def chat(bot_setting_file: str):
|
30
53
|
history = []
|
31
54
|
input_queue = PeekableQueue()
|
55
|
+
interrupt_event = Event() # 用于中断输入进程的事件
|
32
56
|
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
if input_text == INTERRUPT_MESSAGE or input_text.startswith(INPUT_MESSAGE):
|
37
|
-
input_queue.put(input_text)
|
38
|
-
else:
|
39
|
-
raise ValueError("Invalid message")
|
40
|
-
|
41
|
-
input_thread_instance = threading.Thread(target=input_thread, args=(input_queue,))
|
42
|
-
input_thread_instance.start()
|
57
|
+
# 创建并启动输入进程
|
58
|
+
input_process_instance = multiprocessing.Process(target=input_process, args=(input_queue, interrupt_event))
|
59
|
+
input_process_instance.start()
|
43
60
|
|
44
61
|
try:
|
62
|
+
loop = asyncio.new_event_loop()
|
63
|
+
asyncio.set_event_loop(loop)
|
64
|
+
|
45
65
|
while True:
|
46
66
|
if not input_queue.empty():
|
47
67
|
input_text = input_queue.get()
|
@@ -51,10 +71,6 @@ def chat(bot_setting_file: str):
|
|
51
71
|
message = json.loads(input_text[len(INPUT_MESSAGE):])
|
52
72
|
history.append(HumanMessage(message["content"]))
|
53
73
|
clear_chat_data()
|
54
|
-
|
55
|
-
# 创建一个异步事件循环
|
56
|
-
loop = asyncio.new_event_loop()
|
57
|
-
asyncio.set_event_loop(loop)
|
58
74
|
|
59
75
|
# 创建一个 Event 对象用于中断
|
60
76
|
should_exit = asyncio.Event()
|
@@ -77,7 +93,9 @@ def chat(bot_setting_file: str):
|
|
77
93
|
except Exception as e:
|
78
94
|
print(f"An error occurred: {e}")
|
79
95
|
finally:
|
80
|
-
|
96
|
+
# 设置中断事件以停止输入进程
|
97
|
+
interrupt_event.set()
|
98
|
+
input_process_instance.join()
|
81
99
|
|
82
100
|
|
83
101
|
|
@@ -6,7 +6,7 @@ pycoze/automation/browser/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJW
|
|
6
6
|
pycoze/automation/browser/edge_driver_manager.py,sha256=gpgseunph5owZH6EskSYthuhey2SU3UP204gY0yIcuI,3022
|
7
7
|
pycoze/bot/__init__.py,sha256=6HHMxDQVOyZM9dtSjQm9tjGnhj4h7CixD0JOvEwTi48,41
|
8
8
|
pycoze/bot/agent_chat.py,sha256=hr0jGTd-lvLSe4vCcvaN2rKhB7BMBcVBtI1FpVa6ngs,3016
|
9
|
-
pycoze/bot/bot.py,sha256=
|
9
|
+
pycoze/bot/bot.py,sha256=9WtvKt3_kgXnBXZEXINoIm_Vz1Oj2C_onWxnS7rvY2k,4041
|
10
10
|
pycoze/bot/agent/__init__.py,sha256=3wE8_FFQS8j2BY-g9Cr-onV0POEvDRZaw_NCzpqrNus,265
|
11
11
|
pycoze/bot/agent/agent.py,sha256=Ueste4xWvkQFk5Giklv4c-kcxiPL-D-KafzZ4DONosY,3613
|
12
12
|
pycoze/bot/agent/assistant.py,sha256=3iLxnRvf_ia0cP-FHK5Fv4ylltlnzPq1KscRCFYqjkc,1147
|
@@ -28,8 +28,8 @@ pycoze/utils/__init__.py,sha256=Gi5EnrWZGMD2JRejgV4c_VLCXyvA2wwBFI_niDF5MUE,110
|
|
28
28
|
pycoze/utils/arg.py,sha256=GtfGbMTMdaK75Fwh6MpUe1pCA5X6Ep4LFG7a72YrzjI,525
|
29
29
|
pycoze/utils/env.py,sha256=W04lhvTHhAAC6EldP6kk2xrctqtu8K6kl1vDLZDNeh8,561
|
30
30
|
pycoze/utils/text_or_file.py,sha256=gpxZVWt2DW6YiEg_MnMuwg36VNf3TX383QD_1oZNB0Y,551
|
31
|
-
pycoze-0.1.
|
32
|
-
pycoze-0.1.
|
33
|
-
pycoze-0.1.
|
34
|
-
pycoze-0.1.
|
35
|
-
pycoze-0.1.
|
31
|
+
pycoze-0.1.201.dist-info/LICENSE,sha256=QStd_Qsd0-kAam_-sOesCIp_uKrGWeoKwt9M49NVkNU,1090
|
32
|
+
pycoze-0.1.201.dist-info/METADATA,sha256=NhdIlRwQ0ND-FWYkLsIv1xrVms2SVbF4w5hmBb15N9s,726
|
33
|
+
pycoze-0.1.201.dist-info/WHEEL,sha256=bFJAMchF8aTQGUgMZzHJyDDMPTO3ToJ7x23SLJa1SVo,92
|
34
|
+
pycoze-0.1.201.dist-info/top_level.txt,sha256=76dPeDhKvOCleL3ZC5gl1-y4vdS1tT_U1hxWVAn7sFo,7
|
35
|
+
pycoze-0.1.201.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|