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.
Files changed (134) hide show
  1. {jarvis_ai_assistant-0.3.3/src/jarvis_ai_assistant.egg-info → jarvis_ai_assistant-0.3.5}/PKG-INFO +1 -1
  2. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/pyproject.toml +7 -4
  3. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/setup.py +1 -1
  4. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/__init__.py +1 -1
  5. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/__init__.py +164 -3
  6. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/file_methodology_manager.py +6 -1
  7. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/tool_executor.py +8 -4
  8. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/code_agent.py +1 -8
  9. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_memory_organizer/memory_organizer.py +44 -12
  10. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/base.py +3 -14
  11. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/base.py +8 -1
  12. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/git_utils.py +20 -3
  13. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/methodology.py +19 -2
  14. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/utils.py +110 -49
  15. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5/src/jarvis_ai_assistant.egg-info}/PKG-INFO +1 -1
  16. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/LICENSE +0 -0
  17. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/MANIFEST.in +0 -0
  18. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/README.md +0 -0
  19. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/setup.cfg +0 -0
  20. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/agent_manager.py +0 -0
  21. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/builtin_input_handler.py +0 -0
  22. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/config_editor.py +0 -0
  23. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/edit_file_handler.py +0 -0
  24. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/jarvis.py +0 -0
  25. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/main.py +0 -0
  26. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/memory_manager.py +0 -0
  27. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/methodology_share_manager.py +0 -0
  28. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/output_handler.py +0 -0
  29. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/prompt_builder.py +0 -0
  30. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/prompts.py +0 -0
  31. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/protocols.py +0 -0
  32. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/session_manager.py +0 -0
  33. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/share_manager.py +0 -0
  34. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/shell_input_handler.py +0 -0
  35. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/task_analyzer.py +0 -0
  36. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/task_manager.py +0 -0
  37. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_agent/tool_share_manager.py +0 -0
  38. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/__init__.py +0 -0
  39. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_agent/lint.py +0 -0
  40. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/__init__.py +0 -0
  41. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/c_cpp.py +0 -0
  42. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/csharp.py +0 -0
  43. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/data_format.py +0 -0
  44. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/devops.py +0 -0
  45. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/docs.py +0 -0
  46. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/go.py +0 -0
  47. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/infrastructure.py +0 -0
  48. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/java.py +0 -0
  49. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/javascript.py +0 -0
  50. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/kotlin.py +0 -0
  51. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/loader.py +0 -0
  52. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/php.py +0 -0
  53. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/python.py +0 -0
  54. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/ruby.py +0 -0
  55. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/rust.py +0 -0
  56. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/shell.py +0 -0
  57. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/sql.py +0 -0
  58. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/swift.py +0 -0
  59. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/checklists/web.py +0 -0
  60. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_code_analysis/code_review.py +0 -0
  61. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_data/config_schema.json +0 -0
  62. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_data/tiktoken/9b5ad71b2ce5302211f9c61530b329a4922fc6a4 +0 -0
  63. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_git_squash/__init__.py +0 -0
  64. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_git_squash/main.py +0 -0
  65. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_git_utils/git_commiter.py +0 -0
  66. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/__init__.py +0 -0
  67. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/sse_mcp_client.py +0 -0
  68. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/stdio_mcp_client.py +0 -0
  69. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_mcp/streamable_mcp_client.py +0 -0
  70. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_memory_organizer/__init__.py +0 -0
  71. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_methodology/main.py +0 -0
  72. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_multi_agent/__init__.py +0 -0
  73. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_multi_agent/main.py +0 -0
  74. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/__init__.py +0 -0
  75. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/ai8.py +0 -0
  76. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/human.py +0 -0
  77. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/kimi.py +0 -0
  78. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/openai.py +0 -0
  79. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/registry.py +0 -0
  80. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/tongyi.py +0 -0
  81. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform/yuanbao.py +0 -0
  82. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform_manager/__init__.py +0 -0
  83. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform_manager/main.py +0 -0
  84. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_platform_manager/service.py +0 -0
  85. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/__init__.py +0 -0
  86. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/cache.py +0 -0
  87. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/cli.py +0 -0
  88. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/embedding_manager.py +0 -0
  89. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/llm_interface.py +0 -0
  90. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/query_rewriter.py +0 -0
  91. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/rag_pipeline.py +0 -0
  92. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/reranker.py +0 -0
  93. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_rag/retriever.py +0 -0
  94. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_smart_shell/__init__.py +0 -0
  95. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_smart_shell/main.py +0 -0
  96. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/__init__.py +0 -0
  97. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/cli.py +0 -0
  98. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/stats.py +0 -0
  99. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/storage.py +0 -0
  100. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_stats/visualizer.py +0 -0
  101. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/__init__.py +0 -0
  102. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/ask_user.py +0 -0
  103. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/clear_memory.py +0 -0
  104. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/cli/__init__.py +0 -0
  105. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/cli/main.py +0 -0
  106. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/edit_file.py +0 -0
  107. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/execute_script.py +0 -0
  108. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/file_analyzer.py +0 -0
  109. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/generate_new_tool.py +0 -0
  110. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/methodology.py +0 -0
  111. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/read_code.py +0 -0
  112. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/read_webpage.py +0 -0
  113. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/registry.py +0 -0
  114. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/retrieve_memory.py +0 -0
  115. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/rewrite_file.py +0 -0
  116. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/save_memory.py +0 -0
  117. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/search_web.py +0 -0
  118. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_tools/virtual_tty.py +0 -0
  119. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/__init__.py +0 -0
  120. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/builtin_replace_map.py +0 -0
  121. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/clipboard.py +0 -0
  122. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/config.py +0 -0
  123. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/embedding.py +0 -0
  124. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/file_processors.py +0 -0
  125. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/globals.py +0 -0
  126. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/http.py +0 -0
  127. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/input.py +0 -0
  128. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/output.py +0 -0
  129. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis/jarvis_utils/tag.py +0 -0
  130. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/SOURCES.txt +0 -0
  131. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/dependency_links.txt +0 -0
  132. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/entry_points.txt +0 -0
  133. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/requires.txt +0 -0
  134. {jarvis_ai_assistant-0.3.3 → jarvis_ai_assistant-0.3.5}/src/jarvis_ai_assistant.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: jarvis-ai-assistant
3
- Version: 0.3.3
3
+ Version: 0.3.5
4
4
  Summary: Jarvis: An AI assistant that uses tools to interact with the system
5
5
  Home-page: https://github.com/skyfireitdiy/Jarvis
6
6
  Author: skyfire
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "jarvis-ai-assistant"
7
- version = "0.3.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
- [[tool.uv.index]]
105
- name = "tsinghua"
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.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",
@@ -1,4 +1,4 @@
1
1
  # -*- coding: utf-8 -*-
2
2
  """Jarvis AI Assistant"""
3
3
 
4
- __version__ = "0.3.3"
4
+ __version__ = "0.3.5"
@@ -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
- welcome_message = f"{name} 初始化完成 - 使用 {self.model.name()} 模型" # type: ignore
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(msg, self.agent.get_tool_registry())
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:
@@ -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
- print(f"🔧 正在执行{tool_to_execute.name()}...")
45
- result = tool_to_execute.handle(response, agent)
46
- print(f"✅ {tool_to_execute.name()}执行完成")
47
- return result
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, ""
@@ -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
- git_dir = find_git_root_and_cd(curr_dir)
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
- overlap_groups = self._find_overlapping_memories(memories, overlap_count)
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
- group_memories = [memories[i] for i in group]
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, memory_type, [memories[i] for i in group]
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(group)
345
+ stats["merged_memories"] += len(original_indices)
323
346
  stats["created_memories"] += 1
324
347
 
325
- # 从列表中移除已合并的记忆
326
- for i in sorted(group, reverse=True):
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"]).unlink()
380
- PrettyOutput.print(
381
- f"删除原始记忆: {orig_memory.get('id', '未知')}",
382
- OutputType.INFO,
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
- char_count = len(response)
146
- # Calculate token count and tokens per second
147
- try:
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):
@@ -39,4 +39,11 @@ class Tool:
39
39
  返回:
40
40
  Dict[str, Any]: 工具执行结果
41
41
  """
42
- return self.func(arguments)
42
+ try:
43
+ return self.func(arguments)
44
+ except Exception as e:
45
+ return {
46
+ "success": False,
47
+ "stderr": f"工具 {self.name} 执行失败: {str(e)}",
48
+ "stdout": "",
49
+ }
@@ -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
- result[current_file] = (start_line, end_line)
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
- install_cmd = [sys.executable, "-m", "pip", "install", "-e", "."]
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
  )
@@ -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(user_input: str, tool_registery: Optional[Any] = None) -> str:
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
- platform = PlatformRegistry().get_normal_platform()
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:获取所有方法论的标题