0

0

VSCode for Haskell:配置HLS,享受现代开发体验

P粉986688829

P粉986688829

发布时间:2026-01-05 13:05:57

|

664人浏览过

|

来源于php中文网

原创

需安装GHC/Cabal、配置Haskell扩展、按项目类型设hie.yaml,并验证HLS连接状态。具体包括:brew安装工具链;VSCode装官方扩展并设HLS路径;Stack/Cabal项目分别配hie.yaml;通过日志和状态栏确认运行正常。

vscode for haskell:配置hls,享受现代开发体验

如果您希望在 VSCode 中为 Haskell 项目启用类型检查、自动补全和实时错误提示等功能,则必须正确配置 Haskell Language Server(HLS)。以下是完成此配置的具体步骤:

本文运行环境:MacBook Air,macOS Sequoia。

一、安装 Haskell 工具

在启用 HLS 前,需确保系统已安装 GHC 和 Cabal 或 Stack,它们是 HLS 正常运行的基础依赖。HLS 本身不包含编译器,而是依赖本地已安装的 Haskell 构建工具来解析项目结构与类型信息。

1、打开终端,执行 brew install ghc cabal-install 安装 GHC 与 Cabal。

2、运行 cabal update 更新包索引。

3、执行 cabal install hls 安装最新稳定版 HLS 可执行文件。

4、确认安装成功:输入 haskell-language-server --version,应输出版本号及支持的 GHC 版本范围。

二、配置 VSCode 扩展与设置

VSCode 需通过官方 Haskell 扩展识别并启动 HLS,同时需关闭可能冲突的旧扩展(如 Haskero 或 Haskell-ghc-mod),避免语言服务器重复激活或端口占用。

1、在 VSCode 扩展市场中搜索并安装 Haskell(作者:haskell.haskell),该扩展由 Haskell 社区官方维护。

2、打开 VSCode 设置(Cmd + ,),进入 Extensions → Haskell 设置页。

3、将 Haskell: Executable Path 设置为 haskell-language-server(若已加入 PATH)或指定其绝对路径(如 /Users/username/.cabal/bin/haskell-language-server)。

4、勾选 Haskell: Enable HLS,确保开关处于启用状态。

WOMBO
WOMBO

使用AI创作美丽的艺术品

下载

三、适配不同项目构建方式

HLS 的行为会根据项目根目录下是否存在 stack.yaml、cabal.project 或 hie.yaml 文件而自动切换后端驱动。若检测失败,需手动指定驱动类型,否则无法加载模块或报告类型错误。

1、对于使用 Stack 构建的项目,在项目根目录创建 hie.yaml,内容为:cradle: {stack: {}}

2、对于使用 Cabal 构建的项目,hie.yaml 内容应为:cradle: {cabal: {}}

3、若项目无构建配置但含 .hs 文件,可使用 direct 模式:hie.yaml 中写入 cradle: {direct: {arguments: []}}

4、保存 hie.yaml 后,重启 VSCode 窗口或执行命令面板中的 Haskell: Restart Haskell Language Server

四、验证与调试 HLS 连接状态

即使扩展启用且路径正确,HLS 仍可能因权限、GHC 版本不匹配或项目路径含空格而静默失败。此时需检查输出面板中 “Haskell” 日志流,定位初始化中断点。

1、打开 VSCode 命令面板(Cmd + Shift + P),输入并选择 Developer: Toggle Developer Tools

2、切换到 Console 标签页,观察是否有 Failed to start haskell-language-server 类报错。

3、回到 VSCode 底部状态栏,点击左侧 Haskell 图标,查看当前连接状态与使用的 GHC 版本。

4、若显示 Not connected,点击图标后选择 Restart server 并留意输出面板中是否出现 Started haskell-language-server 成功日志。

相关专题

更多
console接口是干嘛的
console接口是干嘛的

console接口是一种用于在计算机命令行或浏览器开发工具中输出信息的工具,提供了一种简单的方式来记录和查看应用程序的输出结果和调试信息。本专题为大家提供console接口相关的各种文章、以及下载和课程。

411

2023.08.08

console.log是什么
console.log是什么

console.log 是 javascript 函数,用于在浏览器控制台中输出信息,便于调试和故障排除。想了解更多console.log的相关内容,可以阅读本专题下面的文章。

482

2024.05.29

vscode
vscode

VS Code(Visual Studio Code)是一款免费、开源的跨平台代码编辑器,由微软开发和维护。它被广泛用于软件开发和编程,支持多种编程语言和框架。VS Code 同时提供了丰富的功能和扩展性,使开发者可以高效地编写、编辑和调试代码。

579

2023.06.30

vscode怎么运行代码
vscode怎么运行代码

vscode是一个运行于MacOS X、Windows和Linux之上的,针对于编写现代Web和云应用的跨平台源代码编辑器;vscode免费而且功能强大,对JavaScript和NodeJS的支持非常好,自带很多功能,例如代码格式化,代码智能提示补全、Emmet插件等。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

219

2023.07.21

vscode使用的框架介绍
vscode使用的框架介绍

VSCode是一款跨平台代码编辑器,它基于Electron框架和Monaco Editor构建。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

385

2024.03.14

vscode一般用来写什么语言
vscode一般用来写什么语言

VSCode是一款功能强大的代码编辑器,支持多种编程语言和文件格式。它内置对 JavaScript、Python、Java、C++、TypeScript、HTML/CSS、Go 等语言的支持。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

374

2024.03.14

vscode可以写什么语言
vscode可以写什么语言

vscode是一款强大的代码编辑器,支持多种编程语言的开发。通过安装扩展,可以为 JavaScript/TypeScript、Python、Java、C#、PHP、Go、Ruby、Rust、HTML/CSS 等语言提供智能代码补全、调试和格式化等功能。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

544

2024.03.15

vscode中文设置方法
vscode中文设置方法

方法一:在设置页面中,搜索“locale”,并选择“zh-cn”。方法二:按“Ctrl Shift P”快捷键,输入“Configure Display Language”,将语言修改为“zh-cn”。如果上述方法无效,可考虑安装中文插件。想了解更多vscode的相关内容,可以阅读本专题下面的文章。

544

2024.03.15

漫蛙2入口地址合集
漫蛙2入口地址合集

本专题整合了漫蛙2入口汇总,阅读专题下面的文章了解更多详细内容。

162

2026.01.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
go语言零基础开发内容管理系统
go语言零基础开发内容管理系统

共34课时 | 2.5万人学习

第二十三期_前端开发
第二十三期_前端开发

共98课时 | 7.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号