"""
完整Pipeline示例
================

演示如何使用完整的 RepoContextPipeline 进行仓库分析和任务匹配。
"""

import sys
from pathlib import Path

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

from repo_analysis import RepoContextPipeline, create_task_dict


def main():
    # 替换为您的仓库路径
    repo_path = '/path/to/your/repository'
    
    print("=" * 80)
    print("完整Pipeline示例")
    print("=" * 80)
    
    # 创建任务描述
    task = create_task_dict(
        description="实现一个基于PyTorch的图像分类模型，使用ResNet架构",
        keywords=["pytorch", "image", "classification", "resnet", "deep learning"],
        task_type="machine_learning"
    )
    
    print(f"\n任务描述: {task['task_description']}")
    print(f"关键词: {', '.join(task['keywords'])}\n")
    
    # 创建pipeline
    print("初始化pipeline...")
    pipeline = RepoContextPipeline(
        repo_path=repo_path,
        llm_client=None  # 不使用LLM，使用启发式评分
    )
    
    # 运行完整分析
    print("\n运行完整分析...")
    results = pipeline.run(
        task=task,
        max_tokens=6000,
        output_file='analysis_results.json',
        format='json'
    )
    
    # 显示摘要
    print("\n" + "=" * 80)
    print(pipeline.get_summary())
    print("=" * 80)
    
    # 显示任务相关性
    if results['task_relevance']:
        print("\n任务相关性分析:")
        print(f"  - 相关性分数: {results['task_relevance']['relevance_score']:.2f}")
        print(f"  - 评分方法: {results['task_relevance']['scoring_method']}")
        
        dimensions = results['task_relevance'].get('dimensions', {})
        if dimensions:
            print("\n  维度分数:")
            for dim, score in dimensions.items():
                print(f"    - {dim}: {score:.2f}")
    
    print("\n结果已保存到: analysis_results.json")
    print("\n分析完成!")


if __name__ == '__main__':
    main()

