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

Visual Studio - 리눅스 용 프로젝트의 인텔리센스를 위한 헤더 파일 처리 방법

리눅스 용 프로젝트를 Visual Studio에서 만들어 컴파일하는 방법을 소개했었는데요.

WSL을 이용해 윈도우 PC 1대에서 Linux 응용 프로그램을 Visual Studio로 개발하는 방법
; https://www.sysnet.pe.kr/2/0/11390

문제는, 다음과 같이 unistd.h 등의 리눅스 전용 헤더 파일을 추가하는 경우,

#include <cstdio>
#include <unistd.h>

int main()
{
    printf("hello from app4!\n");

    while (true)
    {
        sleep(1); // 인텔리센스가 sleep 함수를 나열하지 못함
    }

    return 0;
}

비주얼 스튜디오가 있는 윈도우 환경에는 해당 헤더 파일이 없기 때문에 'cannot open source file "unistd.h"'라는 오류 메시지와 함께 인텔리센스(Intellisense) 기능이 제공되지 않습니다.

이에 대한 문제를 해결하는 방법은 간단합니다.

Linux header file not recognized in Visual Studio 2017 Linux Project
; https://stackoverflow.com/questions/43022494/linux-header-file-not-recognized-in-visual-studio-2017-linux-project

즉, 비주얼 스튜디오에서 리눅스 프로젝트에 대해서도 unistd.h 파일을 발견할 수 있도록 해주면 되는 것입니다. 사실 비주얼 스튜디오의 경우 기본적인 리눅스 헤더 파일을 다음의 경로에 보관하고 있습니다.

[Visual Studio 2015]
C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\Linux\include\usr\include

[Visual Studio 2017]
C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\Common7\IDE\VC\Linux\include

당연히 unistd.h 파일을 저 위치에 복사해 주면 되겠지만 문제는, 일일이 그럴 때마다 파일을 복사해 주는 것은 별로 좋은 방법은 아닌 듯합니다. 바로 이럴 때 윈도우 스토어에 설치했던 Ubuntu 앱이 유용하게 사용됩니다. ^^ 즉, 거기에 이미 구성한 헤더 파일을 포함하면 모든 것이 매끄럽게 해결될 수 있는 것입니다.

우분투 앱에 설치된 모든 파일은 윈도우 파일 시스템으로도 접근할 수 있기 때문에 다음과 같이 검색할 수 있습니다.

C:> dir /a/s unistd.h

검색해 보면 아래는 다음의 경로가 리눅스 용 헤더 파일을 포함하고 있는 것으로 보입니다.

%LOCALAPPDATA%\Packages\CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs\usr\include

그런데 경로가 매우 심란하군요. ^^; 이럴 때는 JUNCTION으로 연결해 주고,

mkdir c:\linux
mklink /J "C:\linux\include" "%LOCALAPPDATA%\Packages\CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs\usr\include"

비주얼 스튜디오에서는 간단하게 c:\linux\include로 설정하면 됩니다.

wsl_header_0.png

이후부터는 다음과 같이 인텔리센스가 아주 잘 적용됩니다. ^^

wsl_header_1.png




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/8/2017]

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

비밀번호

댓글 작성자
 



2018-04-09 11시33분
현재 15.7 Preview 3 버전에서 자동으로 원격의 리눅스 헤더 파일을 처리해 인텔리센스를 제공하는 기능이 추가되었다고 합니다. ^^

IntelliSense for Remote Linux Headers
; https://devblogs.microsoft.com/cppblog/intellisense-for-remote-linux-headers/
정성태
2018-08-17 02시25분
Visual Studio 2017로 완벽한 C++ 리눅스 개발환경 만들기
 ; http://www.gamecodi.com/board/zboard-id-GAMECODI_Talkdev-no-5010-z-0.htm
정성태
2018-11-11 02시19분
[erica] 와 정말 꿀팁입니다. 감사합니다.!
[guest]

1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13893정성태2/27/20252225Linux: 115. eBPF (bpf2go) - ARRAY / HASH map 기본 사용법
13892정성태2/24/20252983닷넷: 2325. C# - PowerShell과 연동하는 방법파일 다운로드1
13891정성태2/23/20252500닷넷: 2324. C# - 프로세스의 성능 카운터용 인스턴스 이름을 구하는 방법파일 다운로드1
13890정성태2/21/20252329닷넷: 2323. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(Win32 API)파일 다운로드1
13889정성태2/20/20253054닷넷: 2322. C# - 프로세스 메모리 중 Private Working Set 크기를 구하는 방법(성능 카운터, WMI) [1]파일 다운로드1
13888정성태2/17/20252498닷넷: 2321. Blazor에서 발생할 수 있는 async void 메서드의 부작용
13887정성태2/17/20253074닷넷: 2320. Blazor의 razor 페이지에서 code-behind 파일로 코드를 분리 및 DI 사용법
13886정성태2/15/20252574VS.NET IDE: 196. Visual Studio - Code-behind처럼 cs 파일을 그룹핑하는 방법
13885정성태2/14/20253236닷넷: 2319. ASP.NET Core Web API / Razor 페이지에서 발생할 수 있는 async void 메서드의 부작용
13884정성태2/13/20253523닷넷: 2318. C# - (async Task가 아닌) async void 사용 시의 부작용파일 다운로드1
13883정성태2/12/20253268닷넷: 2317. C# - Memory Mapped I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13882정성태2/10/20252581스크립트: 70. 파이썬 - oracledb 패키지 연동 시 Thin / Thick 모드
13881정성태2/7/20252832닷넷: 2316. C# - Port I/O를 이용한 PCI Configuration Space 정보 열람파일 다운로드1
13880정성태2/5/20253172오류 유형: 947. sshd - Failed to start OpenSSH server daemon.
13879정성태2/5/20253407오류 유형: 946. Ubuntu - N: Updating from such a repository can't be done securely, and is therefore disabled by default.
13878정성태2/3/20253198오류 유형: 945. Windows - 최대 절전 모드 시 DRIVER_POWER_STATE_FAILURE 발생 (pacer.sys)
13877정성태1/25/20253249닷넷: 2315. C# - PCI 장치 열거 (레지스트리, SetupAPI)파일 다운로드1
13876정성태1/25/20253709닷넷: 2314. C# - ProcessStartInfo 타입의 Arguments와 ArgumentList파일 다운로드1
13875정성태1/24/20253137스크립트: 69. 파이썬 - multiprocessing 패키지의 spawn 모드로 동작하는 uvicorn의 workers
13874정성태1/24/20253558스크립트: 68. 파이썬 - multiprocessing Pool의 기본 프로세스 시작 모드(spawn, fork)
13873정성태1/23/20252983디버깅 기술: 217. WinDbg - PCI 장치 열거파일 다운로드1
13872정성태1/23/20252885오류 유형: 944. WinDbg - 원격 커널 디버깅이 연결은 되지만 Break (Ctrl + Break) 키를 눌러도 멈추지 않는 현상
13871정성태1/22/20253292Windows: 278. Windows - 윈도우를 다른 모니터 화면으로 이동시키는 단축키 (Window + Shift + 화살표)
13870정성태1/18/20253732개발 환경 구성: 741. WinDbg - 네트워크 커널 디버깅이 가능한 NIC 카드 지원 확대
13869정성태1/18/20253456개발 환경 구성: 740. WinDbg - _NT_SYMBOL_PATH 환경 변수에 설정한 경로로 심벌 파일을 다운로드하지 않는 경우
13868정성태1/17/20253112Windows: 277. Hyper-V - Windows 11 VM의 Enhanced Session 모드로 로그인을 할 수 없는 문제
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...