auto-coder 0.1.245__tar.gz → 0.1.247__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.

Potentially problematic release.


This version of auto-coder might be problematic. Click here for more details.

Files changed (159) hide show
  1. {auto_coder-0.1.245 → auto_coder-0.1.247}/PKG-INFO +1 -1
  2. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/auto_coder.egg-info/PKG-INFO +1 -1
  3. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/auto_coder.py +61 -77
  4. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/chat_auto_coder.py +26 -13
  5. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/chat_auto_coder_lang.py +7 -1
  6. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/auto_coder_lang.py +22 -14
  7. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_generate.py +1 -0
  8. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_modification_ranker.py +8 -1
  9. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/git_utils.py +4 -2
  10. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/entry.py +9 -3
  11. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/filter/normal_filter.py +9 -8
  12. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/filter/quick_filter.py +41 -5
  13. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/index.py +11 -5
  14. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/models.py +8 -0
  15. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/tsproject/__init__.py +2 -2
  16. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/auto_coder_utils/chat_stream_out.py +13 -9
  17. auto_coder-0.1.247/src/autocoder/version.py +1 -0
  18. auto_coder-0.1.245/src/autocoder/version.py +0 -1
  19. {auto_coder-0.1.245 → auto_coder-0.1.247}/LICENSE +0 -0
  20. {auto_coder-0.1.245 → auto_coder-0.1.247}/README.md +0 -0
  21. {auto_coder-0.1.245 → auto_coder-0.1.247}/setup.cfg +0 -0
  22. {auto_coder-0.1.245 → auto_coder-0.1.247}/setup.py +0 -0
  23. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/auto_coder.egg-info/SOURCES.txt +0 -0
  24. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/auto_coder.egg-info/dependency_links.txt +0 -0
  25. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/auto_coder.egg-info/entry_points.txt +0 -0
  26. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/auto_coder.egg-info/requires.txt +0 -0
  27. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/auto_coder.egg-info/top_level.txt +0 -0
  28. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/__init__.py +0 -0
  29. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/__init__.py +0 -0
  30. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/auto_demand_organizer.py +0 -0
  31. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/auto_filegroup.py +0 -0
  32. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/auto_guess_query.py +0 -0
  33. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/auto_review_commit.py +0 -0
  34. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/auto_tool.py +0 -0
  35. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/coder.py +0 -0
  36. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/designer.py +0 -0
  37. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/planner.py +0 -0
  38. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/agent/project_reader.py +0 -0
  39. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/auto_coder_rag.py +0 -0
  40. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/auto_coder_rag_client_mcp.py +0 -0
  41. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/auto_coder_rag_mcp.py +0 -0
  42. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/auto_coder_server.py +0 -0
  43. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/benchmark.py +0 -0
  44. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/chat/__init__.py +0 -0
  45. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/command_args.py +0 -0
  46. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/JupyterClient.py +0 -0
  47. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/ShellClient.py +0 -0
  48. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/__init__.py +0 -0
  49. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/anything2images.py +0 -0
  50. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/anything2img.py +0 -0
  51. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/audio.py +0 -0
  52. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/buildin_tokenizer.py +0 -0
  53. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/chunk_validation.py +0 -0
  54. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/cleaner.py +0 -0
  55. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_execute.py +0 -0
  56. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_generate_diff.py +0 -0
  57. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_generate_editblock.py +0 -0
  58. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_generate_strict_diff.py +0 -0
  59. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_merge.py +0 -0
  60. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_merge_diff.py +0 -0
  61. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_merge_editblock.py +0 -0
  62. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/code_auto_merge_strict_diff.py +0 -0
  63. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/command_completer.py +0 -0
  64. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/command_generator.py +0 -0
  65. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/command_templates.py +0 -0
  66. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/const.py +0 -0
  67. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/files.py +0 -0
  68. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/image_to_page.py +0 -0
  69. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/interpreter.py +0 -0
  70. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/llm_rerank.py +0 -0
  71. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/mcp_hub.py +0 -0
  72. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/mcp_server.py +0 -0
  73. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/mcp_servers/__init__.py +0 -0
  74. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/mcp_servers/mcp_server_perplexity.py +0 -0
  75. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/mcp_tools.py +0 -0
  76. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/memory_manager.py +0 -0
  77. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/printer.py +0 -0
  78. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/recall_validation.py +0 -0
  79. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/screenshots.py +0 -0
  80. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/search.py +0 -0
  81. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/search_replace.py +0 -0
  82. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/sys_prompt.py +0 -0
  83. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/text.py +0 -0
  84. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/types.py +0 -0
  85. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/common/utils_code_auto_generate.py +0 -0
  86. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/data/tokenizer.json +0 -0
  87. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/db/__init__.py +0 -0
  88. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/db/store.py +0 -0
  89. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/__init__.py +0 -0
  90. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/actions/__init__.py +0 -0
  91. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/actions/action.py +0 -0
  92. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/actions/copilot.py +0 -0
  93. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/actions/plugins/__init__.py +0 -0
  94. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/actions/plugins/action_regex_project.py +0 -0
  95. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/dispacher/actions/plugins/action_translate.py +0 -0
  96. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/__init__.py +0 -0
  97. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/filter/__init__.py +0 -0
  98. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/for_command.py +0 -0
  99. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/symbols_utils.py +0 -0
  100. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/index/types.py +0 -0
  101. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/lang.py +0 -0
  102. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/pyproject/__init__.py +0 -0
  103. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/__init__.py +0 -0
  104. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/api_server.py +0 -0
  105. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/cache/__init__.py +0 -0
  106. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/cache/base_cache.py +0 -0
  107. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/cache/byzer_storage_cache.py +0 -0
  108. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/cache/file_monitor_cache.py +0 -0
  109. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/cache/simple_cache.py +0 -0
  110. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/doc_filter.py +0 -0
  111. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/document_retriever.py +0 -0
  112. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/llm_wrapper.py +0 -0
  113. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/loaders/__init__.py +0 -0
  114. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/loaders/docx_loader.py +0 -0
  115. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/loaders/excel_loader.py +0 -0
  116. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/loaders/pdf_loader.py +0 -0
  117. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/loaders/ppt_loader.py +0 -0
  118. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/long_context_rag.py +0 -0
  119. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/rag_config.py +0 -0
  120. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/rag_entry.py +0 -0
  121. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/raw_rag.py +0 -0
  122. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/relevant_utils.py +0 -0
  123. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/simple_directory_reader.py +0 -0
  124. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/simple_rag.py +0 -0
  125. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/stream_event/__init__.py +0 -0
  126. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/stream_event/event_writer.py +0 -0
  127. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/stream_event/types.py +0 -0
  128. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/token_checker.py +0 -0
  129. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/token_counter.py +0 -0
  130. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/token_limiter.py +0 -0
  131. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/types.py +0 -0
  132. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/utils.py +0 -0
  133. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/rag/variable_holder.py +0 -0
  134. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/regexproject/__init__.py +0 -0
  135. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/suffixproject/__init__.py +0 -0
  136. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/__init__.py +0 -0
  137. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/_markitdown.py +0 -0
  138. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/auto_coder_utils/__init__.py +0 -0
  139. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/chat_auto_coder_utils/__init__.py +0 -0
  140. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/conversation_store.py +0 -0
  141. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/llm_client_interceptors.py +0 -0
  142. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/llms.py +0 -0
  143. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/log_capture.py +0 -0
  144. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/multi_turn.py +0 -0
  145. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/operate_config_api.py +0 -0
  146. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/print_table.py +0 -0
  147. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/queue_communicate.py +0 -0
  148. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/request_event_queue.py +0 -0
  149. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/request_queue.py +0 -0
  150. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/rest.py +0 -0
  151. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/tests.py +0 -0
  152. {auto_coder-0.1.245 → auto_coder-0.1.247}/src/autocoder/utils/types.py +0 -0
  153. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_action_regex_project.py +0 -0
  154. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_chat_auto_coder.py +0 -0
  155. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_code_auto_merge_editblock.py +0 -0
  156. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_command_completer.py +0 -0
  157. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_planner.py +0 -0
  158. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_queue_communicate.py +0 -0
  159. {auto_coder-0.1.245 → auto_coder-0.1.247}/tests/test_symbols_utils.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: auto-coder
3
- Version: 0.1.245
3
+ Version: 0.1.247
4
4
  Summary: AutoCoder: AutoCoder
5
5
  Author: allwefantasy
6
6
  Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: auto-coder
3
- Version: 0.1.245
3
+ Version: 0.1.247
4
4
  Summary: AutoCoder: AutoCoder
5
5
  Author: allwefantasy
6
6
  Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
@@ -276,7 +276,7 @@ def main(input_args: Optional[List[str]] = None):
276
276
  )
277
277
  byzerllm.connect_cluster(address=args.ray_address)
278
278
 
279
- llm = byzerllm.ByzerLLM(verbose=args.print_request)
279
+ llm = byzerllm.ByzerLLM(verbose=args.print_request)
280
280
 
281
281
  # code_model,index_filter_model,generate_rerank_model,chat_model
282
282
  # 这四个模型如果用户没有设置,就会使用默认的
@@ -300,86 +300,66 @@ def main(input_args: Optional[List[str]] = None):
300
300
  llm.setup_sub_client("chat_model", chat_model)
301
301
 
302
302
  if args.product_mode == "lite":
303
- default_model = args.model
303
+ default_model = args.model
304
+ model_info = models_module.get_model_by_name(default_model)
304
305
  llm = byzerllm.SimpleByzerLLM(default_model_name=default_model)
305
- api_key_dir = os.path.expanduser("~/.auto-coder/keys")
306
- api_key_file = os.path.join(api_key_dir, "api.deepseek.com")
307
-
308
- if not os.path.exists(api_key_file):
309
- raise Exception(f"API key file not found: {api_key_file}")
310
-
311
- with open(api_key_file, "r") as f:
312
- api_key = f.read()
313
-
314
306
  llm.deploy(
315
307
  model_path="",
316
- pretrained_model_type="saas/openai",
317
- udf_name=default_model,
308
+ pretrained_model_type=model_info["model_type"],
309
+ udf_name=args.model,
318
310
  infer_params={
319
- "saas.base_url": "https://api.deepseek.com/v1",
320
- "saas.api_key": api_key,
321
- "saas.model": "deepseek-chat",
322
- "saas.is_reasoning": False
311
+ "saas.base_url": model_info["base_url"],
312
+ "saas.api_key": model_info["api_key"],
313
+ "saas.model": model_info["model_name"],
314
+ "saas.is_reasoning": model_info["is_reasoning"]
323
315
  }
324
- )
325
-
326
- code_llm = byzerllm.SimpleByzerLLM(default_model)
327
- code_llm.deploy(
328
- model_path="",
329
- pretrained_model_type="saas/openai",
330
- udf_name=default_model,
331
- infer_params={
332
- "saas.base_url": "https://api.deepseek.com/v1",
333
- "saas.api_key": api_key,
334
- "saas.model": "deepseek-chat",
335
- "saas.is_reasoning": False
336
- }
337
- )
338
-
339
- chat_llm = byzerllm.SimpleByzerLLM(default_model_name="deepseek_r1_chat")
340
- chat_llm.deploy(
341
- model_path="",
342
- pretrained_model_type="saas/openai",
343
- udf_name="deepseek_r1_chat",
344
- infer_params={
345
- "saas.base_url": "https://api.deepseek.com/v1",
346
- "saas.api_key": api_key,
347
- "saas.model": "deepseek-reasoner",
348
- "saas.is_reasoning": True
349
- }
350
- )
316
+ )
317
+
318
+ if models_module.check_model_exists("deepseek_r1_chat"):
319
+ r1_model_info = models_module.get_model_by_name("deepseek_r1_chat")
320
+ api_key = r1_model_info["api_key"]
321
+ chat_llm = byzerllm.SimpleByzerLLM(default_model_name="deepseek_r1_chat")
322
+ chat_llm.deploy(
323
+ model_path="",
324
+ pretrained_model_type="saas/openai",
325
+ udf_name="deepseek_r1_chat",
326
+ infer_params={
327
+ "saas.base_url": "https://api.deepseek.com/v1",
328
+ "saas.api_key": api_key,
329
+ "saas.model": "deepseek-reasoner",
330
+ "saas.is_reasoning": True
331
+ }
332
+ )
351
333
 
352
- generate_rerank_llm = byzerllm.SimpleByzerLLM(default_model_name="deepseek_r1_chat")
353
- generate_rerank_llm.deploy(
354
- model_path="",
355
- pretrained_model_type="saas/openai",
356
- udf_name="deepseek_r1_chat",
357
- infer_params={
358
- "saas.base_url": "https://api.deepseek.com/v1",
359
- "saas.api_key": api_key,
360
- "saas.model": "deepseek-reasoner",
361
- "saas.is_reasoning": True
362
- }
363
- )
334
+ generate_rerank_llm = byzerllm.SimpleByzerLLM(default_model_name="deepseek_r1_chat")
335
+ generate_rerank_llm.deploy(
336
+ model_path="",
337
+ pretrained_model_type="saas/openai",
338
+ udf_name="deepseek_r1_chat",
339
+ infer_params={
340
+ "saas.base_url": "https://api.deepseek.com/v1",
341
+ "saas.api_key": api_key,
342
+ "saas.model": "deepseek-reasoner",
343
+ "saas.is_reasoning": True
344
+ }
345
+ )
364
346
 
365
- index_filter_llm = byzerllm.SimpleByzerLLM(default_model_name="deepseek_r1_chat")
366
- index_filter_llm.deploy(
367
- model_path="",
368
- pretrained_model_type="saas/openai",
369
- udf_name="deepseek_r1_chat",
370
- infer_params={
371
- "saas.base_url": "https://api.deepseek.com/v1",
372
- "saas.api_key": api_key,
373
- "saas.model": "deepseek-reasoner",
374
- "saas.is_reasoning": True
375
- }
376
- )
377
-
378
- # 这四个模型如果用户没有设置,就会使用默认的
379
- llm.setup_sub_client("code_model", code_llm)
380
- llm.setup_sub_client("chat_model", chat_llm)
381
- llm.setup_sub_client("generate_rerank_model", generate_rerank_llm)
382
- llm.setup_sub_client("index_filter_model", index_filter_llm)
347
+ index_filter_llm = byzerllm.SimpleByzerLLM(default_model_name="deepseek_r1_chat")
348
+ index_filter_llm.deploy(
349
+ model_path="",
350
+ pretrained_model_type="saas/openai",
351
+ udf_name="deepseek_r1_chat",
352
+ infer_params={
353
+ "saas.base_url": "https://api.deepseek.com/v1",
354
+ "saas.api_key": api_key,
355
+ "saas.model": "deepseek-reasoner",
356
+ "saas.is_reasoning": True
357
+ }
358
+ )
359
+
360
+ llm.setup_sub_client("chat_model", chat_llm)
361
+ llm.setup_sub_client("generate_rerank_model", generate_rerank_llm)
362
+ llm.setup_sub_client("index_filter_model", index_filter_llm)
383
363
 
384
364
  if args.product_mode == "lite":
385
365
  # Set up default models based on configuration
@@ -1359,7 +1339,7 @@ def main(input_args: Optional[List[str]] = None):
1359
1339
  elif "review_commit" in args.action:
1360
1340
  from autocoder.agent.auto_review_commit import AutoReviewCommit
1361
1341
  reviewer = AutoReviewCommit(llm=chat_llm, args=args)
1362
- v = reviewer.review_commit(args.query)
1342
+ v = reviewer.review_commit(query=args.query,conversations=loaded_conversations)
1363
1343
  else:
1364
1344
  v = stream_chat_with_continue(
1365
1345
  llm=chat_llm,
@@ -1367,12 +1347,16 @@ def main(input_args: Optional[List[str]] = None):
1367
1347
  llm_config={}
1368
1348
  )
1369
1349
 
1370
-
1350
+
1351
+ model_name = getattr(chat_llm, 'default_model_name', None)
1352
+ if not model_name:
1353
+ model_name = "unknown(without default model name)"
1371
1354
 
1372
1355
  assistant_response, last_meta = stream_out(
1373
1356
  v,
1374
1357
  request_id=args.request_id,
1375
- console=console
1358
+ console=console,
1359
+ model_name=model_name
1376
1360
  )
1377
1361
 
1378
1362
  # 打印耗时和token统计
@@ -1712,14 +1712,24 @@ def commit(query: str):
1712
1712
  finally:
1713
1713
  if os.path.exists(temp_yaml):
1714
1714
  os.remove(temp_yaml)
1715
-
1716
- llm = get_single_llm(args.code_model or args.model, product_mode)
1717
- uncommitted_changes = git_utils.get_uncommitted_changes(".")
1718
- commit_message = git_utils.generate_commit_message.with_llm(llm).run(
1719
- uncommitted_changes
1720
- )
1721
- memory["conversation"].append(
1722
- {"role": "user", "content": commit_message})
1715
+
1716
+ target_model = args.code_model or args.model
1717
+ llm = get_single_llm(target_model, product_mode)
1718
+ printer = Printer()
1719
+ printer.print_in_terminal("commit_generating", style="yellow", model_name=target_model)
1720
+ commit_message = ""
1721
+
1722
+ try:
1723
+ uncommitted_changes = git_utils.get_uncommitted_changes(".")
1724
+ commit_message = git_utils.generate_commit_message.with_llm(llm).run(
1725
+ uncommitted_changes
1726
+ )
1727
+ memory["conversation"].append(
1728
+ {"role": "user", "content": commit_message})
1729
+ except Exception as e:
1730
+ printer.print_in_terminal("commit_failed", style="red", error=str(e), model_name=target_model)
1731
+ return
1732
+
1723
1733
  yaml_config["query"] = commit_message
1724
1734
  yaml_content = convert_yaml_config_to_str(yaml_config=yaml_config)
1725
1735
  with open(os.path.join(execute_file), "w") as f:
@@ -1732,6 +1742,8 @@ def commit(query: str):
1732
1742
  ".", f"auto_coder_{file_name}_{md5}"
1733
1743
  )
1734
1744
  git_utils.print_commit_info(commit_result=commit_result)
1745
+ if commit_message:
1746
+ printer.print_in_terminal("commit_message", style="green", model_name=target_model, message=commit_message)
1735
1747
  except Exception as e:
1736
1748
  import traceback
1737
1749
  traceback.print_exc()
@@ -1875,8 +1887,8 @@ def coding(query: str):
1875
1887
  @byzerllm.prompt()
1876
1888
  def code_review(query: str) -> str:
1877
1889
  """
1878
- 对代码进行review,参考如下检查点。
1879
- 1. 有没有调用不符合方法,类的签名的调用
1890
+ 掐面提供了上下文,对代码进行review,参考如下检查点。
1891
+ 1. 有没有调用不符合方法,类的签名的调用,包括对第三方类,模块,方法的检查(如果上下文提供了这些信息)
1880
1892
  2. 有没有未声明直接使用的变量,方法,类
1881
1893
  3. 有没有明显的语法错误
1882
1894
  4. 如果是python代码,检查有没有缩进方面的错误
@@ -2706,9 +2718,10 @@ def main():
2706
2718
  memory["mode"] = "normal"
2707
2719
 
2708
2720
  # 处理 user_input 的空格
2709
- temp_user_input = user_input.lstrip() # 去掉左侧空格
2710
- if temp_user_input.startswith('/'):
2711
- user_input = temp_user_input
2721
+ if user_input:
2722
+ temp_user_input = user_input.lstrip() # 去掉左侧空格
2723
+ if temp_user_input.startswith('/'):
2724
+ user_input = temp_user_input
2712
2725
 
2713
2726
  if (
2714
2727
  memory["mode"] == "auto_detect"
@@ -113,9 +113,15 @@ MESSAGES = {
113
113
  "remove_files_none": "No files were removed.",
114
114
  "files_removed": "Files Removed",
115
115
  "models_api_key_empty": "Warning : {{name}} API key is empty. Please set a valid API key.",
116
+ "commit_generating": "{{ model_name }} Generating commit message...",
117
+ "commit_message": "{{ model_name }} Generated commit message: {{ message }}",
118
+ "commit_failed": "{{ model_name }} Failed to generate commit message: {{ error }}",
116
119
  },
117
120
  "zh": {
118
- "mcp_remove_error": "移除 MCP 服务器时出错:{error}",
121
+ "commit_generating": "{{ model_name }} 正在生成提交信息...",
122
+ "commit_message": "{{ model_name }} 生成的提交信息: {{ message }}",
123
+ "commit_failed": "{{ model_name }} 生成提交信息失败: {{ error }}",
124
+ "mcp_remove_error": "移除 MCP 服务器时出错:{error}",
119
125
  "mcp_remove_success": "成功移除 MCP 服务器:{result}",
120
126
  "mcp_list_running_error": "列出运行中的 MCP 服务器时出错:{error}",
121
127
  "mcp_list_running_title": "正在运行的 MCP 服务器:",
@@ -14,8 +14,8 @@ MESSAGES = {
14
14
  "no_latest_commit": "Unable to get latest commit information",
15
15
  "code_review_error": "Code review process error: {{error}}",
16
16
  "index_file_too_large": "⚠️ File {{ file_path }} is too large ({{ file_size }} > {{ max_length }}), splitting into chunks...",
17
- "index_update_success": "✅ Successfully updated index for {{ file_path }} (md5: {{ md5 }}) in {{ duration }}s",
18
- "index_build_error": "❌ Error building index for {{ file_path }}: {{ error }}",
17
+ "index_update_success": "✅ {{ model_name }} Successfully updated index for {{ file_path }} (md5: {{ md5 }}) in {{ duration }}s",
18
+ "index_build_error": "❌ {{ model_name }} Error building index for {{ file_path }}: {{ error }}",
19
19
  "index_build_summary": "📊 Total Files: {{ total_files }}, Need to Build Index: {{ num_files }}",
20
20
  "building_index_progress": "⏳ Building Index: {{ counter }}/{{ num_files }}...",
21
21
  "index_source_dir_mismatch": "⚠️ Source directory mismatch (file_path: {{ file_path }}, source_dir: {{ source_dir }})",
@@ -53,8 +53,8 @@ MESSAGES = {
53
53
  "code_generation_complete": "Code generation completed in {{ duration }} seconds, input_tokens_count: {{ input_tokens }}, generated_tokens_count: {{ output_tokens }}",
54
54
  "code_merge_start": "Auto merge the code...",
55
55
  "code_execution_warning": "Content(send to model) is {{ content_length }} tokens (you may collect too much files), which is larger than the maximum input length {{ max_length }}",
56
- "quick_filter_start": "Starting filter context(quick_filter)...",
57
- "normal_filter_start": "Starting filter context(normal_filter)...",
56
+ "quick_filter_start": "{{ model_name }} Starting filter context(quick_filter)...",
57
+ "normal_filter_start": "{{ model_name }} Starting filter context(normal_filter)...",
58
58
  "pylint_check_failed": "⚠️ Pylint check failed: {{ error_message }}",
59
59
  "pylint_error": "❌ Error running pylint: {{ error_message }}",
60
60
  "unmerged_blocks_warning": "⚠️ Found {{ num_blocks }} unmerged blocks, the changes will not be applied. Please review them manually then try again.",
@@ -65,7 +65,7 @@ MESSAGES = {
65
65
  "merge_failed": "❌ Merge file {{ path }} failed: {{ error }}",
66
66
  "files_merged_total": "✅ Merged {{ total }} files into the project.",
67
67
  "ranking_skip": "Only 1 candidate, skip ranking",
68
- "ranking_start": "Start ranking {{ count }} candidates",
68
+ "ranking_start": "Start ranking {{ count }} candidates using model {{ model_name }}",
69
69
  "ranking_failed_request": "Ranking request failed: {{ error }}",
70
70
  "ranking_all_failed": "All ranking requests failed",
71
71
  "ranking_complete": "Ranking completed in {{ elapsed }}s, total voters: {{ total_tasks }}, best candidate index: {{ best_candidate }}, scores: {{ scores }}, input_tokens: {{ input_tokens }}, output_tokens: {{ output_tokens }}",
@@ -73,13 +73,17 @@ MESSAGES = {
73
73
  "ranking_failed": "Ranking failed in {{ elapsed }}s, using original order",
74
74
  "begin_index_source_code": "🚀 Begin to index source code in {{ source_dir }}",
75
75
  "stream_out_stats": "Elapsed time {{ elapsed_time }} seconds, input tokens: {{ input_tokens }}, output tokens: {{ output_tokens }}",
76
+ "quick_filter_stats": "快速过滤器完成,耗时 {{ elapsed_time }} 秒,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}",
76
77
  "upsert_file": "✅ Updated file: {{ file_path }}",
77
- "unmerged_blocks_title": "Unmerged Blocks",
78
+ "unmerged_blocks_title": "Unmerged Blocks",
79
+ "quick_filter_title": "{{ model_name }} is analyzing how to filter context...",
80
+ "quick_filter_failed": "❌ Quick filter failed: {{ error }}. ",
78
81
  "unmerged_file_path": "File: {{file_path}}",
79
82
  "unmerged_search_block": "Search Block({{similarity}}):",
80
83
  "unmerged_replace_block": "Replace Block:",
81
84
  "unmerged_blocks_total": "Total unmerged blocks: {{num_blocks}}",
82
- "git_init_required": "⚠️ auto_merge only applies to git repositories.\n\nPlease try using git init in the source directory:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\nThen run auto - coder again.\nError: {{ error }}"
85
+ "git_init_required": "⚠️ auto_merge only applies to git repositories.\n\nPlease try using git init in the source directory:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\nThen run auto - coder again.\nError: {{ error }}",
86
+ "quick_filter_reason": "Auto get(quick_filter mode)"
83
87
  },
84
88
  "zh": {
85
89
  "model_not_found": "未找到模型: {{model_name}}",
@@ -93,8 +97,8 @@ MESSAGES = {
93
97
  "no_latest_commit": "无法获取最新的提交信息",
94
98
  "code_review_error": "代码审查过程出错: {{error}}",
95
99
  "index_file_too_large": "⚠️ 文件 {{ file_path }} 过大 ({{ file_size }} > {{ max_length }}), 正在分块处理...",
96
- "index_update_success": "✅ 成功更新 {{ file_path }} 的索引 (md5: {{ md5 }}), 耗时 {{ duration }} 秒",
97
- "index_build_error": "❌ 构建 {{ file_path }} 索引时出错: {{ error }}",
100
+ "index_update_success": "✅ {{ model_name }} 成功更新 {{ file_path }} 的索引 (md5: {{ md5 }}), 耗时 {{ duration }} 秒",
101
+ "index_build_error": "❌ {{ model_name }} 构建 {{ file_path }} 索引时出错: {{ error }}",
98
102
  "index_build_summary": "📊 总文件数: {{ total_files }}, 需要构建索引: {{ num_files }}",
99
103
  "building_index_progress": "⏳ 正在构建索引: {{ counter }}/{{ num_files }}...",
100
104
  "index_source_dir_mismatch": "⚠️ 源目录不匹配 (文件路径: {{ file_path }}, 源目录: {{ source_dir }})",
@@ -132,8 +136,8 @@ MESSAGES = {
132
136
  "code_generation_complete": "代码生成完成,耗时 {{ duration }} 秒,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}",
133
137
  "code_merge_start": "正在自动合并代码...",
134
138
  "code_execution_warning": "发送给模型的内容长度为 {{ content_length }} tokens(您可能收集了太多文件),超过了最大输入长度 {{ max_length }}",
135
- "quick_filter_start": "开始查找上下文(quick_filter)...",
136
- "normal_filter_start": "开始查找上下文(normal_filter)...",
139
+ "quick_filter_start": "{{ model_name }} 开始查找上下文(quick_filter)...",
140
+ "normal_filter_start": "{{ model_name }} 开始查找上下文(normal_filter)...",
137
141
  "pylint_check_failed": "⚠️ Pylint 检查失败: {{ error_message }}",
138
142
  "pylint_error": "❌ 运行 Pylint 时出错: {{ error_message }}",
139
143
  "begin_index_source_code": "🚀 开始为 {{ source_dir }} 中的源代码建立索引",
@@ -146,19 +150,23 @@ MESSAGES = {
146
150
  "unmerged_search_block": "Search Block({{similarity}}):",
147
151
  "unmerged_replace_block": "Replace Block:",
148
152
  "unmerged_blocks_total": "未合并代码块数量: {{num_blocks}}",
149
- "git_init_required": "⚠️ auto_merge 仅适用于 git 仓库。\n\n请尝试在源目录中使用 git init:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\n然后再次运行 auto-coder。\n错误: {{ error }}",
153
+ "git_init_required": "⚠️ auto_merge 仅适用于 git 仓库。\n\n请尝试在源目录中使用 git init:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\n然后再次运行 auto-coder。\n错误: {{ error }}",
154
+ "quick_filter_reason": "自动获取(quick_filter模式)",
150
155
  "upsert_file": "✅ 更新文件: {{ file_path }}",
151
156
  "files_merged": "✅ 成功合并了 {{ total }} 个文件到项目中。",
152
157
  "merge_failed": "❌ 合并文件 {{ path }} 失败: {{ error }}",
153
158
  "files_merged_total": "✅ 合并了 {{ total }} 个文件到项目中。",
154
159
  "ranking_skip": "只有1个候选项,跳过排序",
155
- "ranking_start": "开始对 {{ count }} 个候选项进行排序",
160
+ "ranking_start": "开始对 {{ count }} 个候选项进行排序,使用模型 {{ model_name }} 打分",
156
161
  "ranking_failed_request": "排序请求失败: {{ error }}",
157
162
  "ranking_all_failed": "所有排序请求都失败",
158
163
  "ranking_complete": "排序完成,耗时 {{ elapsed }} 秒,总投票数: {{ total_tasks }},最佳候选索引: {{ best_candidate }},得分: {{ scores }},输入token数: {{ input_tokens }},输出token数: {{ output_tokens }}",
159
164
  "ranking_process_failed": "排序过程失败: {{ error }}",
160
165
  "ranking_failed": "排序失败,耗时 {{ elapsed }} 秒,使用原始顺序",
161
- "stream_out_stats": "耗时 {{ elapsed_time }} 秒,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}"
166
+ "stream_out_stats": "耗时 {{ elapsed_time }} 秒,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}",
167
+ "quick_filter_stats": "Quick filter completed in {{ elapsed_time }} seconds, input tokens: {{ input_tokens }}, output tokens: {{ output_tokens }}",
168
+ "quick_filter_title": "{{ model_name }} 正在分析如何筛选上下文...",
169
+ "quick_filter_failed": "❌ 快速过滤器失败: {{ error }}. ",
162
170
  },
163
171
  }
164
172
 
@@ -7,6 +7,7 @@ from autocoder.common import sys_prompt
7
7
  from concurrent.futures import ThreadPoolExecutor
8
8
  from autocoder.common.types import CodeGenerateResult
9
9
  from autocoder.common.utils_code_auto_generate import chat_with_continue
10
+ import json
10
11
 
11
12
 
12
13
  class CodeAutoGenerate:
@@ -77,8 +77,15 @@ class CodeModificationRanker:
77
77
  with ThreadPoolExecutor(max_workers=total_tasks) as executor:
78
78
  # Submit tasks for each model and generate_times
79
79
  futures = []
80
- for llm in self.llms:
80
+ for llm in self.llms:
81
+ model_name = getattr(llm, 'default_model_name', None)
82
+ if not model_name:
83
+ model_name = "unknown(without default model name)"
84
+ self.printer.print_in_terminal(
85
+ "ranking_start", style="blue", count=len(generate_result.contents), model_name=model_name)
86
+
81
87
  for _ in range(rank_times):
88
+
82
89
  futures.append(
83
90
  executor.submit(
84
91
  chat_with_continue,
@@ -262,7 +262,9 @@ def get_uncommitted_changes(repo_path: str) -> str:
262
262
  def generate_commit_message(changes_report: str) -> str:
263
263
  '''
264
264
  我是一个Git提交信息生成助手。我们的目标是通过一些变更报告,倒推用户的需求,将需求作为commit message。
265
- commit message 需要简洁,不要超过100个字符。
265
+ commit message 需要简洁,包含两部分:
266
+ 1. 这个commit 背后的需求是什么
267
+ 2. 为了完成这个需求做了哪些事情
266
268
 
267
269
  下面是一些示例:
268
270
  <examples>
@@ -613,7 +615,7 @@ def print_commit_info(commit_result: CommitResult):
613
615
 
614
616
  table.add_row("Commit Hash", commit_result.commit_hash)
615
617
  table.add_row("Commit Message", commit_result.commit_message)
616
- table.add_row("Changed Files", "\n".join(commit_result.changed_files))
618
+ table.add_row("Changed Files", "\n".join(commit_result.changed_files) if commit_result.changed_files else "No files changed")
617
619
 
618
620
  console.print(
619
621
  Panel(table, expand=False, border_style="green", title="Git Commit Summary")
@@ -101,13 +101,19 @@ def build_index_and_filter_files(
101
101
  )
102
102
  )
103
103
 
104
- if not args.skip_filter_index and args.index_filter_model:
105
- printer.print_in_terminal("quick_filter_start", style="blue")
104
+ if not args.skip_filter_index and args.index_filter_model:
105
+ model_name = getattr(index_manager.index_filter_llm, 'default_model_name', None)
106
+ if not model_name:
107
+ model_name = "unknown(without default model name)"
108
+ printer.print_in_terminal("quick_filter_start", style="blue", model_name=model_name)
106
109
  quick_filter = QuickFilter(index_manager,stats,sources)
107
110
  final_files = quick_filter.filter(index_manager.read_index(),args.query)
108
111
 
109
112
  if not args.skip_filter_index and not args.index_filter_model:
110
- printer.print_in_terminal("normal_filter_start", style="blue")
113
+ model_name = getattr(index_manager.llm, 'default_model_name', None)
114
+ if not model_name:
115
+ model_name = "unknown(without default model name)"
116
+ printer.print_in_terminal("normal_filter_start", style="blue",model_name=model_name)
111
117
  normal_filter = NormalFilter(index_manager,stats,sources)
112
118
  final_files = normal_filter.filter(index_manager.read_index(),args.query)
113
119
 
@@ -60,7 +60,7 @@ class NormalFilter():
60
60
  phase_end = time.monotonic()
61
61
  self.stats["timings"]["normal_filter"]["level1_filter"] = phase_end - phase_start
62
62
 
63
- # Phase 4: Level 2 filtering - Related files
63
+ # Phase 4: Level 2 filtering - Related files
64
64
  if target_files is not None and self.args.index_filter_level >= 2:
65
65
  logger.info(
66
66
  "Phase 4: Performing Level 2 filtering (related files)...")
@@ -84,13 +84,14 @@ class NormalFilter():
84
84
  phase_end = time.monotonic()
85
85
  self.stats["timings"]["normal_filter"]["level2_filter"] = phase_end - phase_start
86
86
 
87
- if not final_files:
88
- logger.warning("No related files found, using all files")
89
- for source in self.sources:
90
- final_files[get_file_path(source.module_name)] = TargetFile(
91
- file_path=source.module_name,
92
- reason="No related files found, use all files",
93
- )
87
+ # if not final_files:
88
+ # logger.warning("No related files found, using all files")
89
+ # for source in self.sources:
90
+ # final_files[get_file_path(source.module_name)] = TargetFile(
91
+ # file_path=source.module_name,
92
+ # reason="No related files found, use all files",
93
+ # )
94
+
94
95
 
95
96
  # Phase 5: Relevance verification
96
97
  logger.info("Phase 5: Performing relevance verification...")
@@ -1,4 +1,7 @@
1
- from typing import List, Union,Dict,Any
1
+ from typing import List, Union, Dict, Any
2
+ from autocoder.utils.auto_coder_utils.chat_stream_out import stream_out
3
+ from autocoder.common.utils_code_auto_generate import stream_chat_with_continue
4
+ from byzerllm.utils.str2model import to_model
2
5
  from autocoder.index.types import IndexItem
3
6
  from autocoder.common import AutoCoderArgs,SourceCode
4
7
  import byzerllm
@@ -11,6 +14,7 @@ from autocoder.index.types import (
11
14
  )
12
15
  from autocoder.rag.token_counter import count_tokens
13
16
  from loguru import logger
17
+ from autocoder.common.printer import Printer
14
18
 
15
19
 
16
20
  def get_file_path(file_path):
@@ -25,6 +29,7 @@ class QuickFilter():
25
29
  self.args = index_manager.args
26
30
  self.stats = stats
27
31
  self.sources = sources
32
+ self.printer = Printer()
28
33
 
29
34
  @byzerllm.prompt()
30
35
  def quick_filter_files(self,file_meta_list:List[IndexItem],query:str) -> str:
@@ -69,6 +74,7 @@ class QuickFilter():
69
74
 
70
75
  def filter(self, index_items: List[IndexItem], query: str) -> Dict[str, TargetFile]:
71
76
  final_files: Dict[str, TargetFile] = {}
77
+
72
78
  if not self.args.skip_filter_index and self.args.index_filter_model:
73
79
  start_time = time.monotonic()
74
80
  index_items = self.index_manager.read_index()
@@ -82,17 +88,47 @@ class QuickFilter():
82
88
  return final_files
83
89
 
84
90
  try:
85
- file_number_list = self.quick_filter_files.with_llm(
86
- self.index_manager.index_filter_llm).with_return_type(FileNumberList).run(index_items, self.args.query)
91
+ model_name = getattr(self.index_manager.index_filter_llm, 'default_model_name', None)
92
+ if not model_name:
93
+ model_name = "unknown(without default model name)"
94
+
95
+ # 渲染 Prompt 模板
96
+ query = self.quick_filter_files.prompt(index_items, self.args.query)
97
+
98
+ # 使用流式输出处理
99
+ stream_generator = stream_chat_with_continue(
100
+ self.index_manager.index_filter_llm,
101
+ [{"role": "user", "content": query}],
102
+ {}
103
+ )
104
+
105
+ # 获取完整响应
106
+ full_response, last_meta = stream_out(
107
+ stream_generator,
108
+ model_name=model_name,
109
+ title=self.printer.get_message_from_key_with_format("quick_filter_title", model_name=model_name)
110
+ )
111
+ # 解析结果
112
+ file_number_list = to_model(full_response, FileNumberList)
113
+
114
+ # 打印 token 统计信息
115
+ self.printer.print_in_terminal(
116
+ "quick_filter_stats",
117
+ style="blue",
118
+ elapsed_time=f"{end_time - start_time:.2f}",
119
+ input_tokens=last_meta.input_tokens_count,
120
+ output_tokens=last_meta.generated_tokens_count
121
+ )
122
+
87
123
  except Exception as e:
88
- logger.error(f"Quick filter failed, error: {str(e)} fallback to normal filter")
124
+ self.printer.print_error(self.printer.get_message_from_key_with_format("quick_filter_failed", error=str(e)))
89
125
  return final_files
90
126
 
91
127
  if file_number_list:
92
128
  for file_number in file_number_list.file_list:
93
129
  final_files[get_file_path(index_items[file_number].module_name)] = TargetFile(
94
130
  file_path=index_items[file_number].module_name,
95
- reason="Quick Filter"
131
+ reason=self.printer.get_message_from_key("quick_filter_reason")
96
132
  )
97
133
  end_time = time.monotonic()
98
134
  self.stats["timings"]["quick_filter"] = end_time - start_time
@@ -195,7 +195,7 @@ class IndexManager:
195
195
  return True
196
196
  return False
197
197
 
198
- def build_index_for_single_source(self, source: SourceCode):
198
+ def build_index_for_single_source(self, source: SourceCode):
199
199
  file_path = source.module_name
200
200
  if not os.path.exists(file_path):
201
201
  return None
@@ -205,6 +205,10 @@ class IndexManager:
205
205
 
206
206
  md5 = hashlib.md5(source.source_code.encode("utf-8")).hexdigest()
207
207
 
208
+ model_name = getattr(self.index_llm, 'default_model_name', None)
209
+ if not model_name:
210
+ model_name = "unknown(without default model name)"
211
+
208
212
  try:
209
213
  start_time = time.monotonic()
210
214
  source_code = source.source_code
@@ -230,13 +234,14 @@ class IndexManager:
230
234
  symbols = self.get_all_file_symbols.with_llm(
231
235
  self.index_llm).run(source.module_name, source_code)
232
236
  time.sleep(self.anti_quota_limit)
233
-
237
+
234
238
  self.printer.print_in_terminal(
235
239
  "index_update_success",
236
240
  style="green",
237
241
  file_path=file_path,
238
242
  md5=md5,
239
- duration=time.monotonic() - start_time
243
+ duration=time.monotonic() - start_time,
244
+ model_name=model_name
240
245
  )
241
246
 
242
247
  except Exception as e:
@@ -246,7 +251,8 @@ class IndexManager:
246
251
  "index_build_error",
247
252
  style="red",
248
253
  file_path=file_path,
249
- error=str(e)
254
+ error=str(e),
255
+ model_name=model_name
250
256
  )
251
257
  return None
252
258
 
@@ -464,7 +470,7 @@ class IndexManager:
464
470
  {file.file_path: file for file in all_results}.values())
465
471
  return FileList(file_list=all_results)
466
472
 
467
- def _query_index_with_thread(self, query, func):
473
+ def _query_index_with_thread(self, query, func):
468
474
  all_results = []
469
475
  lock = threading.Lock()
470
476
  completed_threads = 0