ESP32IDF出现Syntax Warning in cmake code at column 47报错

前言

(1)ESP32的资料还是挺难找的,遇到bug处理起来挺折磨人的。今天分享一个我遇到的bug,以及处理思路。

报错日志

(1)前天在些博客的时候,做测试发现了一个奇怪的bug,报错日志如下。

shell 复制代码
CMake Error at F:/HoloCubic/IDF/Enter_ESP-IDF_container_directory/esp-idf/tools/cmake/component.cmake:224 (message):
  CMake Warning (dev) at build_properties.temp.cmake:8:

    Syntax Warning in cmake code at column 47



    Argument not separated from preceding token by whitespace.

  Call Stack (most recent call first):

    F:/HoloCubic/IDF/Enter_ESP-IDF_container_directory/esp-idf/tools/cmake/scripts/component_get_requirements.cmake:3 (include)

  This warning is for project developers.  Use -Wno-dev to suppress it.



  fatal: not a git repository (or any of the parent directories): .git

  CMake Error at
  F:/HoloCubic/github_esp_box_V0.5.0/esp-box/components/bsp/CMakeLists.txt:24
  (message):

    PLATFORM unknown.

  Call Stack (most recent call first):

    F:/HoloCubic/IDF/Enter_ESP-IDF_container_directory/esp-idf/tools/cmake/scripts/component_get_requirements.cmake:106 (include)
    F:/HoloCubic/IDF/Enter_ESP-IDF_container_directory/esp-idf/tools/cmake/scripts/component_get_requirements.cmake:124 (__component_get_requirements) 





Call Stack (most recent call first):
  F:/HoloCubic/IDF/Enter_ESP-IDF_container_directory/esp-idf/tools/cmake/build.cmake:574 (__component_get_requirements)
  F:/HoloCubic/IDF/Enter_ESP-IDF_container_directory/esp-idf/tools/cmake/project.cmake:547 (idf_build_process)
  CMakeLists.txt:14 (project)


-- Configuring incomplete, errors occurred!
See also "F:/HoloCubic/github_esp_box_V0.5.0/esp-box/examples/factory_demo/build/CMakeFiles/CMakeOutput.log".

(2)测试环境:我为了写ESP32的组件添加教程,做测试实验,将组件路径中添加一个空的CMakeLists.txt,用以验证ESP32的组件添加是根据CMakeLists.txt来判断这个路径是否为有效组件。添加完CMakeLists.txt之后,删除CMakeLists.txt文件再次编译就会出现如上错误。

解决办法

(1)当时我查了很久,一直在想是什么问题导致的。直到看到了下面这一句,说我配置未完成,发生错误!

shell 复制代码
Configuring incomplete, errors occurred!

(2)我就在想是什么配置,于是就打算查看一下是什么配置有问题就找到原工程的sdkconfig文件和现在报错工程的sdkconfig文件进行对比。发现现在的工程sdkconfig文件中会少一些配置信息。

(3)于是我就想到了将原来工程的sdkconfig文件覆盖现在出问题的工程sdkconfig文件,之后编译就没有问题了。

(4)但是有些人肯定要说了,他没有保留原来工程的sdkconfig文件怎么办?你可以删除工程目录下的sdkconfig文件和dependencies.lock文件,重新编译就可行了。

猜测问题所在

(1)应该组件目录中有一个空的CMakeLists.txt文件,导致编译器生成sdkconfig文件配置的时候没有全部生成就终止编译了。

(2)之后,你再次进行编译,编译器发现你项目工程中存在sdkconfig文件,就不会再次进行对sdkconfig文件的处理。但是此时的sdkconfig文件是错误的,后续的编译过程是要利用上sdkconfig文件的,因为此时的sdkconfig文件不完整,所以会导致后续的编译出现问题。

相关推荐
天昊吖5 分钟前
stc8H启用DMA发送后 卡住【踩坑日志】
单片机
李永奉12 分钟前
杰理芯片SDK开发-ENC双麦降噪配置/调试教程
人工智能·单片机·嵌入式硬件·物联网·语音识别
BackCatK Chen23 分钟前
第 1 篇:软件视角扫盲|TMC2240 软件核心特性 + 学习路径(附工具清单)
c语言·stm32·单片机·学习·电机驱动·保姆级教程·tmc2240
兆龙电子单片机设计23 分钟前
【STM32项目开源】STM32单片机多功能电子秤
stm32·单片机·开源·毕业设计·智能家居
切糕师学AI1 小时前
ARM 架构中的复位(Reset)与复位流程
arm开发·单片机·嵌入式·复位
llilian_161 小时前
信号发生器 多通道多功能脉冲信号发生器应用解决方案 多功能脉冲发生器
功能测试·单片机·嵌入式硬件·测试工具
yuanmenghao2 小时前
Classic AUTOSAR深入浅出系列 - 【第十六篇】MCAL:为什么 MCU 换了,上层几乎不用动
单片机·嵌入式硬件·autosar
MickyCode3 小时前
嵌入式开发调试之Traceback
arm开发·stm32·单片机·mcu
czwxkn4 小时前
3STM32(stdl)外部中断
stm32·单片机·嵌入式硬件
羽获飞4 小时前
从零开始学嵌入式之STM32——6.与GPIO相关的7个寄存器--重要知识
stm32·单片机·嵌入式硬件