在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

JetBrains 元编程系统支持面向语言编程和 DSL

  • 2009-01-03
  • 本文字数:1989 字

    阅读完需:约 7 分钟

Meta Programming System( MPS )是 JetBrains 开发的面向语言编程的新工具。开发者可以用它扩展编程语言,也可以用它为企业应用创建领域特定语言( DSLs )。JetBrains 开发团队近日宣布推出 MPS 的 beta 版。

MPS 提供的软件开发环境可以创建新的定制语言,也可以扩展现有语言,然后用它们开发面向领域的应用。MPS 还可以定义新语言的类型系统、约束和专门的编辑器。MPS 用一棵抽象句法树( AST )来维护代码。AST 由节点组成,节点又包含属性、子节点和引用,程序代码就靠 AST 和这些节点完整地表达出来。创建新语言的时候,开发者定义代码编排和表达的规则,还可以规定语言类型系统的组成元素。MPS 凭借这些规则即时检查程序代码,减少用新语言编程的出错机会。MPS 还采用了代码生成的办法:用新语言在更高的层次上表达,然后 MPS 生成 Java、XML、HTML、JavaScript 等语言的可编译代码。用 MPS 建立新语言的时候,必须从 BaseLanguage 扩展。MPS 已经提供了一些常用的 BaseLanguage 扩展,协助开发者处理字符串、容器、日期、正则表达式等语言成分。

面向语言编程( LOP )是一种新的编程风格。在 LOP 里,语言好比传统编程中的类和方法,是搭建软件所用的建筑材料,开发者根据需要,或创建专门的新语言,或对旧语言作扩展。Martin Fowler 曾撰文说明用语言工作台作为IDE 工具去实现面向语言编程,也介绍过用MPS 作为语言工作台。

MPS 还适合用来创建 DSL,因为它可以为任意新语言实现定制的语言编辑器和其他约束条件。不熟悉传统编程的领域专家,可以用本行专业术语构成的 DSL 在 MPS 里工作。

MPS 软件对所有人免费,其中大部分代码还会以 Apache 2.0 许可开源。MPS 起初是 JetBrains 从 2003 年开始的一个研究项目,JetBrains 员工已经用它开发过一些新产品。目前团队的主要目标是下个月的 Beta 2 版,以及 2009 年第一季度的 1.0 版。11 月的时候 JetBrains 还发布过 IDE 产品 IntelliJ IDEA 的 8.0 版,团队协作工具的 TeamCity 的 4.0 版。MPS beta 版下载概念说明,请参阅他们的网站。网站上还有用户指南教程和专门的博客站点介绍MPS 工具的详细信息。

InfoQ 采访了 JetBrains 公司 MPS 核心开发者 Konstantin Solomatov,向他询问 MPS 的软件功能和项目未来的路线图。InfoQ 问及 MPS 与其它建模及代码生成工具的对比,比如 Eclipse Modeling Framework( EMF )、openArchitectureWare( oAW )。

MPS 所依据的概念与 EMF、oAWE 类似。三种技术都可以创建元模型,也都可以描述编辑器、自动完成、模型转换(MPS 称之为“生成器”)等方面。EMF 模型通常用图形编辑器来编辑,你可以用方框线条绘制出代表各实体的图解。这种做法对某些领域很有效,比如绘制 ER 图。但我们认为不适宜用 EMF 创建任何相对复杂的软件。 oAW 最值得注意的部分的 xText 框架,它定义的文字型 DSL 可以被解析成 EMF 模型。不过用这种方式创建语言有其局限。如果在同一个文件里混用多种语言,必须保证文法不会出现二义性,也就是说所有的输入都只能存在一种解释。文本型的语言很难保证这一点。比方说有两家厂商都想为 Java 补充一种支持金融货币的语言,而两家厂商都在语言里新增了 Money 类型。那么,如果代码里两种类型都用到了,我们解析文件的时候就无法分辨一个 Money 类型的变量到底属于哪一种语言。

MPS 把模型表示成一棵可以直接编辑的抽象句法树。在 MPS 里,代码看似文本,在很多方面的表现也如同文本,但由于我们从不需要在代码和文本之间来回转换,也就完全不用担心文法上的二义性。

好像 MPS 还可以编排语言的文法。这项功能与 Oslo OMeta 等工具的类似功能有何异同?

因为 MPS 不是基于文本的,它没有任何文本上的文法。定义语言就是定义它的抽象句法树,它的抽象文法。而没有文本上的文法,也就没有语言兼容的问题,语言从定义上就是兼容的。Oslo 和 Ometa 都是基于文本的,因此都有类似于 xText 的问题。 Oslo 和 Ometa 只能定义语言的解析器,与之相比,MPS 的功能更多,能定义语言的编辑器、约束、类型系统、数据流分析,还有生成器。

JetBrains 开发团队在那些产品中采用了 MPS 作为建模和开发工具?

其中一个是代号为“Charisma”的问题跟踪系统,它也会在 2009 年第一季度公开发布。它是完全用 MPS 编写的。 Charisma 也成了 MPS 本身所用的问题跟踪系统,还被用到 TeamCity 凳产品中。在创建 Charisma 的时候,我们开发了一门完整的 Web 开发语言,在 MPS 中扮演相当于 J2EE 的角色。

MPS 项目的未来路线图如何,有何新特性?

本次 Beta 的主要目的是收集 MPS 用户的反馈,并且决定将来的路线图。我们已经有 1.0 的计划,不过 1.0 版不会有任何大的变动和新特性。我们将在 2009 第一季度发布完 MPS 1.0 之后,再公布更长远的路线图。届时计划中应该会包括调试器和用于定义 UI 的若干新语言。

查看英文原文: JetBrains Meta Programming System Supports Language Oriented Programming and DSLs

2009-01-03 12:476607
用户头像

发布了 225 篇内容, 共 75.6 次阅读, 收获喜欢 53 次。

关注

评论

发布
暂无评论
发现更多内容

Flink 读写多套 Kerberos 认证的 Kafka 方案

移动云大数据

SAP | 如何全局处理消息文本

暮春零贰

SAP 10月月更 动态消息

如何引发一场信创负载均衡领域的大变革?

通明湖

负载均衡 信创

浅谈长连接负载均衡

捉虫大师

负载均衡 长连接 10月月更

SAP | ABAP程序结构中的处理块

暮春零贰

SAP 模块化 10月月更

英特尔财报彰显系统级代工渐成气候

科技之家

流式计算常见的开源实现

穿过生命散发芬芳

10月月更 流式计算

阿里最新产,SpringCloud微服务核心技术全解手册Github星标50k

程序员小毕

Java 微服务 后端 SpringCloud springcloudAlibaba

可观测可回溯 | Continuous Profiling 实践解析

阿里巴巴云原生

阿里云 云原生 可观测

可观测实践|如何使用阿里云 Prometheus 观测 ECS 应用

阿里巴巴云原生

阿里云 云原生

极客时间运维进阶训练营第二周作业

好吃不贵

用芯弹一首《大加洛普舞曲》:从AI-ISP,透视vivo的双芯之路

脑极体

消失与存续——应用交付行业的跌宕演进

通明湖

负载均衡 高可用 云原生 信创

ALL in ONE!博睿数据隆重举行ONE 2.0全面上线仪式

博睿数据

可观测性 智能运维 博睿数据 ONE平台

华为云智能云接入ICA,让世界距离更近

科技怪授

ica

极光笔记 | 极光clickhouse千亿级数据分析实践之路

极光GPTBots-极光推送

千锋沈阳前端怎么样?学员真实案例

千锋IT教育

企业上云也可以很智能,智能云接入ICA替企业搭建“上云梯”

科技怪授

ica

11 月亚马逊云科技培训与认证课程,精彩不容错过!

亚马逊云科技 (Amazon Web Services)

培训与认证

企业数据上云,怎能少的了华为云企业交换机ESW?

科技怪授

ESW

想在杭州学前端,千锋IT培训怎么样?学员真实案例

千锋IT教育

“程”风破浪的开发者|【模块-Java布局】十分钟挑战鸿蒙Codelab组件

liuzhen007

OpenHarmony “程”风破浪的开发者

一文看懂Htmx

天择

JavaScript htmx

NFT质押挖矿分币系统开发模式定制

开发微hkkf5566

穿越周期性调整 英特尔多举措布局半导体产业

科技之家

拒绝繁琐,华为云企业交换机ESW就是要让数据上云一步到位

科技怪授

ica

首次!龙蜥社区生态用户实践精选集发布在即

OpenAnolis小助手

开源 龙蜥社区 生态伙伴 厂商 案例集

政务数据安全解决方案

前嗅大数据

政务 基础数据方案 数据方案

关于软件系统的帮助文档页面,你该知道的那些事儿

Baklib

帮助文档

网络安全hw蓝队实战之溯源

网络安全学海

网络安全 安全 信息安全 渗透测试 漏洞挖掘

千锋大连“匠心8载 感谢有你”周年庆典隆重举行

千锋IT教育

JetBrains元编程系统支持面向语言编程和DSL_JetBrains_Srini Penchikala_InfoQ精选文章