pycoze 0.1.202__py3-none-any.whl → 0.1.204__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 CHANGED
@@ -1,84 +1,71 @@
1
- from langchain_core.messages import HumanMessage, AIMessage
2
- from .agent import INPUT_MESSAGE, INTERRUPT_MESSAGE, output, CHAT_DATA, clear_chat_data
3
- from .agent_chat import agent_chat
1
+ import signal
2
+ import sys
4
3
  import json
5
- import threading
6
- import queue
7
- import time
4
+ from .agent import INPUT_MESSAGE, output, CHAT_DATA, clear_chat_data
5
+ from .agent_chat import agent_chat
6
+ from multiprocessing import Process, Event
8
7
  import asyncio
9
- import multiprocessing
10
- from multiprocessing import Queue, Event
11
8
 
9
+ # 用于标记中断请求
10
+ interrupt_flag = False
12
11
 
13
- class PeekableQueue(queue.Queue):
14
- def peek(self):
15
- try:
16
- return self._get()
17
- except queue.Empty:
18
- return None
19
-
20
- async def handle_input_queue(input_queue, should_exit, history):
21
- while not should_exit.is_set():
22
- if not input_queue.empty():
23
- next_input_text = input_queue.get_nowait()
24
- if next_input_text == INTERRUPT_MESSAGE:
25
- history.append(AIMessage(content=CHAT_DATA["info"]))
26
- should_exit.set() # 设置退出标志
27
- break
28
- await asyncio.sleep(0.1) # 非阻塞地等待一段时间
12
+ # 信号处理函数
13
+ def handle_interrupt(signum, frame):
14
+ global interrupt_flag
15
+ interrupt_flag = True
16
+ print("Interrupt signal received. Waiting for the current operation to complete...")
29
17
 
30
- def chat(bot_setting_file: str):
31
- history = []
32
- input_queue = PeekableQueue()
18
+ # 设置信号处理器
19
+ signal.signal(signal.SIGINT, handle_interrupt)
33
20
 
34
- def input_thread(input_queue: PeekableQueue):
35
- while True:
21
+ def read_input():
22
+ while True:
23
+ try:
36
24
  input_text = input()
37
- if input_text == INTERRUPT_MESSAGE or input_text.startswith(INPUT_MESSAGE):
38
- input_queue.put(input_text)
25
+ if input_text.startswith(INPUT_MESSAGE):
26
+ yield input_text
39
27
  else:
40
28
  raise ValueError("Invalid message")
29
+ except EOFError: # 如果输入流结束,则退出循环
30
+ break
41
31
 
42
- input_thread_instance = threading.Thread(target=input_thread, args=(input_queue,))
43
- input_thread_instance.start()
44
-
45
- try:
46
- while True:
47
- if not input_queue.empty():
48
- input_text = input_queue.get()
49
- if input_text == INTERRUPT_MESSAGE:
50
- continue
51
- try:
52
- message = json.loads(input_text[len(INPUT_MESSAGE):])
53
- history.append(HumanMessage(message["content"]))
54
- clear_chat_data()
55
-
56
- # 创建一个异步事件循环
57
- loop = asyncio.new_event_loop()
58
- asyncio.set_event_loop(loop)
59
-
60
- # 创建一个 Event 对象用于中断
61
- should_exit = asyncio.Event()
32
+ def chat(bot_setting_file: str):
33
+ history = []
34
+ for input_text in read_input():
35
+ try:
36
+ message = json.loads(input_text[len(INPUT_MESSAGE):])
37
+ history.append(HumanMessage(message["content"]))
38
+ clear_chat_data()
62
39
 
63
- # 并发运行 agent_chat 和 handle_input_queue
64
- agent_chat_task = loop.create_task(agent_chat(bot_setting_file, history, should_exit))
65
- input_handler_task = loop.create_task(handle_input_queue(input_queue, should_exit, history))
40
+ # 创建一个事件来控制子进程的退出
41
+ should_exit = Event()
42
+
43
+ # 使用进程来运行 agent_chat
44
+ agent_chat_process = Process(target=asyncio.run, args=(agent_chat(bot_setting_file, history, should_exit),))
45
+ agent_chat_process.start()
66
46
 
67
- # 运行所有任务
68
- loop.run_until_complete(asyncio.gather(agent_chat_task, input_handler_task))
47
+ # 检查是否收到了中断信号
48
+ while agent_chat_process.is_alive():
49
+ if interrupt_flag:
50
+ should_exit.set() # 设置退出标志
51
+ break
52
+ time.sleep(0.1) # 每隔 0.1 秒检查一次
69
53
 
70
- # 如果没有中断,则添加 AI 的响应到历史记录
71
- if not should_exit.is_set():
72
- history.append(AIMessage(content=CHAT_DATA["output"]))
54
+ # 确保子进程已经退出
55
+ agent_chat_process.join()
73
56
 
74
- except json.JSONDecodeError:
75
- print("Invalid JSON format in input message.")
76
- except KeyError:
77
- print("Missing 'content' key in input message.")
78
- except Exception as e:
79
- print(f"An error occurred: {e}")
80
- finally:
81
- input_thread_instance.join()
57
+ # 如果没有收到中断信号,记录输出
58
+ if not interrupt_flag:
59
+ history.append(AIMessage(content=CHAT_DATA["output"]))
60
+
61
+ # 重置中断标志
62
+ interrupt_flag = False
63
+ except json.JSONDecodeError:
64
+ print("Invalid JSON format in input message.")
65
+ except KeyError:
66
+ print("Missing 'content' key in input message.")
67
+ except Exception as e:
68
+ print(f"An error occurred: {e}")
82
69
 
83
70
 
84
71
  def get_chat_response(bot_setting_file: str, input_text: str):
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pycoze
3
- Version: 0.1.202
3
+ Version: 0.1.204
4
4
  Summary: Package for pycoze only!
5
5
  Author: Yuan Jie Xiong
6
6
  Author-email: aiqqqqqqq@qq.com
@@ -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=F4YI2RGruC31jX3MX1fLOTs6j81CRM_GZsU_xAyqKiY,3481
9
+ pycoze/bot/bot.py,sha256=GFLB6YoebO2ozgx6Co76tAQTJt2939w7YZEtpq5txWk,2622
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.202.dist-info/LICENSE,sha256=QStd_Qsd0-kAam_-sOesCIp_uKrGWeoKwt9M49NVkNU,1090
32
- pycoze-0.1.202.dist-info/METADATA,sha256=Eba5-C_KEnuUfCafG1RTxGyWGHiAIMaczsfgUeVQupo,726
33
- pycoze-0.1.202.dist-info/WHEEL,sha256=bFJAMchF8aTQGUgMZzHJyDDMPTO3ToJ7x23SLJa1SVo,92
34
- pycoze-0.1.202.dist-info/top_level.txt,sha256=76dPeDhKvOCleL3ZC5gl1-y4vdS1tT_U1hxWVAn7sFo,7
35
- pycoze-0.1.202.dist-info/RECORD,,
31
+ pycoze-0.1.204.dist-info/LICENSE,sha256=QStd_Qsd0-kAam_-sOesCIp_uKrGWeoKwt9M49NVkNU,1090
32
+ pycoze-0.1.204.dist-info/METADATA,sha256=hmJCpWK-dxGY1AaYShJI45WS5dy_4qtuwUGDtFbYd3g,726
33
+ pycoze-0.1.204.dist-info/WHEEL,sha256=bFJAMchF8aTQGUgMZzHJyDDMPTO3ToJ7x23SLJa1SVo,92
34
+ pycoze-0.1.204.dist-info/top_level.txt,sha256=76dPeDhKvOCleL3ZC5gl1-y4vdS1tT_U1hxWVAn7sFo,7
35
+ pycoze-0.1.204.dist-info/RECORD,,