pycoze 0.1.202__py3-none-any.whl → 0.1.204__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
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,,