Shiki v2.2.0 发布:语法高亮引擎的重大更新
Shiki 是一个基于 TextMate 语法的语法高亮引擎,它能够为代码块提供精确的语法高亮效果。与传统的正则表达式高亮方案不同,Shiki 使用 TextMate 的语法定义文件(.tmLanguage),这使得它能够提供与主流编辑器(如 VS Code)一致的语法高亮体验。
重大变更
在 v2.2.0 版本中,Shiki 默认启用了运行时警告功能。这是一个重大变更,意味着开发者现在会默认看到更多关于潜在问题的警告信息。这一变化旨在帮助开发者更早地发现和解决代码高亮相关的问题。
新特性
改进的警告信息
新版本对警告信息进行了改进,使其更加清晰和有用。这些改进包括更详细的错误描述和更好的格式化输出,帮助开发者更快地定位问题。
支持嵌套装饰
Shiki 现在允许装饰器嵌套,即使它们与父装饰器共享"边缘"。这一改进为代码高亮提供了更大的灵活性,使得更复杂的装饰场景成为可能。
JavaScript 引擎更新
JavaScript 引擎部分进行了依赖更新,并支持了更多语言。这意味着开发者现在可以使用更多编程语言的语法高亮功能,同时也能享受到最新的依赖包带来的性能改进和安全更新。
Markdown-it 异步支持
对于使用 markdown-it 的开发者来说,新版本增加了对 markdown-it-async 集成的支持。这使得在异步环境中使用 Shiki 变得更加方便,特别是在处理大量代码块时。
Rehype 回退语言支持
在 lazy 模式下,Rehype 插件现在支持 fallbackLanguage 选项。当指定的语言不可用时,系统会自动回退到备用语言的高亮方案,这提高了系统的健壮性和用户体验。
问题修复
依赖缺失警告
新版本增加了对缺失依赖的警告功能,帮助开发者及时发现和解决依赖问题。
引擎选项要求
修正了 createHighlighterCore 中 engine 选项的标记问题,现在正确地将其标记为必需选项。
彩色括号修复
彩色括号功能现在使用对象样式的 htmlStyle,这解决了之前版本中的一些样式问题。
核心功能改进
核心部分现在对 engine 选项采用了软性要求,提高了灵活性。
转换器修复
恢复了缺失的 createCommentNotationTransformer 功能,解决了之前版本中的相关问题。
总结
Shiki v2.2.0 带来了多项重要更新和改进,包括默认启用的运行时警告、更好的嵌套装饰支持、更多语言支持以及多项问题修复。这些变化使得 Shiki 作为一个语法高亮引擎更加健壮和灵活,能够满足开发者更复杂的需求。对于正在使用或考虑使用 Shiki 的开发者来说,升级到 v2.2.0 版本将带来更好的开发体验和更强大的功能支持。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0131
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00