Melange 5.0.0-52 版本发布:OCaml 到 JavaScript 编译器的重大更新
Melange 是一个将 OCaml 代码编译为 JavaScript 的工具链,它允许开发者使用 OCaml 强大的类型系统和函数式编程特性来构建前端应用。作为 BuckleScript 的后继者,Melange 提供了更现代化的 OCaml 开发体验,同时保持了与 JavaScript 生态系统的良好互操作性。
本次发布的 5.0.0-52 版本带来了多项重要改进和新特性,包括对 OCaml 5.3 的支持、FFI 系统的增强、代码生成优化以及标准库的更新等。这些变化不仅提升了开发体验,也为 Melange 用户带来了更强大的功能和更好的性能。
核心特性与改进
OCaml 5.3 支持与标准库更新
Melange 5.0.0-52 版本正式添加了对 OCaml 5.3 的支持,这意味着开发者现在可以在最新的 OCaml 版本上使用 Melange。同时,标准库也同步更新到了 OCaml 5.3 的标准库版本,确保了语言特性和标准库功能的一致性。
FFI 系统增强
本次版本对 Melange 的外部函数接口(FFI)系统进行了多项改进:
-
新增了对
[@mel.as "string"]属性的支持,允许在变体定义中指定 JavaScript 端的表示形式。这为与 JavaScript 代码的互操作提供了更大的灵活性。 -
移除了
[@@deriving jsConverter]功能,推荐使用新的[@mel.as "string here"]语法替代,这提供了更直观和灵活的变体转换方式。 -
新增了
[@mel.tag "the_tag"]属性支持,结合[@mel.as]属性和内联记录负载,现在可以表达更复杂的 JavaScript 对象结构,特别是支持了带标签的联合类型。 -
改进了
@mel.send注解的功能,现在可以通过@mel.this明确指定哪个参数代表"self"参数,这使得方法调用的 FFI 定义更加直观和灵活。
代码生成优化
Melange 在这个版本中对生成的 JavaScript 代码进行了多项优化和改进:
-
改进了
for循环、throw和return语句的代码生成格式,使输出代码更加清晰易读。 -
优化了
switch语句的生成,包括更好的缩进处理、移除空的default分支以及冗余的分支等。 -
在 CommonJS 模块系统中,现在使用
module.exports而不是exports.x来导出模块,这符合更常见的 Node.js 模块导出模式。 -
修复了对象初始化代码生成中引用作用域内初始化变量的问题,提高了代码的正确性。
运行时库增强
Melange 的 JavaScript 运行时库在这个版本中获得了多项新功能和改进:
-
新增了
Js.FormData模块,提供了对 Web FormData API 的绑定。 -
新增了
Js.Blob和Js.File模块,提供了对 Web Blob 和 File API 的绑定。 -
在
Js模块顶层添加了TypedArray类型定义,方便处理类型化数组。 -
修复了
Node.Buffer模块中的fromString方法,并新增了fromStringWithEncoding方法,同时绑定了 Node.js 支持的所有 Buffer 编码类型。
破坏性变更
-
移除了
--mel-g编译选项,开发者需要更新构建配置。 -
[@@deriving jsConverter]功能已被移除,需要使用新的[@mel.as]语法替代。 -
@mel.send.pipe注解已被弃用,推荐使用改进后的@mel.send结合@mel.this的方式。 -
不再默认忽略
%mel.raw应用中的警告20(忽略额外参数),开发者需要显式注解这些函数或在项目级别禁用该警告。
性能优化
-
修复了与跨模块优化相关的闭包参数映射计算问题,提高了函数内联的性能。
-
修复了由 dune 的早期
(implicit_transitive_deps false)实现触发的模式匹配中构造函数名称查找相关的崩溃问题。 -
修复了 OCaml 5.2 及以上版本中由于 Lambda IR 生成多个函数节点而导致的优化遗漏问题。
总结
Melange 5.0.0-52 版本标志着这个 OCaml 到 JavaScript 编译器的重要进步。通过支持最新的 OCaml 5.3、增强 FFI 系统、优化代码生成以及丰富运行时库,Melange 为开发者提供了更强大、更灵活的工具来构建类型安全的前端应用。特别是对 JavaScript 互操作性的改进,使得与现有 JavaScript 生态系统的集成更加无缝。
对于现有用户,需要注意几个破坏性变更,特别是 [@@deriving jsConverter] 的移除和 @mel.send.pipe 的弃用。迁移到新的替代方案将带来更清晰和更灵活的代码。
Melange 持续证明自己是一个成熟可靠的 OCaml 到 JavaScript 编译解决方案,这个版本的改进将进一步巩固其在 OCaml 前端开发领域的地位。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00