MoonBit 更新
- 标准库里添加了 Iter 类型,该类型可以高效地对容器中的元素的进行访问,并且将访问过程优化成循环,使用方式比如:
test "iter" { let sum = Iter::[1, 2, 3, 4, 5, 6] .filter(fn { x => x % 2 == 1 }) .take(2) .map(fn { x => x * x}) .reduce(fn (x, y) { x + y }, 0) inspect(sum, cOntent="10")? } - 标准库里添加了 VecView 类型,可以使用如下方式对
Vec[T]类型的值取它的VecView[T]。
test "view" { let v = Vec::[1, 2, 3, 4, 5] let vv1 = v[..] let vv2 = v[1..] let vv3 = v[..4] let vv4 = v[1..4] inspect(vv1, cOntent="VecView::[1, 2, 3, 4, 5]")? inspect(vv2, cOntent="VecView::[2, 3, 4, 5]")? inspect(vv3, cOntent="VecView::[1, 2, 3, 4]")? inspect(vv4, cOntent="VecView::[2, 3, 4]")? } - array pattern 支持
[a, .. as rest, b]形式,其中rest会绑定到一个 VecView ,例如:
test "view_pattern" { fn is_palindrome(s: VecView[Int]) -> Bool { match s { [] => true [_] => true [x, .. as rest, y] => x == y && is_palindrome(rest) } } let v1 = Vec::[1, 2, 3, 4, 5] @assertion.assert_false(is_palndrome(v1[..]))? let v2 = Vec::[1, 2, 3, 2, 1] @assertion.assert_true(is_palindrome(v2[..]))? } - 标签参数调用时允许省略标签里的波浪线
~,例如:
inspect(1, cOntent="1") - 构造器支持带标签的参数:
pub enum Tree[X] { Nil Branch(X, ~left : Tree[X], ~right : Tree[X]) } pub fn leftmost[X](self : Tree[X]) -> Option[X] { loop self { Nil => None // 使用 `label=pattern` 来匹配构造器的带标签参数 Branch(top, left=Nil, right=Nil) => Some(top) // `label=label` 可以简写成 `~label` Branch(_, left=Nil, ~right) => continue right // 可以用 `..` 来忽略所有剩余的带标签参数 Branch(_, ~left, ..) => continue left } } fn init { // 创建带标签的构造器的语法和调用带标签的函数一样 let t: Tree[Int] = Branch(0, right=Nil, left=Branch(1, left=Nil, right=Nil)) println(t.leftmost()) // `Some(1)` } - 可选参数的默认值可以依赖前面的参数,例如:
fn f(~x: Int = 1, ~y: Int = x) -> Int { x + y } - Byte 字面量支持八进制转义。
IDE 更新
- IDE 支持本地环境的 test codelens ;支持 expect test 的自动更新。
-
修复在线 IDE 在 Windows 上找不到 core 的问题。
-
支持识别
test_import和*_test.mbt文件。
工具链更新
-
moonfmt
- 修复了
String和Char字面量中的转义序列没有被正确格式化的问题; - 调整针对
{ ..record }的格式化。
- 修复了
-
moon info和moon coverage现已支持 Windows 。 -
moon info支持在不引起歧义时缩短类型名称,使得生成结果更加干净:- 在没有同名类型定义的时候隐藏 builtin 的包名前缀;
- 在没有歧义时使用包名的最后一部分代替完整的包名。 更新前:
package moonbitlang/core/map // -- snip -- type Map fn Map::debug_write[K : @moonbitlang/core/builtin.Debug, V : @moonbitlang/core/builtin.Debug](Map[K, V], @moonbitlang/core/builtin.Buffer) -> Unit fn Map::keys_set[K : @moonbitlang/core/builtin.Compare + @moonbitlang/core/builtin.Eq, V](Map[K, V]) -> @moonbitlang/core/immutable_set.ImmutableSet[K] fn Map::lookup[K : @moonbitlang/core/builtin.Compare + @moonbitlang/core/builtin.Eq, V](Map[K, V], K) -> Option[V] fn Map::to_vec[K, V](Map[K, V]) -> @moonbitlang/core/vec.Vec[Tuple[K, V]] 更新后:
package moonbitlang/core/map alias @moonbitlang/core/immutable_set as @immutable_set alias @moonbitlang/core/vec as @vec // -- snip -- type Map fn Map::debug_write[K : Debug, V : Debug](Map[K, V], Buffer) -> Unit fn Map::keys_set[K : Compare + Eq, V](Map[K, V]) -> @immutable_set.ImmutableSet[K] fn Map::lookup[K : Compare + Eq, V](Map[K, V], K) -> Option[V] fn Map::to_vec[K, V](Map[K, V]) -> @vec.Vec[Tuple[K, V]] 构建系统更新
moon test添加测试过滤相关选项:
-p, --package <PACKAGE_NAME> Run test in the specified package -f, --file <FILE> Run test in the specified file, only valid when --package is specified -i, --index <INDEX> Run the index-nth test in the specified file, only valid when --file is specified 命令示例:moon test -p username/hello/A -f hello.mbt -i 0 (运行 username/hello/A 包中 hello.mbt 文件中的第 0 个 test block);-f 和 -i 分别在指定 -p 和 -f 时才有效;如果不指定 -f 则运行 -p 指定包中所有测试,不指定 -i 则运行 -f 指定文件中所有测试。
-
moon check|build|test添加--sort-input选项,用于生成稳定的构建顺序。 -
expect test 生成的
~cOntent=省略~,变更为cOntent=。


