refactor: 全面代码质量提升 — StringList→string[], strict 模式, 死代码清理

架构重构:
- StringList 类替换为不可变 string[](消除 dataVersion hack,Zustand 自然检测变化)
- UndoRedoManager.undo/redo 返回新数组而非原地修改
- 删除 dataVersion 字段和 _bumpVersion()
- 启用 TypeScript strict 模式

死代码清理:
- 删除 string-list.ts, string-list.test.ts, use-path-validation.ts
- Rust AppError 保留供未来使用

功能修复:
- importFromJson 添加 try/catch
- handleClean 使用真实格式验证替代 () => true
- savePaths 保存前调用 backup_registry,处理部分保存失败
- importFromJson 校验非 object 类型输入

i18n 完善:
- MergePreview/StatusBar 硬编码中文 → t() 调用
- 新增 merge.* 和 status.* 翻译键

Rust 改进:
- registry.rs 抽取 load_paths/save_paths 通用函数,消除重复
- registry 新增 6 个单元测试(split/join/roundtrip)
- backup.rs 时间戳加毫秒防覆盖,回退路径改为 home_dir

元数据:
- package.json 名称→patheditor, 版本→4.0.0
- 新增 CHANGELOG.md
- 移除 UndoRedoButtons 废弃注释
- tsconfig 添加 strict:true

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
2026-05-26 00:26:27 +08:00
parent 2ceec54790
commit bfd114d80f
21 changed files with 410 additions and 836 deletions
-35
View File
@@ -1,35 +0,0 @@
import { useState, useCallback } from 'react';
import { invoke } from '@tauri-apps/api/core';
// Rust 端未就绪时的 fallback
const isTauri = typeof window !== 'undefined' && '__TAURI_INTERNALS__' in window;
/** 同步验证(基于本地规则,不含文件系统检查) */
export function validatePath(path: string): boolean {
if (path.includes('%')) return true;
return true; // 文件系统检查需要调用 Rust backend
}
/** 异步验证(调用 Rust validate_path */
export function useAsyncValidation() {
const [cache, setCache] = useState<Map<string, boolean>>(new Map());
const validate = useCallback(async (path: string): Promise<boolean> => {
if (path.includes('%')) return true;
if (cache.has(path)) return cache.get(path)!;
if (isTauri) {
try {
const valid: boolean = await invoke('validate_path', { path });
setCache((prev) => new Map(prev).set(path, valid));
return valid;
} catch {
return true;
}
}
return true;
}, [cache]);
return { validate, cache };
}