jarvis-ai-assistant 0.3.3__tar.gz → 0.3.5__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.
- {jarvis_ai_assistant-0.3.3/src/jarvis_ai_assistant.egg-info → jarvis_ai_assistant-0.3.5}/PKG-INFO +1 -1
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/pyproject.toml +7 -4
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/setup.py +1 -1
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/__init__.py +1 -1
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/__init__.py +164 -3
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/file_methodology_manager.py +6 -1
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/tool_executor.py +8 -4
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/code_agent.py +1 -8
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_memory_organizer/memory_organizer.py +44 -12
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/base.py +3 -14
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/base.py +8 -1
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/git_utils.py +20 -3
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/methodology.py +19 -2
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/utils.py +110 -49
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5/src/jarvis_ai_assistant.egg-info}/PKG-INFO +1 -1
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/LICENSE +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/MANIFEST.in +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/README.md +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/setup.cfg +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/agent_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/builtin_input_handler.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/config_editor.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/edit_file_handler.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/jarvis.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/memory_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/methodology_share_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/output_handler.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/prompt_builder.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/prompts.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/protocols.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/session_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/share_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/shell_input_handler.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/task_analyzer.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/task_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/tool_share_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/lint.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/c_cpp.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/csharp.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/data_format.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/devops.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/docs.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/go.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/infrastructure.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/java.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/javascript.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/kotlin.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/loader.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/php.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/python.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/ruby.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/rust.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/shell.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/sql.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/swift.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/web.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/code_review.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_data/config_schema.json +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_data/tiktoken/9b5ad71b2ce5302211f9c61530b329a4922fc6a4 +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_git_squash/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_git_squash/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_git_utils/git_commiter.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/sse_mcp_client.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/stdio_mcp_client.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/streamable_mcp_client.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_memory_organizer/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_methodology/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_multi_agent/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_multi_agent/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/ai8.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/human.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/kimi.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/openai.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/registry.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/tongyi.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/yuanbao.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform_manager/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform_manager/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform_manager/service.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/cache.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/cli.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/embedding_manager.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/llm_interface.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/query_rewriter.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/rag_pipeline.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/reranker.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/retriever.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_smart_shell/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_smart_shell/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/cli.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/stats.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/storage.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/visualizer.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/ask_user.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/clear_memory.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/cli/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/cli/main.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/edit_file.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/execute_script.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/file_analyzer.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/generate_new_tool.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/methodology.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/read_code.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/read_webpage.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/registry.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/retrieve_memory.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/rewrite_file.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/save_memory.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/search_web.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/virtual_tty.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/__init__.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/builtin_replace_map.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/clipboard.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/config.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/embedding.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/file_processors.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/globals.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/http.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/input.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/output.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/tag.py +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/SOURCES.txt +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/dependency_links.txt +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/entry_points.txt +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/requires.txt +0 -0
- {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/top_level.txt +0 -0
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
|
|
4
4
|
|
5
5
|
[project]
|
6
6
|
name = "jarvis-ai-assistant"
|
7
|
-
version = "0.3.
|
7
|
+
version = "0.3.5"
|
8
8
|
description = "Jarvis: An AI assistant that uses tools to interact with the system"
|
9
9
|
readme = "README.md"
|
10
10
|
authors = [{ name = "skyfire", email = "skyfireitdiy@hotmail.com" }]
|
@@ -101,9 +101,8 @@ jst = "jarvis.jarvis_stats.cli:main"
|
|
101
101
|
|
102
102
|
|
103
103
|
|
104
|
-
[
|
105
|
-
|
106
|
-
url = "https://pypi.tuna.tsinghua.edu.cn/simple"
|
104
|
+
[tool.uv]
|
105
|
+
index-strategy = "unsafe-first-match"
|
107
106
|
|
108
107
|
[[tool.uv.index]]
|
109
108
|
name = "aliyun"
|
@@ -112,3 +111,7 @@ url = "https://mirrors.aliyun.com/pypi/simple/"
|
|
112
111
|
[[tool.uv.index]]
|
113
112
|
name = "ustc"
|
114
113
|
url = "https://pypi.mirrors.ustc.edu.cn/simple/"
|
114
|
+
|
115
|
+
[[tool.uv.index]]
|
116
|
+
name = "netease"
|
117
|
+
url = "https://mirrors.163.com/pypi/simple/"
|
@@ -3,7 +3,7 @@ from setuptools import setup, find_packages # type: ignore
|
|
3
3
|
|
4
4
|
setup(
|
5
5
|
name="jarvis-ai-assistant",
|
6
|
-
version="0.3.
|
6
|
+
version="0.3.5",
|
7
7
|
author="skyfire",
|
8
8
|
author_email="skyfireitdiy@hotmail.com",
|
9
9
|
description="An AI assistant that uses various tools to interact with the system",
|
@@ -3,6 +3,7 @@
|
|
3
3
|
import datetime
|
4
4
|
import os
|
5
5
|
import platform
|
6
|
+
from pathlib import Path
|
6
7
|
from typing import Any, Callable, Dict, List, Optional, Protocol, Tuple, Union
|
7
8
|
|
8
9
|
# 第三方库导入
|
@@ -14,6 +15,7 @@ from jarvis.jarvis_agent.protocols import OutputHandlerProtocol
|
|
14
15
|
from jarvis.jarvis_agent.session_manager import SessionManager
|
15
16
|
from jarvis.jarvis_agent.tool_executor import execute_tool_call
|
16
17
|
from jarvis.jarvis_agent.memory_manager import MemoryManager
|
18
|
+
from jarvis.jarvis_memory_organizer.memory_organizer import MemoryOrganizer
|
17
19
|
from jarvis.jarvis_agent.task_analyzer import TaskAnalyzer
|
18
20
|
from jarvis.jarvis_agent.file_methodology_manager import FileMethodologyManager
|
19
21
|
from jarvis.jarvis_agent.prompts import (
|
@@ -28,6 +30,7 @@ from jarvis.jarvis_platform.registry import PlatformRegistry
|
|
28
30
|
|
29
31
|
# jarvis_utils 相关
|
30
32
|
from jarvis.jarvis_utils.config import (
|
33
|
+
get_data_dir,
|
31
34
|
get_max_token_count,
|
32
35
|
get_normal_model_name,
|
33
36
|
get_normal_platform_name,
|
@@ -50,6 +53,98 @@ from jarvis.jarvis_utils.input import get_multiline_input, user_confirm
|
|
50
53
|
from jarvis.jarvis_utils.output import OutputType, PrettyOutput
|
51
54
|
from jarvis.jarvis_utils.tag import ct, ot
|
52
55
|
|
56
|
+
|
57
|
+
def show_agent_startup_stats(agent_name: str, model_name: str) -> None:
|
58
|
+
"""输出启动时的统计信息
|
59
|
+
|
60
|
+
参数:
|
61
|
+
agent_name: Agent的名称
|
62
|
+
model_name: 使用的模型名称
|
63
|
+
"""
|
64
|
+
try:
|
65
|
+
from jarvis.jarvis_utils.methodology import _load_all_methodologies
|
66
|
+
from jarvis.jarvis_tools.registry import ToolRegistry
|
67
|
+
from jarvis.jarvis_utils.config import get_data_dir
|
68
|
+
from pathlib import Path
|
69
|
+
from rich.console import Console
|
70
|
+
from rich.panel import Panel
|
71
|
+
from rich.text import Text
|
72
|
+
from rich.align import Align
|
73
|
+
import os
|
74
|
+
|
75
|
+
methodologies = _load_all_methodologies()
|
76
|
+
methodology_count = len(methodologies)
|
77
|
+
|
78
|
+
# 获取工具数量
|
79
|
+
# 创建一个临时的工具注册表类来获取所有工具(不应用过滤)
|
80
|
+
class TempToolRegistry(ToolRegistry):
|
81
|
+
def _apply_tool_config_filter(self) -> None:
|
82
|
+
"""重写过滤方法,不执行任何过滤"""
|
83
|
+
pass
|
84
|
+
|
85
|
+
# 获取所有工具的数量
|
86
|
+
tool_registry_all = TempToolRegistry()
|
87
|
+
total_tool_count = len(tool_registry_all.tools)
|
88
|
+
|
89
|
+
# 获取可用工具的数量(应用过滤)
|
90
|
+
tool_registry = ToolRegistry()
|
91
|
+
available_tool_count = len(tool_registry.get_all_tools())
|
92
|
+
|
93
|
+
global_memory_dir = Path(get_data_dir()) / "memory" / "global_long_term"
|
94
|
+
global_memory_count = 0
|
95
|
+
if global_memory_dir.exists():
|
96
|
+
global_memory_count = len(list(global_memory_dir.glob("*.json")))
|
97
|
+
|
98
|
+
# 检查项目记忆
|
99
|
+
project_memory_dir = Path(".jarvis/memory")
|
100
|
+
project_memory_count = 0
|
101
|
+
if project_memory_dir.exists():
|
102
|
+
project_memory_count = len(list(project_memory_dir.glob("*.json")))
|
103
|
+
|
104
|
+
# 获取当前工作目录
|
105
|
+
current_dir = os.getcwd()
|
106
|
+
|
107
|
+
# 构建欢迎信息
|
108
|
+
welcome_message = f"{agent_name} 初始化完成 - 使用 {model_name} 模型"
|
109
|
+
|
110
|
+
stats_parts = [
|
111
|
+
f"📚 本地方法论: [bold cyan]{methodology_count}[/bold cyan]",
|
112
|
+
f"🛠️ 工具: [bold green]{available_tool_count}/{total_tool_count}[/bold green] (可用/全部)",
|
113
|
+
f"🧠 全局记忆: [bold yellow]{global_memory_count}[/bold yellow]",
|
114
|
+
]
|
115
|
+
|
116
|
+
# 如果有项目记忆,添加到统计信息中
|
117
|
+
if project_memory_count > 0:
|
118
|
+
stats_parts.append(
|
119
|
+
f"📝 项目记忆: [bold magenta]{project_memory_count}[/bold magenta]"
|
120
|
+
)
|
121
|
+
|
122
|
+
stats_text = Text.from_markup(" | ".join(stats_parts), justify="center")
|
123
|
+
|
124
|
+
# 创建包含欢迎信息和统计信息的面板内容
|
125
|
+
panel_content = Text()
|
126
|
+
panel_content.append(welcome_message, style="bold white")
|
127
|
+
panel_content.append("\n")
|
128
|
+
panel_content.append(f"📁 工作目录: {current_dir}", style="dim white")
|
129
|
+
panel_content.append("\n\n")
|
130
|
+
panel_content.append(stats_text)
|
131
|
+
panel_content.justify = "center"
|
132
|
+
|
133
|
+
panel = Panel(
|
134
|
+
panel_content,
|
135
|
+
title="✨ Jarvis 资源概览 ✨",
|
136
|
+
title_align="center",
|
137
|
+
border_style="blue",
|
138
|
+
expand=False,
|
139
|
+
)
|
140
|
+
|
141
|
+
console = Console()
|
142
|
+
console.print(Align.center(panel))
|
143
|
+
|
144
|
+
except Exception as e:
|
145
|
+
PrettyOutput.print(f"加载统计信息失败: {e}", OutputType.WARNING)
|
146
|
+
|
147
|
+
|
53
148
|
origin_agent_system_prompt = f"""
|
54
149
|
<role>
|
55
150
|
# 🤖 角色
|
@@ -175,9 +270,8 @@ class Agent:
|
|
175
270
|
# 设置系统提示词
|
176
271
|
self._setup_system_prompt()
|
177
272
|
|
178
|
-
#
|
179
|
-
|
180
|
-
PrettyOutput.print(welcome_message, OutputType.SYSTEM)
|
273
|
+
# 输出统计信息(包含欢迎信息)
|
274
|
+
show_agent_startup_stats(name, self.model.name()) # type: ignore
|
181
275
|
|
182
276
|
def _init_model(self, llm_type: str, model_group: Optional[str]):
|
183
277
|
"""初始化模型平台"""
|
@@ -515,6 +609,8 @@ class Agent:
|
|
515
609
|
if self.use_analysis:
|
516
610
|
self.task_analyzer.analysis_task(satisfaction_feedback)
|
517
611
|
|
612
|
+
self._check_and_organize_memory()
|
613
|
+
|
518
614
|
if self.need_summary:
|
519
615
|
print("📄 正在生成总结...")
|
520
616
|
self.session.prompt = self.summary_prompt
|
@@ -711,6 +807,71 @@ class Agent:
|
|
711
807
|
|
712
808
|
self.first = False
|
713
809
|
|
810
|
+
def _check_and_organize_memory(self):
|
811
|
+
"""
|
812
|
+
检查记忆库状态,如果满足条件则提示用户整理。
|
813
|
+
每天只检测一次。
|
814
|
+
"""
|
815
|
+
try:
|
816
|
+
# 检查项目记忆
|
817
|
+
self._perform_memory_check("project_long_term", Path(".jarvis"), "project")
|
818
|
+
# 检查全局记忆
|
819
|
+
self._perform_memory_check(
|
820
|
+
"global_long_term",
|
821
|
+
Path(get_data_dir()),
|
822
|
+
"global",
|
823
|
+
)
|
824
|
+
except Exception as e:
|
825
|
+
PrettyOutput.print(f"检查记忆库时发生意外错误: {e}", OutputType.WARNING)
|
826
|
+
|
827
|
+
def _perform_memory_check(self, memory_type: str, base_path: Path, scope_name: str):
|
828
|
+
"""执行特定范围的记忆检查和整理"""
|
829
|
+
check_file = base_path / ".last_memory_organizer_check"
|
830
|
+
now = datetime.datetime.now()
|
831
|
+
|
832
|
+
if check_file.exists():
|
833
|
+
try:
|
834
|
+
last_check_time = datetime.datetime.fromisoformat(
|
835
|
+
check_file.read_text()
|
836
|
+
)
|
837
|
+
if (now - last_check_time).total_seconds() < 24 * 3600:
|
838
|
+
return # 24小时内已检查
|
839
|
+
except (ValueError, FileNotFoundError):
|
840
|
+
# 文件内容无效或文件在读取时被删除,继续执行检查
|
841
|
+
pass
|
842
|
+
|
843
|
+
# 立即更新检查时间,防止并发或重复检查
|
844
|
+
base_path.mkdir(parents=True, exist_ok=True)
|
845
|
+
check_file.write_text(now.isoformat())
|
846
|
+
|
847
|
+
organizer = MemoryOrganizer()
|
848
|
+
# NOTE: 使用受保护方法以避免重复实现逻辑
|
849
|
+
memories = organizer._load_memories(memory_type)
|
850
|
+
|
851
|
+
if len(memories) < 200:
|
852
|
+
return
|
853
|
+
|
854
|
+
# NOTE: 使用受保护方法以避免重复实现逻辑
|
855
|
+
overlap_groups = organizer._find_overlapping_memories(memories, min_overlap=3)
|
856
|
+
has_significant_overlap = any(groups for groups in overlap_groups.values())
|
857
|
+
|
858
|
+
if not has_significant_overlap:
|
859
|
+
return
|
860
|
+
|
861
|
+
prompt = (
|
862
|
+
f"检测到您的 '{scope_name}' 记忆库中包含 {len(memories)} 条记忆,"
|
863
|
+
f"并且存在3个以上标签重叠的记忆。\n"
|
864
|
+
f"是否立即整理记忆库以优化性能和相关性?"
|
865
|
+
)
|
866
|
+
if user_confirm(prompt, default=True):
|
867
|
+
PrettyOutput.print(
|
868
|
+
f"正在开始整理 '{scope_name}' ({memory_type}) 记忆库...",
|
869
|
+
OutputType.INFO,
|
870
|
+
)
|
871
|
+
organizer.organize_memories(memory_type, min_overlap=3)
|
872
|
+
else:
|
873
|
+
PrettyOutput.print(f"已取消 '{scope_name}' 记忆库整理。", OutputType.INFO)
|
874
|
+
|
714
875
|
def clear_history(self):
|
715
876
|
"""
|
716
877
|
Clears conversation history by delegating to the session manager.
|
@@ -80,7 +80,12 @@ class FileMethodologyManager:
|
|
80
80
|
|
81
81
|
memory_manager = MemoryManager(self.agent)
|
82
82
|
memory_tags_prompt = memory_manager.prepare_memory_tags_prompt()
|
83
|
-
methodology = load_methodology(
|
83
|
+
methodology = load_methodology(
|
84
|
+
msg,
|
85
|
+
self.agent.get_tool_registry(),
|
86
|
+
platform_name=self.agent.model.platform_name(),
|
87
|
+
model_name=self.agent.model.name(),
|
88
|
+
)
|
84
89
|
self.agent.session.prompt = f"{self.agent.session.prompt}\n\n以下是历史类似问题的执行经验,可参考:\n{methodology}{memory_tags_prompt}"
|
85
90
|
|
86
91
|
def handle_history_with_file_upload(self) -> str:
|
{jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/tool_executor.py
RENAMED
@@ -41,9 +41,13 @@ def execute_tool_call(response: str, agent: "Agent") -> Tuple[bool, Any]:
|
|
41
41
|
if not agent.execute_tool_confirm or user_confirm(
|
42
42
|
f"需要执行{tool_to_execute.name()}确认执行?", True
|
43
43
|
):
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
44
|
+
try:
|
45
|
+
print(f"🔧 正在执行{tool_to_execute.name()}...")
|
46
|
+
result = tool_to_execute.handle(response, agent)
|
47
|
+
print(f"✅ {tool_to_execute.name()}执行完成")
|
48
|
+
return result
|
49
|
+
except Exception as e:
|
50
|
+
PrettyOutput.print(f"工具执行失败: {str(e)}", OutputType.ERROR)
|
51
|
+
return False, str(e)
|
48
52
|
|
49
53
|
return False, ""
|
{jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/code_agent.py
RENAMED
@@ -398,11 +398,6 @@ class CodeAgent:
|
|
398
398
|
if not user_confirm("是否要提交?", True):
|
399
399
|
return
|
400
400
|
|
401
|
-
# 用户确认修改,统计修改次数
|
402
|
-
from jarvis.jarvis_stats.stats import StatsManager
|
403
|
-
|
404
|
-
StatsManager.increment("code_modification_confirmed", group="code_agent")
|
405
|
-
|
406
401
|
try:
|
407
402
|
confirm_add_new_files()
|
408
403
|
|
@@ -697,9 +692,7 @@ def cli(
|
|
697
692
|
sys.exit(0)
|
698
693
|
|
699
694
|
curr_dir = os.getcwd()
|
700
|
-
|
701
|
-
PrettyOutput.print(f"当前目录: {git_dir}", OutputType.INFO)
|
702
|
-
|
695
|
+
find_git_root_and_cd(curr_dir)
|
703
696
|
try:
|
704
697
|
agent = CodeAgent(
|
705
698
|
llm_type=llm_type,
|
@@ -278,8 +278,23 @@ tags:
|
|
278
278
|
# 从高重叠度开始处理
|
279
279
|
max_tags = max(len(m.get("tags", [])) for m in memories)
|
280
280
|
|
281
|
+
# 创建一个标记已删除记忆的集合
|
282
|
+
deleted_indices = set()
|
283
|
+
|
281
284
|
for overlap_count in range(min(max_tags, 5), min_overlap - 1, -1):
|
282
|
-
|
285
|
+
# 过滤掉已删除的记忆
|
286
|
+
active_memories = [
|
287
|
+
(i, mem) for i, mem in enumerate(memories) if i not in deleted_indices
|
288
|
+
]
|
289
|
+
if not active_memories:
|
290
|
+
break
|
291
|
+
|
292
|
+
# 创建索引映射:原始索引 -> 活跃索引
|
293
|
+
active_memory_list = [mem for _, mem in active_memories]
|
294
|
+
|
295
|
+
overlap_groups = self._find_overlapping_memories(
|
296
|
+
active_memory_list, overlap_count
|
297
|
+
)
|
283
298
|
|
284
299
|
if overlap_count in overlap_groups:
|
285
300
|
groups = overlap_groups[overlap_count]
|
@@ -289,7 +304,13 @@ tags:
|
|
289
304
|
)
|
290
305
|
|
291
306
|
for group in groups:
|
292
|
-
|
307
|
+
# 将活跃索引转换回原始索引
|
308
|
+
original_indices = set()
|
309
|
+
for active_idx in group:
|
310
|
+
original_idx = active_memories[active_idx][0]
|
311
|
+
original_indices.add(original_idx)
|
312
|
+
|
313
|
+
group_memories = [memories[i] for i in original_indices]
|
293
314
|
|
294
315
|
# 显示将要合并的记忆
|
295
316
|
PrettyOutput.print(
|
@@ -315,16 +336,17 @@ tags:
|
|
315
336
|
|
316
337
|
# 保存新记忆
|
317
338
|
self._save_merged_memory(
|
318
|
-
merged_memory,
|
339
|
+
merged_memory,
|
340
|
+
memory_type,
|
341
|
+
[memories[i] for i in original_indices],
|
319
342
|
)
|
320
343
|
|
321
344
|
stats["processed_groups"] += 1
|
322
|
-
stats["merged_memories"] += len(
|
345
|
+
stats["merged_memories"] += len(original_indices)
|
323
346
|
stats["created_memories"] += 1
|
324
347
|
|
325
|
-
#
|
326
|
-
|
327
|
-
del memories[i]
|
348
|
+
# 标记这些记忆已被删除
|
349
|
+
deleted_indices.update(original_indices)
|
328
350
|
else:
|
329
351
|
PrettyOutput.print(" [模拟运行] 跳过实际合并", OutputType.INFO)
|
330
352
|
|
@@ -376,11 +398,18 @@ tags:
|
|
376
398
|
for orig_memory in original_memories:
|
377
399
|
if "file_path" in orig_memory:
|
378
400
|
try:
|
379
|
-
Path(orig_memory["file_path"])
|
380
|
-
|
381
|
-
|
382
|
-
|
383
|
-
|
401
|
+
file_path = Path(orig_memory["file_path"])
|
402
|
+
if file_path.exists():
|
403
|
+
file_path.unlink()
|
404
|
+
PrettyOutput.print(
|
405
|
+
f"删除原始记忆: {orig_memory.get('id', '未知')}",
|
406
|
+
OutputType.INFO,
|
407
|
+
)
|
408
|
+
else:
|
409
|
+
PrettyOutput.print(
|
410
|
+
f"原始记忆文件已不存在,跳过删除: {orig_memory.get('id', '未知')}",
|
411
|
+
OutputType.INFO,
|
412
|
+
)
|
384
413
|
except Exception as e:
|
385
414
|
PrettyOutput.print(
|
386
415
|
f"删除记忆文件失败 {orig_memory['file_path']}: {str(e)}",
|
@@ -607,6 +636,9 @@ def organize(
|
|
607
636
|
else:
|
608
637
|
raise typer.Exit(0) # 即使没有处理也是正常退出
|
609
638
|
|
639
|
+
except typer.Exit:
|
640
|
+
# typer.Exit 是正常的退出方式,直接传播
|
641
|
+
raise
|
610
642
|
except Exception as e:
|
611
643
|
PrettyOutput.print(f"记忆整理失败: {str(e)}", OutputType.ERROR)
|
612
644
|
raise typer.Exit(1)
|
@@ -142,20 +142,9 @@ class BasePlatform(ABC):
|
|
142
142
|
live.update(panel)
|
143
143
|
end_time = time.time()
|
144
144
|
duration = end_time - start_time
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
token_count = get_context_token_count(response)
|
149
|
-
tokens_per_second = (
|
150
|
-
token_count / duration if duration > 0 else 0
|
151
|
-
)
|
152
|
-
except Exception as e:
|
153
|
-
PrettyOutput.print(
|
154
|
-
f"Tokenization failed: {str(e)}", OutputType.WARNING
|
155
|
-
)
|
156
|
-
token_count = 0
|
157
|
-
tokens_per_second = 0
|
158
|
-
panel.subtitle = f"[bold green]✓ 对话完成耗时: {duration:.2f}秒, 输入字符数: {len(message)}, 输入Token数量: {input_token_count}, 输出字符数: {char_count}, 输出Token数量: {token_count}, 每秒Token数量: {tokens_per_second:.2f}[/bold green]"
|
145
|
+
panel.subtitle = (
|
146
|
+
f"[bold green]✓ 对话完成耗时: {duration:.2f}秒[/bold green]"
|
147
|
+
)
|
159
148
|
live.update(panel)
|
160
149
|
else:
|
161
150
|
for s in self.chat(message):
|
{jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/git_utils.py
RENAMED
@@ -309,7 +309,9 @@ def get_modified_line_ranges() -> Dict[str, List[Tuple[int, int]]]:
|
|
309
309
|
start_line = int(range_match.group(1)) # 保持从1开始
|
310
310
|
line_count = int(range_match.group(2)) if range_match.group(2) else 1
|
311
311
|
end_line = start_line + line_count - 1
|
312
|
-
|
312
|
+
if current_file not in result:
|
313
|
+
result[current_file] = []
|
314
|
+
result[current_file].append((start_line, end_line))
|
313
315
|
|
314
316
|
return result
|
315
317
|
|
@@ -414,8 +416,23 @@ def check_and_update_git_repo(repo_path: str) -> bool:
|
|
414
416
|
hasattr(sys, "base_prefix") and sys.base_prefix != sys.prefix
|
415
417
|
)
|
416
418
|
|
417
|
-
|
418
|
-
|
419
|
+
is_uv_env = False
|
420
|
+
if in_venv:
|
421
|
+
# 检查是否在uv创建的虚拟环境内
|
422
|
+
if sys.platform == "win32":
|
423
|
+
uv_path = os.path.join(sys.prefix, "Scripts", "uv.exe")
|
424
|
+
else:
|
425
|
+
uv_path = os.path.join(sys.prefix, "bin", "uv")
|
426
|
+
if os.path.exists(uv_path):
|
427
|
+
is_uv_env = True
|
428
|
+
|
429
|
+
# 根据环境选择安装命令
|
430
|
+
if is_uv_env:
|
431
|
+
install_cmd = ["uv", "pip", "install", "-e", "."]
|
432
|
+
else:
|
433
|
+
install_cmd = [sys.executable, "-m", "pip", "install", "-e", "."]
|
434
|
+
|
435
|
+
# 尝试安装
|
419
436
|
result = subprocess.run(
|
420
437
|
install_cmd, cwd=git_root, capture_output=True, text=True
|
421
438
|
)
|
{jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/methodology.py
RENAMED
@@ -175,13 +175,20 @@ def upload_methodology(platform: BasePlatform, other_files: List[str] = []) -> b
|
|
175
175
|
pass
|
176
176
|
|
177
177
|
|
178
|
-
def load_methodology(
|
178
|
+
def load_methodology(
|
179
|
+
user_input: str,
|
180
|
+
tool_registery: Optional[Any] = None,
|
181
|
+
platform_name: Optional[str] = None,
|
182
|
+
model_name: Optional[str] = None,
|
183
|
+
) -> str:
|
179
184
|
"""
|
180
185
|
加载方法论并上传到大模型。
|
181
186
|
|
182
187
|
参数:
|
183
188
|
user_input: 用户输入文本,用于提示大模型
|
184
189
|
tool_registery: 工具注册表,用于获取工具列表
|
190
|
+
platform_name (str, optional): 指定的平台名称. Defaults to None.
|
191
|
+
model_name (str, optional): 指定的模型名称. Defaults to None.
|
185
192
|
|
186
193
|
返回:
|
187
194
|
str: 相关的方法论提示,如果未找到方法论则返回空字符串
|
@@ -203,7 +210,17 @@ def load_methodology(user_input: str, tool_registery: Optional[Any] = None) -> s
|
|
203
210
|
return ""
|
204
211
|
print(f"✅ 加载方法论文件完成 (共 {len(methodologies)} 个)")
|
205
212
|
|
206
|
-
|
213
|
+
if platform_name:
|
214
|
+
platform = PlatformRegistry().create_platform(platform_name)
|
215
|
+
if platform and model_name:
|
216
|
+
platform.set_model_name(model_name)
|
217
|
+
else:
|
218
|
+
platform = PlatformRegistry().get_normal_platform()
|
219
|
+
|
220
|
+
if not platform:
|
221
|
+
PrettyOutput.print("无法创建平台实例", OutputType.ERROR)
|
222
|
+
return ""
|
223
|
+
|
207
224
|
platform.set_suppress_output(True)
|
208
225
|
|
209
226
|
# 步骤1:获取所有方法论的标题
|