内容简介:自原型搭建已过去两个多月,现在实现了木兰编程语言一些基本的功能。正值搬家到 OSChina,作一阶段小结。 功能 以下示例都选自测试用例。 调用现有 Python 库如草蟒: using * in 海龟 颜色("黄色", "红色") ...
自原型搭建已过去两个多月,现在实现了木兰编程语言一些基本的功能。正值搬家到 OSChina,作一阶段小结。
功能
以下示例都选自测试用例。
using * in 海龟
颜色("黄色", "红色")
开始填充()
for 拐数 in 0..4 {
前进(200)
右转(144)
}
结束填充()
主循环()
类型:
type Animal {
func getName() {
return 1
}
}
type Person : Animal {
{}
}
print(Person.getName())
函数:
func increment(step) {
func add(n) {
return n + step
}
return add
}
print(increment(10)(1))
流程控制:
print(false ? 2 : 1)
sum = 0
number = 1
while number < 4 {
sum = sum + number
number = number + 1
}
print(sum)
中文报错信息
上述基本功能之外,对部分报错信息进行了加工,使之更易懂好读。
比如下面的死递归:
func f() {
f()
}
f()
运行报错信息如下:
(..•˘_˘•..) 递归过深。请确认: 1、的确需要递归 2、递归的收敛正确
见第2行:f()
调用层级如下
第2行:f()
【中略 995 行】
第2行:f()
第4行:f()
又如此段代码:
func add(number) {
return number1+1
}
func output(number) {
print(number)
}
output(add(2))
运行报错如下:
(..•˘_˘•..) 请先定义'number1'再使用
见第2行:return number1+1
调用层级如下
第7行:output(add(2))
语法分析的错误信息亦然。比如现在尚不支持空行,于是下面的代码:
print(2)
会报错如下:
错误.语法错误: 文件 "测试/错误处理/空行.ul", 第1行, 第1列, 没认出这个词 "换行"
^
代码统计
由于实现机制是将源码转换为 Python 的抽象语法树(AST)后调用 exec 执行,因此主要代码量在词法分析器和语法分析器(包括 AST 转换)。下面是几个主要部分的代码量统计(使用 scc,包括空行和注释,木兰的.ul
代码统计使用--count-as ul:javascript
参数)
- 测试
- 木兰测试用例:465
测试.py
,运行测试的脚本:123test语法树.py
,确保生成的语法树与原始版本一致:52
- 实现:1287
- (语法)
分析器.py
,包括 AST 转换:569 语法树.py
,功用/语法树处理.py
,包括对 ast 库的中文封装:214词法分析器.py
,主要是词法规则:110中.py
,主程序:56功用/反馈信息.py
,报错信息中文化:43环境.py
,全局变量:30
- (语法)
下一步
除了继续补全木兰语言本身功能之外,将尝试开发一个简单的代码编辑器,使新用户可以挑选各测试用例进行修改后直接运行。
以上所述就是小编给大家介绍的《木兰编程语言重现——功能初具雏形,添加中文报错信息》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 带你从0开发图表库系列-初具雏形
- Beta 版三星 Linux on DeX 上手体验:已初具雏形
- 逻辑式编程语言极简实现(使用C#) - 1. 逻辑式编程语言介绍
- 那些主流编程语言的知识:C 语言(一)
- 那些主流编程语言的知识:C 语言(一)
- 我的“第二”编程语言
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法概论
Sanjoy Dasgupta、Christos Papadimitriou、Umesh Vazirani / 钱枫 注、邹恒明 注 / 机械工业出版社 / 2009-1 / 55.00元
《算法概论(注释版)》源自加州大学伯克利分校和加州大学圣迭戈分校本科生的算法课讲义,以独特的视角展现了算法设计的精巧技术及魅力。在表达每一种技术时,强调每个算法背后的简洁数学思想,分析其时间和空间效率,运用与其他技术类比的方法来说明特征,并提供了大量实例。《算法概论(注释版)》以人类最古老的算法(算术运算)为起点,将各种算法中优美而有代表性的内容囊括书中,并以最前沿的理论(量子算法)结束,构成了较......一起来看看 《算法概论》 这本书的介绍吧!