pycoze 0.1.332__tar.gz → 0.1.334__tar.gz
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-0.1.332 → pycoze-0.1.334}/PKG-INFO +1 -1
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/chat.py +6 -5
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/chat_base.py +2 -2
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/lib.py +22 -12
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/prompt.md +2 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/PKG-INFO +1 -1
- {pycoze-0.1.332 → pycoze-0.1.334}/setup.py +1 -1
- {pycoze-0.1.332 → pycoze-0.1.334}/LICENSE +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/README.md +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/chat.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/text_to_image_prompt.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/think.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/vram_reserve.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/tab.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/view.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/web.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/window.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/message.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/tools.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/bot.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/lib.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/tool.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/workflow.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/base.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/color.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/typ.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/ui_def.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/__init__.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/arg.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/env.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/socket.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/text_or_file.py +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/SOURCES.txt +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/dependency_links.txt +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/top_level.txt +0 -0
- {pycoze-0.1.332 → pycoze-0.1.334}/setup.cfg +0 -0
@@ -17,11 +17,11 @@ async def check_interrupt_file(interval, interrupt_file, chat_task):
|
|
17
17
|
break
|
18
18
|
|
19
19
|
|
20
|
-
async def run_with_interrupt_check(conversation_history, user_input, cwd: str, abilities, bot_setting, interrupt_file):
|
20
|
+
async def run_with_interrupt_check(conversation_history, user_input, cwd: str, abilities, bot_setting, has_any_tool, interrupt_file):
|
21
21
|
clear_chat_data()
|
22
22
|
try:
|
23
23
|
chat_task = asyncio.create_task(
|
24
|
-
handle_user_inputs(conversation_history, user_input, cwd, abilities, bot_setting)
|
24
|
+
handle_user_inputs(conversation_history, user_input, cwd, abilities, bot_setting, has_any_tool)
|
25
25
|
)
|
26
26
|
check_task = asyncio.create_task(
|
27
27
|
check_interrupt_file(0.5, interrupt_file, chat_task)
|
@@ -52,10 +52,11 @@ def chat(bot_setting_file: str):
|
|
52
52
|
bot_setting = json.load(f)
|
53
53
|
abilities = get_abilities(bot_setting)
|
54
54
|
cwd = tempfile.mkdtemp()
|
55
|
+
system_prompt, has_any_tool = get_system_prompt(abilities, bot_setting)
|
55
56
|
conversation_history = [
|
56
57
|
{
|
57
58
|
"role": "system",
|
58
|
-
"content":
|
59
|
+
"content": system_prompt,
|
59
60
|
}
|
60
61
|
]
|
61
62
|
while True:
|
@@ -69,12 +70,12 @@ def chat(bot_setting_file: str):
|
|
69
70
|
if "interruptFile" in params:
|
70
71
|
asyncio.run(
|
71
72
|
run_with_interrupt_check(
|
72
|
-
conversation_history, user_input, cwd, abilities, bot_setting, params["interruptFile"]
|
73
|
+
conversation_history, user_input, cwd, abilities, bot_setting, has_any_tool, params["interruptFile"]
|
73
74
|
)
|
74
75
|
)
|
75
76
|
else:
|
76
77
|
asyncio.run(
|
77
|
-
handle_user_inputs(conversation_history, user_input, cwd, abilities, bot_setting)
|
78
|
+
handle_user_inputs(conversation_history, user_input, cwd, abilities, bot_setting, has_any_tool)
|
78
79
|
)
|
79
80
|
|
80
81
|
output("assistant", CHAT_DATA["info"])
|
@@ -145,7 +145,7 @@ async def stream_openai_response(conversation_history, start_new_stream):
|
|
145
145
|
yield ("text", text_content.strip())
|
146
146
|
|
147
147
|
|
148
|
-
async def handle_user_inputs(conversation_history, user_input, cwd, abilities, bot_setting):
|
148
|
+
async def handle_user_inputs(conversation_history, user_input, cwd, abilities, bot_setting, has_any_tool):
|
149
149
|
no_exit_if_incomplete = bot_setting["systemAbility"]['no_exit_if_incomplete']
|
150
150
|
programmer_mode = bot_setting["systemAbility"]['programmer_mode']
|
151
151
|
|
@@ -174,7 +174,7 @@ async def handle_user_inputs(conversation_history, user_input, cwd, abilities, b
|
|
174
174
|
conversation_history, start_new_stream
|
175
175
|
):
|
176
176
|
if len(response) == 2:
|
177
|
-
if response[0] == "text" and response[1].strip() != "":
|
177
|
+
if response[0] == "text" and response[1].strip() != "" or (response[0] == "json" and not has_any_tool):
|
178
178
|
conversation_history.append(
|
179
179
|
{"role": "assistant", "content": response[1]}
|
180
180
|
)
|
@@ -68,28 +68,38 @@ def get_system_prompt(abilities, bot_setting):
|
|
68
68
|
|
69
69
|
|
70
70
|
abilities_str = "\n".join([function_to_string(a) for a in abilities])
|
71
|
+
|
71
72
|
context = {
|
72
73
|
"prompt": bot_setting["prompt"],
|
73
74
|
"system": system,
|
74
75
|
"cd_prompt": cd_prompt,
|
75
76
|
"abilities_str": abilities_str,
|
76
|
-
"programmer_mode":
|
77
|
-
"no_exit_if_incomplete":
|
78
|
-
"allow_read_file":
|
79
|
-
"allow_read_multiple_files":
|
80
|
-
"allow_execute_command":
|
81
|
-
"allow_write_or_overwrite_file":
|
82
|
-
"allow_replace_part_of_a_file":
|
83
|
-
"allow_search_files":
|
84
|
-
"allow_list_files":
|
85
|
-
"allow_access_webpage":
|
86
|
-
|
77
|
+
"programmer_mode": False,
|
78
|
+
"no_exit_if_incomplete": False,
|
79
|
+
"allow_read_file": False,
|
80
|
+
"allow_read_multiple_files": False,
|
81
|
+
"allow_execute_command": False,
|
82
|
+
"allow_write_or_overwrite_file": False,
|
83
|
+
"allow_replace_part_of_a_file": False,
|
84
|
+
"allow_search_files": False,
|
85
|
+
"allow_list_files": False,
|
86
|
+
"allow_access_webpage": False,
|
87
87
|
}
|
88
88
|
|
89
89
|
context.update(bot_setting["systemAbility"])
|
90
|
+
|
91
|
+
has_any_tool = False
|
92
|
+
if len(abilities) > 0:
|
93
|
+
has_any_tool = True
|
94
|
+
for key in bot_setting["systemAbility"]:
|
95
|
+
if key != "programmer_mode" and bot_setting["systemAbility"][key] == True:
|
96
|
+
has_any_tool = True
|
97
|
+
break
|
98
|
+
|
99
|
+
context["has_any_tool"] = has_any_tool
|
90
100
|
system_prompt = template.render(context)
|
91
101
|
|
92
|
-
return system_prompt
|
102
|
+
return system_prompt, has_any_tool
|
93
103
|
|
94
104
|
|
95
105
|
def resolve_relative_path(cwd:str, path_str: str) -> str:
|
@@ -1,5 +1,6 @@
|
|
1
1
|
{{ prompt }}
|
2
2
|
|
3
|
+
{% if has_any_tool %}
|
3
4
|
==== Tool Usage
|
4
5
|
You have access to a set of tools running on the {{ system }} system that are executed upon user approval. Only one tool can be used per message, and you will receive the result of the tool's execution in the user's response. You progressively use these tools to accomplish tasks, with each tool's usage being based on the outcome of the previous tool.
|
5
6
|
|
@@ -17,6 +18,7 @@ Here's the translation in English:
|
|
17
18
|
}
|
18
19
|
}
|
19
20
|
```
|
21
|
+
{% endif %}
|
20
22
|
|
21
23
|
{% if allow_read_file %}
|
22
24
|
For example:
|
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
|
File without changes
|
File without changes
|