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