写点什么

HVML 解释器 PurC 0.9.2 发布;持续演进!

作者:hvmlenvoy
  • 2022-12-27
    北京
  • 本文字数:3306 字

    阅读完需:约 11 分钟

HVML 是由中国首款开源基础软件 MiniGUI 的作者魏永明设计的描述式编程语言,也是世界首款可编程标记语言。


从 2020 年 5 月开始构思算起,魏永明带领团队历经两年多的时间,于 2022 年 7 月 31 日正式开源发布了 HVML 规范文档以及解释器、渲染器等软件,总代码行数逾百万!


面向未来多屏协同场景下的应用开发需求,HVML 为应用的跨端运行提供了全新的技术框架。HVML 蕴含了大量新颖的设计和独创的思想,是魏永明及其团队近三十年基础软件开发经验的结晶,一经发布便获得了业界的广泛关注。


本文将向读者介绍 HVML 社区的近期动态。

软件及文档的更新

HVML 解释器 PurC 0.9.2

2022 年 11 月 30 日,HVML 社区发布 PurC 0.9.2,这也是 PurC 1.0.x 的第四个 alpha 版本。若发现任何错误、不兼容性和问题,请向 https://github.com/HVML/PurC/issues 报告。


在这个版本中,主要完成了解释器相关的大量增强,并修复了一些缺陷。一些主要的增强说明如下:


  1. 现在,我们可以在复合表达式中使用行注释,如:


{{    # 尝试改变工作路径到 `/root` 目录下    $SYS.cwd(! '/root') &&        // 如果成功则调用 $FS.list 获得该目录下的所有目录项对象数组        $FS.list ||            # 否则向标准输出($STREAM.stdout)打印提示信息            $STREAM.stdout.writelines('Cannot change directory to "/root"');            // 并改变工作路径到 `/` 下            $SYS.cwd(! '/' ) &&                // 若成功,则获得该目录下所有目录项对象数组                $FS.list ||                    // 否则将 `false` 作为该 CHEE 的最终求值结果                    false}}
复制代码


如上所示,我们可在复合表达式中,使用 # 或者 // 定义一个行注释。


  1. 可使用 """(三双引号,triple-double-quote)定义多行文本字符串,将原样保留其中的 ASCII 制表符或者新行符(U+0009 TAB、U+000A LF、U+000D CR),单引号(')以及不连续出现三次的双引号(")无需使用转义符号。类似地,可使用 '''(三单引号,triple-single-quote)定义多行文本字符串,将原样保留其中的 ASCII 制表符或者新行符,双引号(")以及不连续出现三次的单引号(')无需使用转义符号。如:


{    id:         1234567890UL,    nickname:   "David",    signature:"""一个
被'程序'耽误的
"文艺"青年。""",}
复制代码


三单引号和三双引号的区别在于,使用三双引号时,将对包含其中的表达式进行求值,并将结果做字符串化之后和其他部分串接在一起作为最终结果,当使用三单引号时,将忽略其中的求值表达式。


  1. 在参数化数据或者 eJSON 当中,支持使用 [! 和 ] 包围来定义元组。如:


<iterate on [! 1, 1, 2, 3, 5 ] >    ...</iterate>
复制代码


在 HVML 中,元组是具有固定大小的数组,可修改其中的成员,但不能删除或者新增成员。相比数组,元组的内存消耗更低。


  1. 支持字符串常量语法,用于在 catch 和 except 元素中定义异常的名称。如:


    <choose on $locales in "#the-footer" by "KEY: AS '$global.locale'">        <update on "p > a" at 'textContent attr.href attr.title' with ["$?.se_name", "$?.se_url", "$?.se_title"] />        <catch for `NoData`>            <update on 'p' at 'textContent' with 'You forget to define the $locales/$global variables!' />        </catch>        <catch for `NoSuchKey`>            <update on 'p > a' at 'textContent attr.href attr.title' with ["Google", "https://www.google.com", "Google"] />        </catch>        <catch for `ANY`>            <update on 'p' at 'textContent' with 'Bad $locales/$global data!' />        </catch>    </choose>
复制代码


如此,当我们在 catch 或者 except 当中使用了不正确的异常名称时,将在 HVML 程序的解析阶段报错。


本版本全部的错误修复、增强、优化和调整罗列如下:


  • 变化:

  • 更改了某些过长的接口名称。

  • 调整:

  • 微调了 HVML 生成的文档的序列化格式,方便开发者查看。

  • 微调了某些 API 的描述。

  • 增强:

  • 支持三单引号语法定义多行字符串。

  • 使用三双引号语法时,其中的求值表达式将被求值。

  • 复合表达式支持行注释。

  • 支持元组。

  • 支持字符串常量语法,用于在 catch 和 except 元素中定义异常的名称。

  • 在预定义变量的实现中,使用线性容器接口来替代数组,以支持更多的容器类型。

  • 添加新的接口:purc_variant_make_atom()

  • purc 命令行工具可支持使用 URL 查询字符串(RFC 3986)来指定传递给 HVML 协程的请求参数。

  • purc 命令行工具的 Foil 渲染器支持更多的 CSS 属性,比如 white-spacelist-style-typequotescounter 和 counters 等。

  • 错误修正:

  • 对未转义的字符串中的 C0 控制字符,eJSON 解析器将报错。

  • hvml 和 iterate 元素中的表达式会被错误地求值两次。

HVML 规范 1.0 RC8

我们于 2022 年 11 月 30 日发布了 HVML 规范 1.0 RC8 版本,并进入到 HVML 规范的 1.0 RC9 版本。


在 RC8 版本中,我们围绕 HVML 语言规范主要做了如下调整及增强:


  1. 使用反引号属性值语法定义异常或错误名称。

  2. 扩展 JSON 语法,支持三单引号(''')。

  3. 微调字符串化处理规则,避免使用新行符,转而使用逗号和分号。

  4. 调整某些术语:

  5. 求值表达式:Hybrid evaluation expression (HEE)。

  6. 复合求值表达式:Compound hybrid evaluation expression(CHEE)。

  7. 参数化数据:Parameterized Data。

  8. 参数化字符串:Parameterized String。

  9. $EJSON 重命名为 $DATA

  10. $DATA.numberify 重命名为 $DATA.numerify

  11. 调整有关求值表达式语法、eJSON 语法的章节。


有关详情,可点击阅读如下链接:


社区活动

2022 年 11 月,社区小伙伴们围绕如下方面做出了贡献:


  1. 更新 0.9.0 版本的 AUR 包描述信息,由 @taotieren 提交拉取请求。

下一步计划

2022 年 12 月底,我们将发布 PurC 0.9.4 版本,预期功能包括:


  1. 增强 update 元素以支持 intersectsubtract 和 xor 等操作以及 individually 副词属性。

  2. 对 request 元素的完整支持。

  3. 继续增强 Foil 渲染器,完成除表格以外的布局支持。


2023 年 01 月底,我们将发布 PurC 0.9.6 版本,预期功能包括:


  1. 支持 CSS Level 3 选择器规范,完善预定义 $DOC 变量各属性获取器及设置器。

  2. 增强文档定位功能。

  3. 将来自外部数据源的 text/html 类型装载为原生实体对象,以方便对网页内容的处理和操作。

  4. Foil 字符渲染器支持表格布局。


2023 年 02 月底,我们将发布 PurC 0.9.8 版本,预期功能包括:


  1. 内存及性能的初步优化。

  2. 预定义变量规范中定义的,但尚未完成的动态对象属性及方法。

  3. 全功能的 Foil 字符渲染器,支持多窗口、构件及交互。


2023 年 3 月底,我们将发布 PurC 0.9.9 版本(PurC 1.0.0 Beta 版本),预期功能包括:


  1. 对 Windows 平台的支持。

  2. 预定义动态对象的完整实现。

常见问题及解答

Q:HVML 是针对嵌入式和物联网使用的吗?


A:不仅仅是。HVML 是一种通用的胶水语言,HVML 的目标平台包括传统的桌面、服务器、智能手机、平板、嵌入式设备和物联网设备。


Q:HVML 是打算取代现有的 Web 前端开发技术,比如 JavaScript 吗?


A:没有这个计划。HVML 的渲染器会用到 Web 前端技术,但 HVML 的目标并不是取代现有的 Web 前端开发技术,而是面向未来的多屏协同场景下的需求,为应用的跨端运行提供全新的技术框架,同时作为合璧操作系统(HybridOS)的首选编程语言。


Q:在哪里可以看到 HVML 相关的源代码?


A:HVML 相关文档及代码仓库在 https://github.com/HVML 上开源发布,其中包括:


  1. HVML 解释器(PurC):https://github.com/HVML/PurC

  2. HVML 图形渲染器(xGUI Pro):https://github.com/HVML/xGUI-Pro

  3. 扩展 WebKit 引擎(仅源代码包)

  4. 开发用 HVML 字符渲染器(PurC Midnight Commander):https://github.com/HVML/PurC-Midnight-Commander


Q:有可以直接下载安装的软件包吗?


A:因开发团队精力有限,目前尚没有制作针对各个操作系统的安装包,但来自开源社区的小伙伴们已经积极行动,帮助我们完成了一些 Linux 发行版的安装包。我们将这些软件包收集到了如下页面,可访问查看:


https://hvml.fmsoft.cn/software

用户头像

hvmlenvoy

关注

还未添加个人签名 2022-12-06 加入

还未添加个人简介

评论

发布
暂无评论
HVML 解释器 PurC 0.9.2 发布;持续演进!_编程语言_hvmlenvoy_InfoQ写作社区