from hello_agents import SimpleAgent, HelloAgentsLLM
from hello_agents.tools import Tool
from typing import List
class ReviewerAgent(SimpleAgent):
"""
负责评审代码的智能体。
它可以访问 CodeRunner 工具来执行代码。
"""
def __init__(self, llm: HelloAgentsLLM, tools: List[Tool] = None, knowledge_service=None):
"""
初始化 ReviewerAgent。
Args:
llm: 用于评审代码的大语言模型实例。
tools: 智能体可用的工具列表(例如 CodeRunner)。
"""
system_prompt = """
你是一位细致的编程代码评审员。
你的目标是分析用户代码的正确性、风格和效率。
你配备了一个 'code_runner' 工具,可以用来执行 Python 代码。
**重要:代码形式识别**
- 代码片段(Code Snippet):可以直接运行的简短代码,如变量赋值、简单计算等
- 函数定义(Function):以 def 开头,包含函数体的完整代码
- 不完整代码:缺少必要的语法元素(如未闭合的括号、缺少 return 等)
**评审流程**:
1. **识别代码类型**:判断是代码片段还是函数定义
2. **运行代码**(推荐):使用 'code_runner' 工具执行代码,验证是否能正常运行
3. **分析逻辑**:检查代码逻辑是否正确,是否达到预期目标
4. **检查风格**:评估代码风格(变量命名、PEP8规范)
5. **性能分析**:提出优化建议(时间/空间复杂度)
6. **建设性反馈**:指出优点和改进空间
**评审原则**:
- ✅ 如果代码可以正常运行,不要说它"不完整"
- ✅ 针对实际代码逻辑进行评审,而不是臆测用户意图
- ✅ 区分"代码片段"和"需要函数封装"的建议
- ✅ 先肯定做得好的地方,再提出改进建议
如果代码有错误,解释原因并提供修复提示,但不要直接给出完整的解决方案,除非用户多次尝试失败。
"""
self.knowledge = knowledge_service
super().__init__(
name="Reviewer",
llm=llm,
system_prompt=system_prompt
)
if tools:
for tool in tools:
self.add_tool(tool)
def run(self, input_text: str, max_tool_iterations: int = 3, **kwargs) -> str:
result = super().run(input_text, max_tool_iterations, **kwargs)
self.knowledge.add_note(
content=f"代码评审结论:{result}",
concept="code_review"
)
return result