Files
monkeycode-ai db536cfb2c feat: CodePlay 第二阶段优化 - 转换质量与特性完善
核心修复:
- 修复 LinqToStreamConverter 13 个正则双反斜杠转义错误 (87→0 失败)
- 修复 InheritanceConverter 接口判断逻辑 (纯 I 前缀父类→implements)
- 修复 PropertyConverter init-only 属性组索引

新增转换器 (C# 8-13 特性):
- NullCoalescingConverter: ??、?.、??= 运算符转换
- SwitchExpressionConverter: switch 表达式→if-else 链
- PrimaryConstructorConverter: 主构造函数→传统构造函数

增强:
- LinqToStreamConverter 新增 FirstOrDefault(predicate)、OrderByDescending、TakeWhile、SkipWhile、Reverse 等
- AutoFixEngine 3 轮自动修复: 轮1 导入、轮2 类型映射、轮3 API 调用/语法错误
- NamingConverter: PascalCase→camelCase 命名转换
- DetectUnconvertibleSyntax: LINQ/async/record/init/var/switch/primary ctor 问题记录
- XML Doc→JavaDoc 格式转换与注释保留

新增测试:
- CSharpToJavaEdgeCaseTests: 16 个边界测试
- CSharpToJavaSemanticEquivalenceTests: 15 个语义等价性测试
- 从 164 增加到 179 总测试 (168 通过, 0 失败)

新增文件:
- Pipeline/Converters/NullCoalescingConverter.cs
- Pipeline/Converters/SwitchExpressionConverter.cs
- Pipeline/Converters/PrimaryConstructorConverter.cs
- Converters/CSharpToCppStrategy.cs + CppCodeGenerator.cs
- Tests/Semantics/CSharpToJavaSemanticEquivalenceTests.cs
- Tests/CSharpAdvancedFeaturesTests.cs + CSharp13FeatureTests.cs
Co-authored-by: monkeycode-ai <monkeycode-ai@chaitin.com>
2026-06-16 07:08:11 +00:00

104 lines
3.2 KiB
C#

using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using CodePlay.Core.Models;
using CodePlay.Core.Services;
using CodePlay.Core.Common;
namespace CodePlay.Persistence;
public class DatabaseStorageService : IReportStorageService
{
private readonly AppDbContext _context;
public DatabaseStorageService(AppDbContext context)
{
_context = context;
}
public async Task<ConversionReport> SaveReportAsync(ConversionReport report, string? projectId = null)
{
if (string.IsNullOrEmpty(report.Id))
report.Id = Guid.NewGuid().ToString("N")[..20];
report.ProjectId = projectId ?? "default";
report.CreatedAt = DateTime.UtcNow;
_context.ConversionReports.Add(report);
await _context.SaveChangesAsync();
// 更新项目统计
if (projectId != null)
{
var project = await _context.Projects.FindAsync(projectId);
if (project != null)
{
project.TotalConversions++;
project.UpdatedAt = DateTime.UtcNow;
await _context.SaveChangesAsync();
}
}
return report;
}
public async Task<ConversionReport?> GetReportAsync(string reportId)
{
return await _context.ConversionReports.FindAsync(reportId);
}
public async Task<List<ConversionReport>> GetReportsByProjectAsync(string projectId)
{
return await _context.ConversionReports
.Where(r => r.ProjectId == projectId)
.OrderByDescending(r => r.CreatedAt)
.ToListAsync();
}
public async Task<List<ConversionReport>> GetAllReportsAsync()
{
return await _context.ConversionReports
.OrderByDescending(r => r.CreatedAt)
.ToListAsync();
}
public async Task DeleteReportAsync(string reportId)
{
var report = await _context.ConversionReports.FindAsync(reportId);
if (report != null)
{
_context.ConversionReports.Remove(report);
await _context.SaveChangesAsync();
}
}
public async Task<ConversionStatistics> GetStatisticsAsync()
{
var reports = await _context.ConversionReports.ToListAsync();
var projects = await _context.Projects.ToListAsync();
return new ConversionStatistics
{
TotalConversions = reports.Count,
TotalProjects = projects.Count,
ConversionsByLanguage = reports.GroupBy(r => r.TargetLanguage)
.ToDictionary(g => g.Key, g => g.Count()),
AverageLinesConverted = reports.Any() ? reports.Average(r => r.LinesConverted) : 0,
TotalIssuesDetected = reports.Sum(r => r.IssueCount),
TotalTODOs = reports.Sum(r => r.TodoCount)
};
}
}
public static class PersistenceServiceExtensions
{
public static IServiceCollection AddPersistence(this IServiceCollection services, string connectionString)
{
services.AddDbContext<AppDbContext>(options =>
options.UseSqlite(connectionString));
services.AddScoped<IReportStorageService, DatabaseStorageService>();
return services;
}
}