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.
Files changed (44) hide show
  1. {pycoze-0.1.332 → pycoze-0.1.334}/PKG-INFO +1 -1
  2. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/chat.py +6 -5
  3. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/chat_base.py +2 -2
  4. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/lib.py +22 -12
  5. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/prompt.md +2 -0
  6. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/PKG-INFO +1 -1
  7. {pycoze-0.1.332 → pycoze-0.1.334}/setup.py +1 -1
  8. {pycoze-0.1.332 → pycoze-0.1.334}/LICENSE +0 -0
  9. {pycoze-0.1.332 → pycoze-0.1.334}/README.md +0 -0
  10. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/__init__.py +0 -0
  11. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/__init__.py +0 -0
  12. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/__init__.py +0 -0
  13. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/chat.py +0 -0
  14. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/text_to_image_prompt.py +0 -0
  15. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/llm/think.py +0 -0
  16. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ai/vram_reserve.py +0 -0
  17. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/__init__.py +0 -0
  18. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/__init__.py +0 -0
  19. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/tab.py +0 -0
  20. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/view.py +0 -0
  21. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/web.py +0 -0
  22. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/api/lib/window.py +0 -0
  23. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/__init__.py +0 -0
  24. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/message.py +0 -0
  25. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/bot/tools.py +0 -0
  26. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/__init__.py +0 -0
  27. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/bot.py +0 -0
  28. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/lib.py +0 -0
  29. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/tool.py +0 -0
  30. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/reference/workflow.py +0 -0
  31. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/__init__.py +0 -0
  32. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/base.py +0 -0
  33. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/color.py +0 -0
  34. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/typ.py +0 -0
  35. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/ui/ui_def.py +0 -0
  36. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/__init__.py +0 -0
  37. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/arg.py +0 -0
  38. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/env.py +0 -0
  39. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/socket.py +0 -0
  40. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze/utils/text_or_file.py +0 -0
  41. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/SOURCES.txt +0 -0
  42. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/dependency_links.txt +0 -0
  43. {pycoze-0.1.332 → pycoze-0.1.334}/pycoze.egg-info/top_level.txt +0 -0
  44. {pycoze-0.1.332 → pycoze-0.1.334}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: pycoze
3
- Version: 0.1.332
3
+ Version: 0.1.334
4
4
  Summary: Package for pycoze only!
5
5
  Author: Yuan Jie Xiong
6
6
  Author-email: aiqqqqqqq@qq.com
@@ -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": get_system_prompt(abilities, bot_setting),
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": True,
77
- "no_exit_if_incomplete": True,
78
- "allow_read_file": True,
79
- "allow_read_multiple_files": True,
80
- "allow_execute_command": True,
81
- "allow_write_or_overwrite_file": True,
82
- "allow_replace_part_of_a_file": True,
83
- "allow_search_files": True,
84
- "allow_list_files": True,
85
- "allow_access_webpage": True,
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:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: pycoze
3
- Version: 0.1.332
3
+ Version: 0.1.334
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.332",
5
+ version="0.1.334",
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
File without changes
File without changes
File without changes
File without changes
File without changes