pycoze 0.1.205__tar.gz → 0.1.207__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {pycoze-0.1.205 → pycoze-0.1.207}/PKG-INFO +1 -1
- pycoze-0.1.207/pycoze/bot/bot.py +36 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze.egg-info/PKG-INFO +1 -1
- {pycoze-0.1.205 → pycoze-0.1.207}/setup.py +1 -1
- pycoze-0.1.205/pycoze/bot/bot.py +0 -77
- {pycoze-0.1.205 → pycoze-0.1.207}/LICENSE +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/README.md +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ai/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ai/vram_reserve.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/automation/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/automation/browser/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/automation/browser/edge_driver_manager.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/agent.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/agent_types/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/agent_types/const.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/agent_types/openai_func_call_agent.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/assistant.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent/chat.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/bot/agent_chat.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/reference/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/reference/bot.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/reference/lib.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/reference/tool.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/reference/workflow.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ui/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ui/base.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ui/color.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ui/typ.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/ui/ui_def.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/utils/__init__.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/utils/arg.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/utils/env.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze/utils/text_or_file.py +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze.egg-info/SOURCES.txt +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze.egg-info/dependency_links.txt +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/pycoze.egg-info/top_level.txt +0 -0
- {pycoze-0.1.205 → pycoze-0.1.207}/setup.cfg +0 -0
@@ -0,0 +1,36 @@
|
|
1
|
+
from langchain_core.messages import HumanMessage, AIMessage
|
2
|
+
import threading
|
3
|
+
import queue
|
4
|
+
import json
|
5
|
+
from .agent import INPUT_MESSAGE, output, CHAT_DATA, clear_chat_data
|
6
|
+
from .agent_chat import agent_chat
|
7
|
+
import asyncio
|
8
|
+
|
9
|
+
class PeekableQueue(queue.Queue):
|
10
|
+
def peek(self):
|
11
|
+
try:
|
12
|
+
return self._get()
|
13
|
+
except queue.Empty:
|
14
|
+
return None
|
15
|
+
|
16
|
+
|
17
|
+
def chat(bot_setting_file: str):
|
18
|
+
history = []
|
19
|
+
while True:
|
20
|
+
input_text = input()
|
21
|
+
if not input_text.startswith(INPUT_MESSAGE):
|
22
|
+
raise ValueError("Invalid message")
|
23
|
+
message = json.loads(input_text[len(INPUT_MESSAGE) :])
|
24
|
+
history.append(HumanMessage(message["content"]))
|
25
|
+
result = agent_chat(bot_setting_file, history)
|
26
|
+
history.append(AIMessage(result["output"]))
|
27
|
+
|
28
|
+
|
29
|
+
|
30
|
+
|
31
|
+
def get_chat_response(bot_setting_file: str, input_text: str):
|
32
|
+
history = [HumanMessage(input_text)]
|
33
|
+
clear_chat_data()
|
34
|
+
should_exit = threading.Event()
|
35
|
+
asyncio.run(agent_chat(bot_setting_file, history, should_exit))
|
36
|
+
return CHAT_DATA["output"]
|
pycoze-0.1.205/pycoze/bot/bot.py
DELETED
@@ -1,77 +0,0 @@
|
|
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
|
-
from langchain_core.messages import HumanMessage, AIMessage
|
9
|
-
|
10
|
-
# 用于标记中断请求
|
11
|
-
interrupt_flag = False
|
12
|
-
|
13
|
-
# 信号处理函数
|
14
|
-
def handle_interrupt(signum, frame):
|
15
|
-
global interrupt_flag
|
16
|
-
interrupt_flag = True
|
17
|
-
print("Interrupt signal received. Waiting for the current operation to complete...")
|
18
|
-
|
19
|
-
# 设置信号处理器
|
20
|
-
signal.signal(signal.SIGINT, handle_interrupt)
|
21
|
-
|
22
|
-
def read_input():
|
23
|
-
while True:
|
24
|
-
try:
|
25
|
-
input_text = input()
|
26
|
-
if input_text.startswith(INPUT_MESSAGE):
|
27
|
-
yield input_text
|
28
|
-
else:
|
29
|
-
raise ValueError("Invalid message")
|
30
|
-
except EOFError: # 如果输入流结束,则退出循环
|
31
|
-
break
|
32
|
-
|
33
|
-
def chat(bot_setting_file: str):
|
34
|
-
history = []
|
35
|
-
for input_text in read_input():
|
36
|
-
try:
|
37
|
-
message = json.loads(input_text[len(INPUT_MESSAGE):])
|
38
|
-
history.append(HumanMessage(message["content"]))
|
39
|
-
clear_chat_data()
|
40
|
-
|
41
|
-
# 创建一个事件来控制子进程的退出
|
42
|
-
should_exit = Event()
|
43
|
-
|
44
|
-
# 使用进程来运行 agent_chat
|
45
|
-
agent_chat_process = Process(target=asyncio.run, args=(agent_chat(bot_setting_file, history, should_exit),))
|
46
|
-
agent_chat_process.start()
|
47
|
-
|
48
|
-
# 检查是否收到了中断信号
|
49
|
-
while agent_chat_process.is_alive():
|
50
|
-
if interrupt_flag:
|
51
|
-
should_exit.set() # 设置退出标志
|
52
|
-
break
|
53
|
-
time.sleep(0.1) # 每隔 0.1 秒检查一次
|
54
|
-
|
55
|
-
# 确保子进程已经退出
|
56
|
-
agent_chat_process.join()
|
57
|
-
|
58
|
-
# 如果没有收到中断信号,记录输出
|
59
|
-
if not interrupt_flag:
|
60
|
-
history.append(AIMessage(content=CHAT_DATA["output"]))
|
61
|
-
|
62
|
-
# 重置中断标志
|
63
|
-
interrupt_flag = False
|
64
|
-
except json.JSONDecodeError:
|
65
|
-
print("Invalid JSON format in input message.")
|
66
|
-
except KeyError:
|
67
|
-
print("Missing 'content' key in input message.")
|
68
|
-
except Exception as e:
|
69
|
-
print(f"An error occurred: {e}")
|
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
|
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
|
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
|