Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

Visual Studio Code extension for Arduino - #include errors detected.

이상하군요. 다음과 같은 오류가 발생하는데,

vs_code_include_error_1.png

Configure your IntelliSense settings to help find missing headers.

Source C/C++ (Extension)

붉은 밑줄이 있는 "void setup()" 위에 마우스를 올려놓으니 이런 오류 메시지가 나타납니다.

#include errors detected. Please update your includePath. IntelliSense features for this translation unit (%USERPROFILE%\Documents\Arduino\generated_examples\Blink\Blink.ino) will be provided by the Tag Parser.

cannot open source file "avr/pgmspace.h" (dependency of "C:\Program Files (x86)\Arduino\hardware\arduino\avr\cores\arduino\Arduino.h")


더욱 이상한 것은, 위의 프로젝트는 c:\temp\My 폴더에 있는 My.ino인데, 엉뚱하게 %USERPROFILE%\Documents\Arduino\generated_examples\Blink\Blink.ino 파일의 경로가 나오는 것입니다. 혹시나 해서, %USERPROFILE%\Documents\Arduino\generated_examples\Blink 폴더를 삭제했더니 이제는 다음과 같이 오류 메시지가 바뀝니다.

#include errors detected. Please update your includePath. IntelliSense features for this translation unit (C:\temp\My\My.ino) will be provided by the Tag Parser.

cannot open source file "avr/pgmspace.h" (dependency of "C:\Program Files (x86)\Arduino\hardware\arduino\avr\cores\arduino\Arduino.h")


우선, 두 번째 오류는 ./.vscode/settings.json 파일을 통해 "Workspace Settings" 수준으로 C_Cpp.intelliSenseEngineFallback 설정을 하면 없어집니다. (settings.json 파일이 없는 경우 그냥 만들거나 Command Palette을 통해 "> Preferences: Open Settings (JSON)" 명령을 실행합니다.)

{
    "C_Cpp.intelliSenseEngineFallback": "Disabled"
}

첫 번째 오류는 해결 방법이 상황에 따라 달라질 수 있을 것 같은데, 일단 제 경우에는 다음과 같이 2개의 include 폴더를 추가했을 때 없어졌습니다.

{
    "configurations": [
        {
            "name": "Win32",
            "includePath": [
                "C:\\Program Files (x86)\\Arduino\\tools\\**",
                "C:\\Program Files (x86)\\Arduino\\hardware\\arduino\\avr\\**",
                "C:/Program Files (x86)/Arduino/hardware/tools/avr/avr/include",
                "C:/Program Files (x86)/Arduino/hardware/arduino/avr/variants/circuitplay32u4"
            ],
            "forcedInclude": [
                "C:\\Program Files (x86)\\Arduino\\hardware\\arduino\\avr\\cores\\arduino\\Arduino.h"
            ],
            "intelliSenseMode": "msvc-x64",
            "compilerPath": "C:/Program Files (x86)/Microsoft Visual Studio/2017/Enterprise/VC/Tools/MSVC/14.15.26726/bin/Hostx64/x64/cl.exe",
            "cStandard": "c11",
            "cppStandard": "c++17"
        }
    ],
    "version": 4
}

재미있는 것은, 첫 번째 문제를 해결하면 두 번째의 settings.json 설정을 하지 않아도 됩니다. 음... 보면 볼수록 이상하군요. ^^ /avr/avr/include 폴더는 그렇다 쳐도 /avr/variants 폴더는 그 상위에 있는 avr\\** 설정에 포함이 되는데도 다시 해줘야만 합니다.




참고로, 이번 2개의 오류는 사실 발생했다고 해도 그다지 개발에 영향을 주는 것은 아니고 IntelliSense에만 약간 문제가 발생합니다. 중요 작업인 컴파일 및 업로드가 잘 되므로 고치지 않아도 상관없지만 그래도 빨간 줄이 그어지는 것을 참고 못 보는 분들이라면 ^^ 이런 유의 작업을 해줘야만 합니다.




Visual Studio Code를 이용한 아두이노 프로그램 개발
; https://www.sysnet.pe.kr/2/0/11753

Visual Studio Code를 이용한 아두이노 프로그램 개발 - 새 프로젝트
; https://www.sysnet.pe.kr/2/0/11754

Visual Studio Code의 아두이노 프로그램 개발 시 인텔리센스가 안 된다면?
; https://www.sysnet.pe.kr/2/0/11756

Visual Studio Code extension for Arduino - #include errors detected.
; https://www.sysnet.pe.kr/2/0/11755




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 10/19/2018]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2019-08-05 04시11분
[나그네] VSCode 버그인거 같습니다. 보통 코드 수정없이 VSCode를 재시작하면 사라지더군요.

[guest]

... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10899정성태2/17/201623344개발 환경 구성: 282. kernel32.dll, kernel32legacy.dll, api-ms-win-core-sysinfo-l1-2-0.dll [1]
10898정성태2/17/201621802.NET Framework: 547. PerformanceCounter의 InstanceName 지정 시 주의 사항파일 다운로드1
10897정성태2/17/201621147디버깅 기술: 76. windbg 분석 사례 - 닷넷 프로파일러의 GC 콜백 부하
10896정성태2/17/201622313오류 유형: 320. FATAL: 28000: no pg_hba.conf entry for host "fe80::1970:8120:695:a41e%12"
10895정성태2/17/201621113.NET Framework: 546. System.AppDomain으로부터 .NET Profiler의 AppDomainID 구하는 방법 [1]
10894정성태2/17/201621831오류 유형: 319. Visual Studio에서 찾기는 성공하지만 해당 소스 코드 정보가 보이지 않는 경우
10893정성태2/16/201620480.NET Framework: 545. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까? - 두 번째 이야기
10892정성태2/16/201621098오류 유형: 318. 탐색기에서 폴더 생성/삭제 시 몇 초 동안 멈추는 현상
10891정성태2/16/201624116VC++: 95. 내 CPU가 MPX/SGX를 지원할까요? [1]
10890정성태2/15/201623989.NET Framework: 544. C# 5의 Caller Info를 .NET 4.5 미만의 응용 프로그램에 적용하는 방법 [5]
10889정성태2/14/201620280.NET Framework: 543. C++의 inline asm 사용을 .NET으로 포팅하는 방법 - 두 번째 이야기파일 다운로드1
10888정성태2/14/201618625.NET Framework: 542. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까?
10887정성태2/3/201619292VC++: 94. MPX(Memory Protection Extensions) 테스트파일 다운로드1
10886정성태2/3/201620527개발 환경 구성: 281. Intel MPX Runtime Driver 수동 설치
10885정성태2/2/201620218오류 유형: 317. Sybase.Data.AseClient.AseException: The command has timed out.
10884정성태1/11/201621435개발 환경 구성: 280. 닷넷에서 SAP Adaptive Server Enterprise 데이터베이스 사용파일 다운로드1
10882정성태1/6/201620731Windows: 113. 윈도우의 2179, 26143, 47001 TCP 포트 사용 [1]
10881정성태1/3/201622166오류 유형: 316. 윈도우 10 - 바탕/돋음 체가 사라져 한글이 깨지는 현상 [2]
10880정성태12/16/201519846오류 유형: 315. 닷넷 프로파일러의 오류 코드 정보
10879정성태12/16/201521773오류 유형: 314. Error : DEP0700 : Registration of the app failed. error 0x80070005
10878정성태12/9/201524836디버깅 기술: 75. UWP(유니버설 윈도우 플랫폼) 앱에서 global::System.Diagnostics.Debugger.Break 예외 발생 시 대응 방법
10877정성태12/9/201529271VC++: 93. std::thread 사용 시 R6010 오류 [2]
10876정성태11/26/201525329.NET Framework: 541. SignedXml을 이용한 ds:Signature만드는 방법 [3]파일 다운로드1
10875정성태11/26/201530318개발 환경 구성: 279. signtool.exe의 다중 서명 기능 [2]
10874정성태11/26/201526323개발 환경 구성: 278. 인증서와 인증서를 이용한 코드 사인의 해시 구분
10873정성태11/25/201525443.NET Framework: 540. C# - 부동 소수 계산 왜 이렇게 나오죠? (2) [3]파일 다운로드1
... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...