3个版本 (破坏性更新)
0.4.0 | 2022年12月12日 |
---|---|
0.2.0 | 2021年4月11日 |
0.1.0 | 2020年5月16日 |
在游戏开发类别中排名1664
每月下载量44次
用于5个Crate(其中2个直接使用)
295KB
6K SLoC
Mun是一种通过迭代赋予创造力的编程语言。
特性
-
编译前编译 - Mun在编译前编译(AOT),而不是在解释或即时编译(JIT)。通过在AOT编译过程中检测代码中的错误,可以消除一类运行时错误。这允许开发者留在他们的IDE中,而不是需要在IDE和目标应用程序之间切换以调试运行时错误。
-
静态类型 - Mun在编译时而不是在运行时解析类型,这使得在编写代码时立即获得反馈,并为强大的重构工具打开了大门。
-
一等热重载 - Mun的每个方面都是为热重载而设计的。热重载是更改正在运行的应用程序的代码和资源的过程,消除了每次更改函数或值时都需要启动、停止和重新编译应用程序的需要。
-
性能 - AOT编译与静态类型结合确保Mun可以编译成可以在任何目标平台上原生执行的机器代码。使用LLVM进行编译和优化,保证最佳性能。热重载确实会引入轻微的运行时开销,但可以禁用于生产构建,以确保最佳的运行时性能。
-
交叉编译 - Mun编译器能够从任何支持的编译器平台编译到所有支持的目标平台。
-
强大的IDE集成 - Mun语言和编译器框架被设计为支持源代码查询,允许进行强大的IDE集成,如代码完成和重构工具。
示例
fn fibonacci(n: i32) -> i32 {
if n <= 1 {
n
} else {
fibonacci(n - 1) + fibonacci(n - 2)
}
}
// Comments: functions marked as `pub` can be called outside the module
pub fn main() {
// Native support for bool, f32, f64, i8, u8, u128, i128, usize, isize, etc
let is_true = true;
let var = 0.5;
// Type annotations are not required when a variable's type can be deduced
let n = 3;
let result = fibonacci(n);
// Adding a suffix to a literal restricts its type
let lit = 15u128;
let foo = record();
let bar = tuple();
let baz = on_heap();
}
// Both record structs and tuple structs are supported
struct Record {
n: i32,
}
// Struct definitions include whether they are allocated by a garbage collector
// (`gc`) and passed by reference, or passed by `value`. By default, a struct
// is garbage collected.
struct(value) Tuple(f32, f32);
struct(gc) GC(i32);
// The order of function definitions doesn't matter
fn record() -> Record {
// Mun allows implicit returns
Record { n: 7 }
}
fn tuple() -> Tuple {
// Mun allows explicit returns
return Tuple(3.14, -6.28);
}
fn on_heap() -> GC {
GC(0)
}
文档
预构建的二进制文件
[注意] 我们不提供里程碑版本的支援
[注意] 目前没有对二进制文件进行签名
下载适用于 macOS、Linux 和 Windows(仅限 64 位)的里程碑版本的预构建二进制文件。
从源代码构建
确保您的机器已安装以下依赖项
克隆源代码,包括所有子模块
git clone https://github.com/mun-lang/mun.git
git submodule update --init --recursive
使用 cargo
构建发布版本
cargo build --release
语言服务器
Mun 支持 lsp 协议,使用以下命令启动可执行文件
mun language-server
或者,您也可以安装特定编辑器的扩展。
VS code
在Visual Studio Code中运行。使用以下扩展:VS code 扩展。
Vim/Neovim
使用语言服务器插件(或 neovim 的内置 lsp 支持),例如使用 coc.nvim。
将以下配置粘贴到您的 :CocConfig
中,将 command
替换为 mun 可执行文件的正确路径。
"languageserver": {
"mun": {
"command": "<path_to_mun>",
"rootPatterns": ["mun.toml"],
"trace.server": "verbose",
"args": ["language-server"],
"filetypes": ["mun"]
}
}
请注意,"trace.server": "verbose"
是可选的,有助于语言服务器调试。
构建文档
构建书籍需要 mdBook,理想版本为 0.3.x。要安装它,运行
$ cargo install mdbook --vers [version-num]
Mun 书籍使用 Highlight.js 的自定义版本来启用 Mun 代码的突出显示。mdbook 需要在 theme/
文件夹中使用的 Highlight.js 构建版本,但该版本未与源代码一起分发。相反,可以通过调用构建脚本来构建它
cd book
./ci/build-highlight-js
每次您更改自定义版本中的 highlight.js 中的任何内容时,都必须调用上述脚本以确保您本地使用最新版本。
在生成自定义压缩的 Highlight.js 后,要构建书籍,请键入
$ mdbook build
输出将在子目录中。要查看书籍,请使用网页浏览器打开它。
对于本地开发,请使用 mdbook serve
而不是 mdbook build
。这将启动一个本地 web 服务器,端口为 3000
,该服务器提供书籍并在检测到更改时重新构建内容。
所有上述内容也合并到单个 shell 脚本中,可以通过简单地运行来调用
./ci/build
要测试书籍中的 rust
源代码,请运行
mdbook test -L path/to/target/debug/deps
为此要工作,提供库路径中只能有一个 libmun_runtime-{HASH}.rlib
文件。
许可证
Mun 运行时根据您的选择受以下任一项的许可
- Apache 许可证 2.0(LICENSE-APACHE 或 https://apache.ac.cn/licenses/LICENSE-2.0)
- MIT 许可证(LICENSE-MIT 或 http://opensource.org/licenses/MIT)
。
依赖项
~1.2–7MB
~40K SLoC