"""
基础使用示例
=============

演示如何使用 SimplePipeline 进行简单的仓库分析。
"""

import sys
from pathlib import Path

# 添加包路径
sys.path.insert(0, str(Path(__file__).parent.parent))

from repo_analysis import SimplePipeline


def main():
    # 替换为您的仓库路径
    repo_path = '/path/to/your/repository'
    
    print("=" * 80)
    print("基础仓库分析示例")
    print("=" * 80)
    print(f"\n分析仓库: {repo_path}\n")
    
    # 创建简单pipeline
    pipeline = SimplePipeline(repo_path)
    
    # 获取关键模块
    print("正在提取关键模块...")
    key_modules = pipeline.get_key_modules(top_k=10)
    
    print(f"\n找到 {len(key_modules)} 个关键模块:\n")
    for i, module in enumerate(key_modules, 1):
        print(f"{i}. {module['path']}")
        print(f"   重要性分数: {module['importance_score']:.2f}")
        print(f"   模块ID: {module['id']}\n")
    
    # 获取上下文 (字典格式)
    print("\n正在构建上下文...")
    context = pipeline.get_context(max_tokens=4000, format='dict')
    
    print("\n仓库概览:")
    overview = context['repository_overview']
    print(f"  - 模块总数: {overview['total_modules']}")
    print(f"  - 类总数: {overview['total_classes']}")
    print(f"  - 函数总数: {overview['total_functions']}")
    print(f"  - 代码行数: {overview['total_lines']}")
    print(f"  - 关键技术: {', '.join(overview['key_technologies'][:10])}")
    
    # 获取上下文 (字符串格式，LLM友好)
    print("\n正在生成LLM友好格式...")
    context_str = pipeline.get_context(max_tokens=4000, format='string')
    
    # 保存到文件
    output_file = 'repo_context.txt'
    with open(output_file, 'w', encoding='utf-8') as f:
        f.write(context_str)
    
    print(f"\n上下文已保存到: {output_file}")
    print("\n分析完成!")


if __name__ == '__main__':
    main()

