pycoze 0.1.199__tar.gz → 0.1.200__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (39) hide show
  1. {pycoze-0.1.199 → pycoze-0.1.200}/PKG-INFO +1 -1
  2. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/agent.py +1 -0
  3. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/bot.py +28 -25
  4. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze.egg-info/PKG-INFO +1 -1
  5. {pycoze-0.1.199 → pycoze-0.1.200}/setup.py +1 -1
  6. {pycoze-0.1.199 → pycoze-0.1.200}/LICENSE +0 -0
  7. {pycoze-0.1.199 → pycoze-0.1.200}/README.md +0 -0
  8. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/__init__.py +0 -0
  9. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ai/__init__.py +0 -0
  10. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ai/vram_reserve.py +0 -0
  11. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/automation/__init__.py +0 -0
  12. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/automation/browser/__init__.py +0 -0
  13. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/automation/browser/edge_driver_manager.py +0 -0
  14. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/__init__.py +0 -0
  15. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/__init__.py +0 -0
  16. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/agent_types/__init__.py +0 -0
  17. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/agent_types/const.py +0 -0
  18. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/agent_types/openai_func_call_agent.py +0 -0
  19. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/assistant.py +0 -0
  20. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent/chat.py +0 -0
  21. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/bot/agent_chat.py +0 -0
  22. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/reference/__init__.py +0 -0
  23. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/reference/bot.py +0 -0
  24. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/reference/lib.py +0 -0
  25. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/reference/tool.py +0 -0
  26. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/reference/workflow.py +0 -0
  27. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ui/__init__.py +0 -0
  28. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ui/base.py +0 -0
  29. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ui/color.py +0 -0
  30. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ui/typ.py +0 -0
  31. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/ui/ui_def.py +0 -0
  32. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/utils/__init__.py +0 -0
  33. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/utils/arg.py +0 -0
  34. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/utils/env.py +0 -0
  35. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze/utils/text_or_file.py +0 -0
  36. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze.egg-info/SOURCES.txt +0 -0
  37. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze.egg-info/dependency_links.txt +0 -0
  38. {pycoze-0.1.199 → pycoze-0.1.200}/pycoze.egg-info/top_level.txt +0 -0
  39. {pycoze-0.1.199 → pycoze-0.1.200}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pycoze
3
- Version: 0.1.199
3
+ Version: 0.1.200
4
4
  Summary: Package for pycoze only!
5
5
  Author: Yuan Jie Xiong
6
6
  Author-email: aiqqqqqqq@qq.com
@@ -70,6 +70,7 @@ async def run_agent(agent, inputs: list, tool_compatibility_mode: bool, should_e
70
70
 
71
71
  if __name__ == "__main__":
72
72
  from langchain_experimental.tools import PythonREPLTool
73
+ import threading
73
74
 
74
75
  llm_file = r"C:\Users\aiqqq\AppData\Roaming\pycoze\JsonStorage\llm.json"
75
76
  with open(llm_file, "r", encoding="utf-8") as f:
@@ -6,7 +6,6 @@ import threading
6
6
  import queue
7
7
  import time
8
8
  import asyncio
9
- import multiprocessing
10
9
 
11
10
 
12
11
  class PeekableQueue(queue.Queue):
@@ -15,14 +14,17 @@ class PeekableQueue(queue.Queue):
15
14
  return self._get()
16
15
  except queue.Empty:
17
16
  return None
17
+
18
18
 
19
-
20
- def run_agent_chat(bot_setting_file, history, should_exit):
21
- loop = asyncio.new_event_loop()
22
- asyncio.set_event_loop(loop)
23
- loop.run_until_complete(agent_chat(bot_setting_file, history, should_exit))
24
- loop.close()
25
-
19
+ async def handle_input_queue(input_queue, should_exit, history):
20
+ while not should_exit.is_set():
21
+ if not input_queue.empty():
22
+ next_input_text = input_queue.get_nowait()
23
+ if next_input_text == INTERRUPT_MESSAGE:
24
+ history.append(AIMessage(content=CHAT_DATA["info"]))
25
+ should_exit.set() # 设置退出标志
26
+ break
27
+ await asyncio.sleep(0.1) # 非阻塞地等待一段时间
26
28
 
27
29
  def chat(bot_setting_file: str):
28
30
  history = []
@@ -35,7 +37,6 @@ def chat(bot_setting_file: str):
35
37
  input_queue.put(input_text)
36
38
  else:
37
39
  raise ValueError("Invalid message")
38
-
39
40
 
40
41
  input_thread_instance = threading.Thread(target=input_thread, args=(input_queue,))
41
42
  input_thread_instance.start()
@@ -51,22 +52,24 @@ def chat(bot_setting_file: str):
51
52
  history.append(HumanMessage(message["content"]))
52
53
  clear_chat_data()
53
54
 
54
- # 创建进程退出标志
55
- should_exit = multiprocessing.Event()
56
- agent_chat_process = multiprocessing.Process(target=run_agent_chat, args=(bot_setting_file, history, should_exit)) # 需要是独立进程,不然无法创建新进程
57
- agent_chat_process.start()
58
-
59
- next_input_text = ""
60
- while agent_chat_process.is_alive():
61
- if not input_queue.empty():
62
- next_input_text = input_queue.peek()
63
- if next_input_text == INTERRUPT_MESSAGE:
64
- history.append(AIMessage(content=CHAT_DATA["info"]))
65
- should_exit.set() # 设置退出标志
66
- break
67
- time.sleep(0.1) # 每隔 0.1 秒检查一次
68
- if next_input_text != INTERRUPT_MESSAGE:
55
+ # 创建一个异步事件循环
56
+ loop = asyncio.new_event_loop()
57
+ asyncio.set_event_loop(loop)
58
+
59
+ # 创建一个 Event 对象用于中断
60
+ should_exit = asyncio.Event()
61
+
62
+ # 并发运行 agent_chat 和 handle_input_queue
63
+ agent_chat_task = loop.create_task(agent_chat(bot_setting_file, history, should_exit))
64
+ input_handler_task = loop.create_task(handle_input_queue(input_queue, should_exit, history))
65
+
66
+ # 运行所有任务
67
+ loop.run_until_complete(asyncio.gather(agent_chat_task, input_handler_task))
68
+
69
+ # 如果没有中断,则添加 AI 的响应到历史记录
70
+ if not should_exit.is_set():
69
71
  history.append(AIMessage(content=CHAT_DATA["output"]))
72
+
70
73
  except json.JSONDecodeError:
71
74
  print("Invalid JSON format in input message.")
72
75
  except KeyError:
@@ -81,6 +84,6 @@ def chat(bot_setting_file: str):
81
84
  def get_chat_response(bot_setting_file: str, input_text: str):
82
85
  history = [HumanMessage(input_text)]
83
86
  clear_chat_data()
84
- should_exit = multiprocessing.Event()
87
+ should_exit = threading.Event()
85
88
  asyncio.run(agent_chat(bot_setting_file, history, should_exit))
86
89
  return CHAT_DATA["output"]
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pycoze
3
- Version: 0.1.199
3
+ Version: 0.1.200
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.199",
5
+ version="0.1.200",
6
6
  packages=find_packages(),
7
7
  install_requires=[],
8
8
  author="Yuan Jie Xiong",
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