无法打开 源 文件 “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 工程模板。

相关推荐
进击的小头17 小时前
第7篇:嵌入式芯片运算核心:ALU_MAC_FPU的工作原理与性能差异
单片机·嵌入式硬件
振南的单片机世界17 小时前
RS485组网:一问一答,多个从机不打架
单片机·嵌入式硬件
开源盛世!!17 小时前
4.9-4.11
单片机·嵌入式硬件
路过羊圈的狼18 小时前
STM32使用SFUD (Serial Flash Universal Driver) 串行 Flash 通用驱动库驱动W25Q128
stm32·单片机·嵌入式硬件
LCG元18 小时前
多MCU通信:STM32F1通过I2C/SPI实现数据同步与控制
stm32·单片机·嵌入式硬件
史蒂芬_丁18 小时前
EPWM Global Load
单片机·嵌入式硬件
碎像18 小时前
单片机-数码管显示
单片机·嵌入式硬件
LCMICRO-133108477461 天前
长芯微LPS123完全P2P替代ADP123,高性能、低压差的线性稳压器
单片机·嵌入式硬件·fpga开发·硬件工程·dsp开发·线性稳压器
守护安静星空1 天前
esp32开发笔记-工程搭建
笔记·单片机·嵌入式硬件·物联网·visual studio code
ACP广源盛139246256731 天前
破局 Type‑C 切换器痛点@ACP#GSV6155+LH3828/GSV2221+LH3828 黄金方案
c语言·开发语言·网络·人工智能·嵌入式硬件·计算机外设·电脑