Sublime如何配置Erlang环境?Sublime编写Erlang脚本高亮设置
Sublime如何配置Erlang环境?Sublime编写Erlang脚本高亮设置

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
开门见山地说,Sublime Text本身并不运行Erlang,也没有内置的Erlang支持。所以,我们常说的“配置环境”,本质上就是把三件事理顺:让.erl文件获得正确的语法高亮、让Ctrl+B快捷键能顺利调用erlc进行编译、以及最终能在终端里用erl加载测试。这三步环环相扣,顺序不能乱,缺了哪一环都玩不转。
怎么确认 erlc 和 erl 已就位?
这是所有后续操作的地基。必须明白,Sublime的构建系统本质上是在执行shell命令。如果连你的终端都找不到erlc或erl,那Sublime肯定也调不动它们。
- 首先,打开终端,运行
erlc -v和erl -version。如果一切正常,你应该能看到类似Erlang/OTP 26这样的版本输出。 - 对于macOS用户,通过
brew install erlang安装通常会自动配置好PATH。而Windows用户则需要留意,如果在安装时没有勾选“Add to PATH”,就必须手动将类似C:Program Fileserl-25.3in的路径添加到系统环境变量中。 - 使用
asdf等版本管理工具的Linux用户,务必确保已设置asdf global erlang ref,并在终端中用which erlc命令验证路径。 - 千万别跳过这一步直接去配置Sublime的构建系统。很多后续遇到的“没反应”问题,根源往往就在这里。
为什么装了插件还是没语法高亮?
原因通常是装错了插件,或者语法映射没有正确激活。Sublime Text默认并不认识.erl这个后缀,必须依靠插件来补全支持。但社区里名字带“Erlang”的插件有好几个,只有官方维护的那款(作者是erlang-editors)才能稳定支持OTP 24+的新语法特性,比如-spec fun/0。
- 按下
Ctrl+Shift+P(Windows/Linux)或Cmd+Shift+P(macOS),调出命令面板,输入Package Control: Install Package。 - 搜索
Erlang,认准GitHub地址为https://github.com/erlang-editors/sublime-erlang的那个进行安装。 - 安装完成后,打开一个
.erl文件,注意查看编辑器右下角,应该显示为Erlang。如果仍然是Plain Text,可以右键点击文件,选择Set Syntax → Erlang → Erlang手动切换一次,之后Sublime就会自动识别了。 - 如果不慎安装了错误的插件(例如已经停止更新的
Erlang Language Support),可能会导致保存时误删空行,或者-spec等语法解析失败。
Build System 怎么写才不报错?
Sublime没有预设的Erlang构建系统,所以我们必须手动新建一个。这里的关键不在于“能不能编译”,而在于编译结果是否生成在正确的位置、错误信息能否准确定位到行号、以及模块依赖关系是否能够被正确解析。
- 从菜单栏进入:
Tools → Build System → New Build System…。 - 将以下配置内容粘贴进去,并保存为
Erlang.sublime-build(文件会自动保存在Packages/User/目录下):
{
"cmd": ["erlc", "$file"],
"file_regex": "^(.+):([0-9]+):([0-9]+):.*$",
"working_dir": "$file_path",
"selector": "source.erlang"
}
- 配置说明:
$file代表当前文件的完整路径(例如/home/user/proj/test.erl),而$file_path则是其所在目录(/home/user/proj)。必须设置working_dir,否则erlc编译器可能找不到通过-include引入的.hrl头文件,或者把生成的.beam文件输出到错误的地方。 - Windows用户请注意:如果你的
erlc.exe位于带空格的路径下(比如C:Program Fileserl-25.3in),建议将其复制到一个没有空格的路径(例如D:erlanginerlc.exe),然后将配置中的"cmd"项相应地修改为["D:\erlang\bin\erlc.exe", "$file"],这样可以避免很多潜在的路径解析问题。 - 一个小技巧:尽量使用
cmd数组,而不是shell_cmd。因为在macOS或Linux的GUI环境下,shell_cmd有时无法正确继承shell中的PATH环境变量,直接使用cmd数组通常更可靠。
为什么 Ctrl+B 编译完却没法在 Sublime 里运行?
这其实是一个常见的误解。Sublime Text是编辑器,不是IDE,它没有内置Erlang运行时。所谓的“运行”,实际上是两个独立的步骤:先用erlc编译出.beam字节码文件,再用erl虚拟机加载执行。第二步必须在终端里手动完成。一些插件封装的“一键运行”功能,往往在处理路径、cookie或应用启动顺序时出现问题,反而会增加调试的复杂度。
- 在Sublime中按
Ctrl+B编译成功后,打开你的系统终端。 - 使用
cd命令切换到你的源码目录(也就是.erl文件所在的目录)。 - 运行
erl -pa .启动Erlang shell。-pa .这个参数非常重要,它告诉Erlang虚拟机在当前目录下寻找.beam文件。 - 在Erlang shell中,执行
c(module_name).(注意末尾的点号),如果返回{ok, module_name},就说明模块加载成功了。 - 接下来,你就可以像在生产环境中一样调用函数了:
module_name:function().。 - 如果你的模块依赖其他
.beam文件,确保这些文件也在-pa参数指定的路径下。不要指望编辑器插件能自动处理复杂的多级目录结构,比如src/或_build/。
对于使用rebar3管理的项目,情况也是类似的:纯erlc的构建方式只适用于单文件测试。真实的并发系统(包含gen_server、supervisor等OTP行为)必须使用rebar3 compile来编译,这通常需要额外编写shell或batch脚本来调用,Sublime的构建系统本身并不感知rebar.config的配置。
相关攻略
插件安装失败主因是Package Control资源获取失败、SSL证书验证失败或被ignored_packages屏蔽;需依次检查channel地址有效性、系统时间与证书、ignored_packages配置及依赖模块是否以 sublime-package形式安装。 遇到插件安装报错,先别急着删了
关掉 preview_on_click 即可,需在用户设置中添加 "preview_on_click ": false(布尔值,非字符串),补全逗号,保存后生效;残留预览页需手动双击转正,SidebarEnhancements 插件还需单独禁用 enable_click_to_open。 其实,解决这
Sublime Text 代码对比功能:FileDiffs插件安装与排错指南 想在Sublime Text里快速对比两个文件的差异?FileDiffs插件是个不错的选择。但别急着高兴,这插件有点“小脾气”——它对文件状态、编码格式甚至路径都有明确要求。如果条件不满足,它不会报错,只会给你一个静默的失
Minimap 背景色和代码块颜色由主题文件控制,而非 color_scheme 先说一个核心事实:Sublime Text 里那个侧边栏的代码地图(Minimap),它的配色系统是独立的。很多人折腾半天,把 color_scheme 文件里的背景色改成护眼绿,结果发现 Minimap 纹丝不动,还
Sublime快捷键只能在User sublime-keymap中覆盖,默认配置不可修改;需保持合法JSON数组格式,命令名须通过命令面板或控制台获取,避免覆盖高频键,鼠标键位需另建Default sublime-mousemap文件。 给Sublime Text自定义快捷键,有个核心原则必须牢记:
热门专题
热门推荐
WF-1000XM4蓝牙配对指南:两种触发路径,一个核心逻辑 给索尼WF-1000XM4配对,核心其实就一件事:让耳机进入“被发现”的状态。有意思的是,它并不依赖某个单一的物理按键,而是提供了双路径的触发方式。根据官方的操作指南以及多次的实际测试,无论是通过充电盒上的功能键,还是直接操作耳机本身,都
迅捷路由器桥接失败怎么办?原因分析与解决方法大全 许多用户在使用迅捷路由器进行无线桥接时,经常遇到“显示已连接但无法访问互联网”的问题。实际上,这通常并非设备故障,而是由于关键的网络参数配置不当或主副路由器之间的通信协调不畅所致。简单来说,就是两台路由器之间的设置没有完全匹配。那么,具体哪些环节最容
迅捷路由器无线桥接:手机端设置实操指南 使用手机为迅捷路由器配置无线桥接(WDS),听似专业,实则通过官方适配的移动端界面就能轻松完成。只要满足几个关键条件,您仅需一部手机即可高效架设扩展网络。操作时,请先将手机连接至副路由器的默认无线信号(通常以FAST_XXXX格式命名),随后在Safari或C
小米空调联网故障全解析:从新手排查到专家级修复,步步为营 当小米空调始终无法成功连接网络时,许多用户的第一反应往往是联系售后或怀疑设备故障。然而实际情况是,超过九成的联网失败案例,根源都出在网络配置、操作流程这类“软性”环节,空调硬件本身出问题的概率极低。解决问题的核心在于掌握系统化的排查思路,按照
有线音响加装蓝牙功能并不复杂,普通用户借助外置蓝牙接收器即可在十分钟内完成升级 想给家里的老款有线音响“剪掉”那根烦人的音频线?其实这件事没你想的那么复杂。普通用户完全不需要动用电烙铁,借助一个小巧的外置蓝牙接收器,十分钟之内就能搞定升级。核心操作很简单:确认你的音箱背面有标准的3 5毫米或RCA音





