无法打开 源 文件 “esp_err.h“

ESP-IDF 开发环境。目标是:

  • 默认用 clangd 做语义分析
  • C/C++ 扩展不再重复画红线
  • clangd 能识别 ESP 的交叉编译器
  • 保留 ESP-IDF 扩展本身的功能

可以把这些内容放进 VS Code 的"用户设置(JSON)"里。

打开方法:

  1. Ctrl+Shift+P

  2. 输入 Preferences: Open User Settings (JSON)

  3. 回车

  4. 把下面这些配置合并进去

    {
    "C_Cpp.intelliSenseEngine": "disabled",
    "C_Cpp.errorSquiggles": "disabled",

    "clangd.path": "e:\Users\brain\.espressif\tools\esp-clang\esp-19.1.2_20250312\esp-clang\bin\clangd.exe",
    "clangd.arguments": [
    "--background-index",
    "--query-driver=**"
    ],

    "idf.currentSetup": "e:\Users\brain\esp\v5.5.2\esp-idf",
    "idf.portWin": "detect",
    "idf.customExtraVars": {
    "IDF_TARGET": "esp32"
    }
    }

说明一下这几项的作用:

  • C_Cpp.intelliSenseEngine: disabled
    让微软的 C/C++ 扩展不再接管语义分析。
  • C_Cpp.errorSquiggles: disabled
    不再出现它自己的重复红线。
  • clangd.path
    指向你机器上实际安装的 Espressif clangd。
  • clangd.arguments
    让 clangd 后台建索引,并允许识别交叉编译器。
  • idf.currentSetup
    指向你当前 ESP-IDF 安装目录。
  • idf.customExtraVars.IDF_TARGET
    默认目标芯片先用 esp32。

还要注意一件事:

这套"全局配置"只能解决"诊断引擎打架"的问题,但每个新工程最好仍然有自己的 build/compile_commands.json。也就是说,新项目第一次最好至少执行一次:

这样 clangd 才能准确知道头文件路径和编译参数。

如果想把新工程也完全免配置,建议以后每个 ESP-IDF 项目都带一个最小 .vscode/settings.json,内容像这样:

复制代码
{
  "idf.buildPath": "${workspaceFolder}/build",
  "C_Cpp.default.compileCommands": "${workspaceFolder}/build/compile_commands.json",
  "clangd.arguments": [
    "--background-index",
    "--query-driver=**",
    "--compile-commands-dir=${workspaceFolder}/build"
  ]
}

可以把它当作自己的 ESP-IDF 工程模板。

相关推荐
Hello World . .2 小时前
51单片机基础外设:中断、定时器/计数器(PWM控制蜂鸣器、电机)
单片机·嵌入式硬件·51单片机
LCG元3 小时前
基于STM32CubeMX的HAL库串口通信与DMA传输深度优化
stm32·单片机·嵌入式硬件
嵌入小生0074 小时前
硬件 --- GPIO/中断/定时器/蜂鸣器
单片机·嵌入式硬件·定时器·pwm·gpio·蜂鸣器·中断
forAllforMe5 小时前
LAN9252 从机模式寄存器的配置代码示例
stm32·单片机·嵌入式硬件
不想起床&5 小时前
51单片机
单片机·嵌入式硬件·51单片机
我在人间贩卖青春5 小时前
单片机复位源
单片机·嵌入式硬件·复位源
项目題供诗5 小时前
51单片机入门-温度传感器DS18B20(十三)
单片机·嵌入式硬件·51单片机
莎士比亚的文学花园6 小时前
硬件通信——UART串行口
单片机·嵌入式硬件
guygg886 小时前
基于STM32的贪吃蛇游戏实现(OLED屏)
stm32·嵌入式硬件·游戏