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 报告。
在这个版本中,主要完成了解释器相关的大量增强,并修复了一些缺陷。一些主要的增强说明如下:
- 现在,我们可以在复合表达式中使用行注释,如:
{{
# 尝试改变工作路径到 `/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
}}
如上所示,我们可在复合表达式中,使用 #
或者 //
定义一个行注释。
- 可使用
"""
(三双引号,triple-double-quote)定义多行文本字符串,将原样保留其中的 ASCII 制表符或者新行符(U+0009 TAB、U+000A LF、U+000D CR),单引号('
)以及不连续出现三次的双引号("
)无需使用转义符号。类似地,可使用'''
(三单引号,triple-single-quote)定义多行文本字符串,将原样保留其中的 ASCII 制表符或者新行符,双引号("
)以及不连续出现三次的单引号('
)无需使用转义符号。如:
{
id: 1234567890UL,
nickname: "David",
signature:
"""
一个
被'程序'耽误的
"文艺"青年。
""",
}
三单引号和三双引号的区别在于,使用三双引号时,将对包含其中的表达式进行求值,并将结果做字符串化之后和其他部分串接在一起作为最终结果,当使用三单引号时,将忽略其中的求值表达式。
- 在参数化数据或者 eJSON 当中,支持使用
[!
和]
包围来定义元组。如:
<iterate on [! 1, 1, 2, 3, 5 ] >
...
</iterate>
在 HVML 中,元组是具有固定大小的数组,可修改其中的成员,但不能删除或者新增成员。相比数组,元组的内存消耗更低。
- 支持字符串常量语法,用于在
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-space
、list-style-type
、quotes
、counter
和counters
等。
- 错误修正:
- 对未转义的字符串中的 C0 控制字符,eJSON 解析器将报错。
hvml
和iterate
元素中的表达式会被错误地求值两次。
HVML 规范 1.0 RC8
我们于 2022 年 11 月 30 日发布了 HVML 规范 1.0 RC8 版本,并进入到 HVML 规范的 1.0 RC9 版本。
在 RC8 版本中,我们围绕 HVML 语言规范主要做了如下调整及增强:
- 使用反引号属性值语法定义异常或错误名称。
- 扩展 JSON 语法,支持三单引号(
'''
)。 - 微调字符串化处理规则,避免使用新行符,转而使用逗号和分号。
- 调整某些术语:
- 求值表达式:Hybrid evaluation expression (HEE)。
- 复合求值表达式:Compound hybrid evaluation expression(CHEE)。
- 参数化数据:Parameterized Data。
- 参数化字符串:Parameterized String。
$EJSON
重命名为$DATA
。$DATA.numberify
重命名为$DATA.numerify
。- 调整有关求值表达式语法、eJSON 语法的章节。
有关详情,可点击阅读如下链接:
社区活动
2022 年 11 月,社区小伙伴们围绕如下方面做出了贡献:
- 更新 0.9.0 版本的 AUR 包描述信息,由 @taotieren 提交拉取请求。
下一步计划
2022 年 12 月底,我们将发布 PurC 0.9.4 版本,预期功能包括:
- 增强
update
元素以支持intersect
、subtract
和xor
等操作以及individually
副词属性。 - 对
request
元素的完整支持。 - 继续增强 Foil 渲染器,完成除表格以外的布局支持。
2023 年 01 月底,我们将发布 PurC 0.9.6 版本,预期功能包括:
- 支持 CSS Level 3 选择器规范,完善预定义
$DOC
变量各属性获取器及设置器。 - 增强文档定位功能。
- 将来自外部数据源的
text/html
类型装载为原生实体对象,以方便对网页内容的处理和操作。 - Foil 字符渲染器支持表格布局。
2023 年 02 月底,我们将发布 PurC 0.9.8 版本,预期功能包括:
- 内存及性能的初步优化。
- 预定义变量规范中定义的,但尚未完成的动态对象属性及方法。
- 全功能的 Foil 字符渲染器,支持多窗口、构件及交互。
2023 年 3 月底,我们将发布 PurC 0.9.9 版本(PurC 1.0.0 Beta 版本),预期功能包括:
- 对 Windows 平台的支持。
- 预定义动态对象的完整实现。
常见问题及解答
Q:HVML 是针对嵌入式和物联网使用的吗?
A:不仅仅是。HVML 是一种通用的胶水语言,HVML 的目标平台包括传统的桌面、服务器、智能手机、平板、嵌入式设备和物联网设备。
Q:HVML 是打算取代现有的 Web 前端开发技术,比如 JavaScript 吗?
A:没有这个计划。HVML 的渲染器会用到 Web 前端技术,但 HVML 的目标并不是取代现有的 Web 前端开发技术,而是面向未来的多屏协同场景下的需求,为应用的跨端运行提供全新的技术框架,同时作为合璧操作系统(HybridOS)的首选编程语言。
Q:在哪里可以看到 HVML 相关的源代码?
A:HVML 相关文档及代码仓库在 https://github.com/HVML 上开源发布,其中包括:
- HVML 解释器(PurC):https://github.com/HVML/PurC
- HVML 图形渲染器(xGUI Pro):https://github.com/HVML/xGUI-Pro
- 扩展 WebKit 引擎(仅源代码包)
- 开发用 HVML 字符渲染器(PurC Midnight Commander):https://github.com/HVML/PurC-Midnight-Commander
Q:有可以直接下载安装的软件包吗?
A:因开发团队精力有限,目前尚没有制作针对各个操作系统的安装包,但来自开源社区的小伙伴们已经积极行动,帮助我们完成了一些 Linux 发行版的安装包。我们将这些软件包收集到了如下页面,可访问查看:
https://hvml.fmsoft.cn/software
Q:如何赞助 HVML 相关的项目?
A:个人打赏性质的赞助,您可以点击文后的原文链接。大额的赞助,可以联系我们留下联系方式,或者致信 hvml@fmsoft.cn
,我们会及时联系您。