仓库源文

通过添加列表操作等功能,已可编写经典排序算法。另外,作为代码编辑器的第一步,用 Python 实现了带基本语法高亮的编辑器原型,用于显示木兰源码。

功能

编辑器功能

用 tkinter 的 Text 实现了如下的木兰源码高亮效果:

语言功能

添加了列表操作、多项赋值等等基本功能,编写经典算法已经可行。比如快速排序

func 分区(数列, 下界, 上界) {
  中值 = 数列[上界] // 中值可以取任意一个位置的
  前位 = 下界
  for 后位 in 下界..上界 {
    if 数列[后位] < 中值 {
      数列[前位], 数列[后位] = 数列[后位], 数列[前位]
      前位 += 1
    }
  }
  数列[前位], 数列[上界] = 数列[上界], 数列[前位]
  return 前位
}

func 快速排序(数列) {
  func 递归(各项, 下界, 上界) {
    if 下界 < 上界 {
      中位 = 分区(各项, 下界, 上界)
      递归(各项, 下界, 中位 - 1)
      递归(各项, 中位 + 1, 上界)
    }
  }

  递归(数列, 0, len(数列) - 1)
}

支持了三元运算? :,见例程测试/手工测试/命令行.ul

using Cmd in cmd
using 随机范围数 in 随机数
using exit in sys

type 猜数字 : Cmd {
    {
        intro = "木兰想了个 100 之内的数,猜猜是几?"
        想的 = 随机范围数(100)
        prompt = '请猜吧: '
    }

    func $default(行) {
        数 = int(行)
        if 数 == self.想的 {
            println("中了!")
            exit()
        } else {
            println("太" + (数 > self.想的 ? "大" : "小") + "了!")
        }
    }
}
猜数字().cmdloop()

代码统计

下面是几个主要部分的代码行数统计,+的为相对上周的增量。

下一步

添加对木兰模块的支持,改进编辑器。