jarvis-ai-assistant 0.1.63__py3-none-any.whl → 0.1.74__py3-none-any.whl
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.
Potentially problematic release.
This version of jarvis-ai-assistant might be problematic. Click here for more details.
- jarvis/__init__.py +1 -1
- jarvis/agent.py +29 -22
- jarvis/jarvis_codebase/__init__.py +0 -0
- jarvis/jarvis_codebase/main.py +636 -0
- jarvis/jarvis_coder/__init__.py +0 -0
- jarvis/jarvis_coder/main.py +122 -382
- jarvis/main.py +0 -2
- jarvis/models/ai8.py +1 -2
- jarvis/models/openai.py +0 -1
- jarvis/models/oyi.py +1 -4
- jarvis/models/registry.py +1 -1
- jarvis/tools/__init__.py +1 -0
- jarvis/tools/codebase_qa.py +74 -0
- jarvis/tools/registry.py +1 -1
- jarvis/utils.py +8 -1
- {jarvis_ai_assistant-0.1.63.dist-info → jarvis_ai_assistant-0.1.74.dist-info}/METADATA +38 -3
- jarvis_ai_assistant-0.1.74.dist-info/RECORD +33 -0
- {jarvis_ai_assistant-0.1.63.dist-info → jarvis_ai_assistant-0.1.74.dist-info}/entry_points.txt +1 -0
- jarvis_ai_assistant-0.1.63.dist-info/RECORD +0 -29
- {jarvis_ai_assistant-0.1.63.dist-info → jarvis_ai_assistant-0.1.74.dist-info}/LICENSE +0 -0
- {jarvis_ai_assistant-0.1.63.dist-info → jarvis_ai_assistant-0.1.74.dist-info}/WHEEL +0 -0
- {jarvis_ai_assistant-0.1.63.dist-info → jarvis_ai_assistant-0.1.74.dist-info}/top_level.txt +0 -0
jarvis/__init__.py
CHANGED
jarvis/agent.py
CHANGED
|
@@ -142,20 +142,6 @@ class Agent:
|
|
|
142
142
|
except Exception as e:
|
|
143
143
|
PrettyOutput.print(f"总结对话历史失败: {str(e)}", OutputType.ERROR)
|
|
144
144
|
|
|
145
|
-
|
|
146
|
-
def _choose_methodology(self, methodology: Dict[str, str], task: str) -> str:
|
|
147
|
-
"""选择方法论"""
|
|
148
|
-
prompt = f"""请根据任务内容选择合适的方法论,并返回方法论内容,格式如下:
|
|
149
|
-
任务内容:
|
|
150
|
-
{task}
|
|
151
|
-
|
|
152
|
-
方法论:
|
|
153
|
-
"""
|
|
154
|
-
for k, v in methodology.items():
|
|
155
|
-
prompt += f"问题类型:{k}\n"
|
|
156
|
-
prompt += f"方法论:{v}\n"
|
|
157
|
-
return self._call_model(prompt)
|
|
158
|
-
|
|
159
145
|
def _complete_task(self) -> str:
|
|
160
146
|
"""完成任务并生成总结
|
|
161
147
|
|
|
@@ -164,6 +150,34 @@ class Agent:
|
|
|
164
150
|
"""
|
|
165
151
|
PrettyOutput.section("任务完成", OutputType.SUCCESS)
|
|
166
152
|
|
|
153
|
+
# 询问是否生成方法论,带输入验证
|
|
154
|
+
while True:
|
|
155
|
+
user_input = input("是否要为此任务生成方法论?(y/n): ").strip().lower()
|
|
156
|
+
if user_input in ['y', 'n', '']:
|
|
157
|
+
break
|
|
158
|
+
PrettyOutput.print("无效输入,请输入 y 或 n", OutputType.WARNING)
|
|
159
|
+
|
|
160
|
+
if user_input == 'y':
|
|
161
|
+
try:
|
|
162
|
+
# 让模型判断是否需要生成方法论
|
|
163
|
+
analysis_prompt = """本次任务已结束,请分析是否需要生成方法论。
|
|
164
|
+
如果认为需要生成方法论,请先判断是创建新的方法论还是更新已有方法论。如果是更新已有方法论,使用update,否则使用add。
|
|
165
|
+
如果认为不需要生成方法论,请说明原因。
|
|
166
|
+
仅输出方法论工具的调用指令,或者是不需要生成方法论的说明,除此之外不要输出任何内容。
|
|
167
|
+
"""
|
|
168
|
+
self.prompt = analysis_prompt
|
|
169
|
+
response = self._call_model(self.prompt)
|
|
170
|
+
|
|
171
|
+
# 检查是否包含工具调用
|
|
172
|
+
try:
|
|
173
|
+
result = Agent.extract_tool_calls(response)
|
|
174
|
+
PrettyOutput.print(result, OutputType.RESULT)
|
|
175
|
+
except Exception as e:
|
|
176
|
+
PrettyOutput.print(f"处理方法论生成失败: {str(e)}", OutputType.ERROR)
|
|
177
|
+
|
|
178
|
+
except Exception as e:
|
|
179
|
+
PrettyOutput.print(f"生成方法论时发生错误: {str(e)}", OutputType.ERROR)
|
|
180
|
+
|
|
167
181
|
if not self.is_sub_agent:
|
|
168
182
|
return "Task completed"
|
|
169
183
|
|
|
@@ -198,9 +212,6 @@ class Agent:
|
|
|
198
212
|
|
|
199
213
|
# 加载方法论
|
|
200
214
|
methodology = self._load_methodology()
|
|
201
|
-
|
|
202
|
-
methodology =self._choose_methodology(methodology, user_input)
|
|
203
|
-
|
|
204
215
|
methodology_prompt = ""
|
|
205
216
|
if methodology:
|
|
206
217
|
methodology_prompt = f"""这是以往处理问题的标准方法论,如果当前任务与此类似,可参考:
|
|
@@ -266,12 +277,12 @@ arguments:
|
|
|
266
277
|
6. 处理问题的每个步骤不是必须有的,可按情况省略
|
|
267
278
|
7. 在执行一些可能对系统或者用户代码库造成破坏的工具时,请先询问用户
|
|
268
279
|
8. 在多次迭代却没有任何进展时,可请求用户指导
|
|
280
|
+
9. 如果返回的yaml字符串中包含冒号,请将整个字符串用引号包裹,避免yaml解析错误
|
|
269
281
|
|
|
270
282
|
-------------------------------------------------------------
|
|
271
283
|
|
|
272
284
|
特殊指令:
|
|
273
285
|
1. !<<SUMMARIZE>>! - 当你发现对话历史过长可能导致token超限时,可以使用此指令总结当前对话要点并清空历史。使用方法:直接回复"!<<SUMMARIZE>>!"即可。
|
|
274
|
-
2. !<<FINISHED>>! - 当你确认任务已经完成时,使用此指令结束任务。使用方法:在回复中包含"!<<FINISHED>>!"即可。
|
|
275
286
|
|
|
276
287
|
-------------------------------------------------------------
|
|
277
288
|
|
|
@@ -316,10 +327,6 @@ arguments:
|
|
|
316
327
|
self.prompt = tool_result
|
|
317
328
|
continue
|
|
318
329
|
|
|
319
|
-
# 检查是否完成任务
|
|
320
|
-
if "!<<FINISHED>>!" in current_response:
|
|
321
|
-
return self._complete_task()
|
|
322
|
-
|
|
323
330
|
# 获取用户输入
|
|
324
331
|
user_input = get_multiline_input(f"{self.name}: 您可以继续输入,或输入空行结束当前任务")
|
|
325
332
|
if user_input == "__interrupt__":
|
|
File without changes
|