pycoze 0.1.203__tar.gz → 0.1.204__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (40) hide show
  1. {pycoze-0.1.203 → pycoze-0.1.204}/PKG-INFO +1 -1
  2. pycoze-0.1.204/pycoze/bot/bot.py +76 -0
  3. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze.egg-info/PKG-INFO +1 -1
  4. {pycoze-0.1.203 → pycoze-0.1.204}/setup.py +1 -1
  5. pycoze-0.1.203/pycoze/bot/bot.py +0 -77
  6. {pycoze-0.1.203 → pycoze-0.1.204}/LICENSE +0 -0
  7. {pycoze-0.1.203 → pycoze-0.1.204}/README.md +0 -0
  8. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/__init__.py +0 -0
  9. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ai/__init__.py +0 -0
  10. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ai/vram_reserve.py +0 -0
  11. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/automation/__init__.py +0 -0
  12. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/automation/browser/__init__.py +0 -0
  13. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/automation/browser/edge_driver_manager.py +0 -0
  14. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/__init__.py +0 -0
  15. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/__init__.py +0 -0
  16. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/agent.py +0 -0
  17. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/agent_types/__init__.py +0 -0
  18. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/agent_types/const.py +0 -0
  19. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/agent_types/openai_func_call_agent.py +0 -0
  20. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/assistant.py +0 -0
  21. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent/chat.py +0 -0
  22. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/bot/agent_chat.py +0 -0
  23. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/reference/__init__.py +0 -0
  24. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/reference/bot.py +0 -0
  25. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/reference/lib.py +0 -0
  26. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/reference/tool.py +0 -0
  27. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/reference/workflow.py +0 -0
  28. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ui/__init__.py +0 -0
  29. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ui/base.py +0 -0
  30. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ui/color.py +0 -0
  31. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ui/typ.py +0 -0
  32. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/ui/ui_def.py +0 -0
  33. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/utils/__init__.py +0 -0
  34. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/utils/arg.py +0 -0
  35. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/utils/env.py +0 -0
  36. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze/utils/text_or_file.py +0 -0
  37. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze.egg-info/SOURCES.txt +0 -0
  38. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze.egg-info/dependency_links.txt +0 -0
  39. {pycoze-0.1.203 → pycoze-0.1.204}/pycoze.egg-info/top_level.txt +0 -0
  40. {pycoze-0.1.203 → pycoze-0.1.204}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pycoze
3
- Version: 0.1.203
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
@@ -0,0 +1,76 @@
1
+ import signal
2
+ import sys
3
+ import json
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
7
+ import asyncio
8
+
9
+ # 用于标记中断请求
10
+ interrupt_flag = False
11
+
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...")
17
+
18
+ # 设置信号处理器
19
+ signal.signal(signal.SIGINT, handle_interrupt)
20
+
21
+ def read_input():
22
+ while True:
23
+ try:
24
+ input_text = input()
25
+ if input_text.startswith(INPUT_MESSAGE):
26
+ yield input_text
27
+ else:
28
+ raise ValueError("Invalid message")
29
+ except EOFError: # 如果输入流结束,则退出循环
30
+ break
31
+
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()
39
+
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()
46
+
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 秒检查一次
53
+
54
+ # 确保子进程已经退出
55
+ agent_chat_process.join()
56
+
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}")
69
+
70
+
71
+ def get_chat_response(bot_setting_file: str, input_text: str):
72
+ history = [HumanMessage(input_text)]
73
+ clear_chat_data()
74
+ should_exit = threading.Event()
75
+ asyncio.run(agent_chat(bot_setting_file, history, should_exit))
76
+ return CHAT_DATA["output"]
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pycoze
3
- Version: 0.1.203
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
@@ -2,7 +2,7 @@ from setuptools import setup, find_packages
2
2
 
3
3
  setup(
4
4
  name="pycoze",
5
- version="0.1.203",
5
+ version="0.1.204",
6
6
  packages=find_packages(),
7
7
  install_requires=[],
8
8
  author="Yuan Jie Xiong",
@@ -1,77 +0,0 @@
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
4
- import json
5
- import threading
6
- import queue
7
- import time
8
- import asyncio
9
-
10
-
11
- class PeekableQueue(queue.Queue):
12
- def peek(self):
13
- try:
14
- return self._get()
15
- except queue.Empty:
16
- return None
17
-
18
- def chat(bot_setting_file: str):
19
- history = []
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 or input_text.startswith(INPUT_MESSAGE):
26
- input_queue.put(input_text)
27
- else:
28
- raise ValueError("Invalid message")
29
-
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
- history.append(AIMessage(content=CHAT_DATA["info"]))
56
- should_exit.set() # 设置退出标志
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
-
70
-
71
-
72
- def get_chat_response(bot_setting_file: str, input_text: str):
73
- history = [HumanMessage(input_text)]
74
- clear_chat_data()
75
- should_exit = threading.Event()
76
- asyncio.run(agent_chat(bot_setting_file, history, should_exit))
77
- return CHAT_DATA["output"]
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes