"""
使用LLM的示例
=============

演示如何配置和使用LLM客户端进行精确的任务匹配评分。
"""

import sys
from pathlib import Path

sys.path.insert(0, str(Path(__file__).parent.parent))

from repo_analysis import RepoContextPipeline, FilterAndRankRepos


# 示例LLM客户端实现
def example_llm_client(messages, json_format=False):
    """
    这是一个示例LLM客户端函数。
    您需要替换为实际的LLM API调用。
    
    Args:
        messages: 消息列表，格式为 [{"role": "system/user/assistant", "content": "..."}]
        json_format: 是否要求返回JSON格式
        
    Returns:
        Dict 或 List[Dict]，取决于请求
    """
    # 示例：使用OpenAI API
    # import openai
    # response = openai.ChatCompletion.create(
    #     model="gpt-4",
    #     messages=messages,
    #     response_format={"type": "json_object"} if json_format else None
    # )
    # return response.choices[0].message.content
    
    # 示例：使用自定义API
    # import requests
    # response = requests.post(
    #     "https://your-api-endpoint.com/chat",
    #     json={"messages": messages, "json_mode": json_format}
    # )
    # return response.json()
    
    # 占位符返回
    print("⚠️  请实现您的LLM客户端函数")
    return {
        "Algorithm Match": 1,
        "Domain Applicability": 1,
        "Data Processing Capability": 1,
        "Model Implementation Quality": 1,
        "Code Readability": 1,
        "Structure Organization": 1,
        "Experimental Results": 1,
        "Scalability": 1,
        "Overall Score": 7
    }


def example_single_repo_with_llm():
    """单仓库分析 + LLM评分"""
    print("=" * 80)
    print("单仓库LLM评分示例")
    print("=" * 80)
    
    repo_path = '/path/to/your/repository'
    
    # 使用LLM客户端创建pipeline
    pipeline = RepoContextPipeline(
        repo_path=repo_path,
        llm_client=example_llm_client
    )
    
    # 运行分析 (会自动使用LLM进行任务匹配)
    results = pipeline.run(
        task="实现一个用于文本分类的BERT模型",
        max_tokens=8000
    )
    
    print("\n" + pipeline.get_summary())


def example_multi_repo_with_llm():
    """多仓库筛选 + LLM批量评分"""
    print("\n" + "=" * 80)
    print("多仓库LLM批量评分示例")
    print("=" * 80)
    
    repo_paths = [
        '/path/to/repo1',
        '/path/to/repo2',
        '/path/to/repo3',
    ]
    
    # 使用LLM客户端创建筛选器
    filter_ranker = FilterAndRankRepos(
        llm_client=example_llm_client,
        max_workers=2  # 减少并行数以避免API限流
    )
    
    # 执行筛选 (会自动使用LLM批量评分)
    task = "实现一个推荐系统，包含协同过滤和深度学习模型"
    top_repos = filter_ranker.filter_and_rank(
        task=task,
        repo_paths=repo_paths,
        top_k=2,
        use_llm=True,  # 使用LLM
        batch_size=3  # 每次LLM调用评分3个仓库
    )
    
    # 显示结果
    from repo_analysis.multi_repo_filter import print_ranking_results
    print_ranking_results(top_repos)


def main():
    print("\n⚠️  注意: 这是一个示例脚本。")
    print("您需要在 example_llm_client 函数中实现您的LLM API调用。\n")
    
    # 运行示例
    # example_single_repo_with_llm()
    # example_multi_repo_with_llm()
    
    print("\n请取消注释上面的函数调用来运行示例。")


if __name__ == '__main__':
    main()

