Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 48. Orcas - VC++ 프로젝트 마이그레이션 [링크 복사], [링크+제목 복사],
조회: 22543
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


Orcas로 VC++ 프로젝트 마이그레이션


이번에는 저희 회사 제품 중의 하나를 실제로 VS.NET 2005에서 Orcas로 마이그레이션 하면서 발생한 호환성 문제를 다뤄보려고 합니다. 결론부터 말씀드리면, 사실 큰 이슈는 없었고 그런대로 무난하게 마이그레이션이 되었습니다.

한가지... 실망스러운 점이 있다면 (아직 베타 버전이라 희망이 있는지는 알 수 없으나.) VC++ 프로젝트가 이번에도 MSBuild에 통합되지 않았다는 점입니다. 예전부터 있어왔던 이야기였는데, 왜 Orcas에서도 이것이 받아들여지지 않았는지 모르겠군요. (어쨌든, VCBuild Task로 그나마 관리가 좀 되긴 하지만.)

그리고, 참고로 지난 "Orcas와 VS.NET 2005의 혼합 개발" 토픽의 내용은 VC++에는 해당하지 않습니다. 이 부분에서 좀 아쉬움이 남더군요. 사실, 기존 VS.NET 2005의 VC++ 프로젝트와 Orcas에서의 차이는 다음과 같이 간단합니다.

<?xml version="1.0" encoding="ks_c_5601-1987"?>
<VisualStudioProject
  ProjectType="Visual C++"
  Version="8.00" ==> Orcas에서는 이 값이 "9.00"
  Name="Win32ConsoleApp"
  ProjectGUID="{150B5BFA-0F3F-484D-B034-8595291F182F}"
  RootNamespace="Win32ConsoleApp"
  Keyword="Win32Proj"
  >

이 때문에, VS.NET 2005용 프로젝트를 Orcas로 마이그레이션 하고 싶다면 위의 버전 값만 "9.00"으로 바꿔주는 것으로 끝납니다. 하지만 이 프로젝트를 VS.NET 2005에서 로드를 하게 되면 다음과 같은 오류가 발생합니다.

orcas_migration_issue_2.png

"
The following error has occurred during XML parsing:

File: D:\temp\uacTest\Win32ConsoleApp\Win32ConsoleApp.vcproj
Line: 9
Column: 2
Error Message:
'9.00' violates enumeration constraint of '7.00 7,00 7.10 7,10 8.00 8,00'.
The attribute 'Version' with value '9.00' failed to parse.

The file 'D:\temp\uacTest\Win32ConsoleApp\Win32ConsoleApp.vcproj' has failed to load.
"



정말 아쉽지요... 차라리 특별한 차이가 없다면 버전을 올리지 않는 것도 방법이었을 텐데. 아니면, VS.NET 2005에서 9.0을 그냥 8.0으로 인식해서 처리해 주는 간단한 패치가 나오는 것도 좋은 방법일 것 같고.




자... 그럼 마이그레이션에서 발생한 이슈를 좀 알아볼까요? VS.NET 2003에서 VS.NET 2005로 넘어올 때의 이슈에 비해서는 확실히 많이 줄어들었습니다. 단 2가지 문제만 있었으니.

이슈 1: 정규식 사용
음... 아직 VC++ 2005에서 정규식 클래스가 제공된다는 사실조차도 모를 분이 많을래나??? ^^;
어쨌든, 마이그레이션 중인 VC++ 프로젝트에서는 VC++ 2005의 ATL에서 기본제공되는 정규식 클래스 - CAtlRegExp를 사용하고 있었습니다.

그런데, Orcas에서 해당 클래스를 컴파일하지 못하더군요. 이유인 즉, 현재의 Orcas에 포함된 atl 클래스 중에서 CAtlRegExp 클래스 정의를 포함한 헤더 파일이 누락되어 있기 때문이었습니다. (사실, ATL Server 관련한 헤더 파일들이 모두 누락되어 있습니다.)

원래, VC++ 2005에서는 다음의 폴더에 있었는데,

C:\Program Files (x86)\Microsoft Visual Studio 8\VC\atlmfc\include\

Orcas에서의 폴더 "C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\atlmfc\include"에는 해당 파일이 아예 없었습니다. 하지만, ATL 클래스이다 보니 해결 방법도 그리 어렵지 않았습니다. 간단하게 VC++ 2005에 있는 파일을 복사해도 될 것 같았지만, 검색 결과 알아낸 다음의 Orcas 폴더에 있는 파일을 복사해서 해결했습니다.

C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\ce\atlmfc\include\atlrx.h

아마도 이 문제는 "C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\atlmfc\include" 폴더의 내용이 아직 정리가 안 되어서 나타난 것으로 보이는데, 향후 정식 버전에서는 이러한 마이그레이션 이슈는 없을 것으로 예상이 됩니다.

이슈 2: INTERNETFEATURELIST 정의
이 문제를 보니,,, Windows 98/ME 등이 빨라 사라져 주길 바라는 마음이 다시 간절해지는군요.

제가 마이그레이션을 한 제품의 목표 하나가 바로, Windows 98의 지원이었습니다. 내부적으로, CoInternetSetFeatureEnabled 함수를 사용해야하는 상황이었는데, Win 98에서는 해당 함수가 지원되지 않기 때문에 GetProceAddress를 사용한 함수 호출을 했습니다. 해당 함수의 정의는 다음과 같이 간단하게 포함해 주었고.

typedef  HRESULT (__stdcall *CoInternetSetFeatureEnabled_Proc)
( INTERNETFEATURELIST FeatureEntry, DWORD dwFlags, BOOL fEnable );

그런데, VS.NET 2005에서는 멀쩡하게 빌드가 잘 되던 것이, Orcas에서 빌드하면서 "INTERNETFEATURELIST" 정의가 없다면서 빌드가 실패해 버렸습니다.

INTERNETFEATURELIST 정의가 들어 있는 "urnmon.h" 파일을 보니 다음과 같이 매크로 상수 컴파일 조건이 들어있었습니다.

#if (_WIN32_IE >= _WIN32_IE_IE60SP2)
#ifndef _INTERNETFEATURELIST_DEFINED
#define _INTERNETFEATURELIST_DEFINED
typedef 
enum _tagINTERNETFEATURELIST
    { FEATURE_OBJECT_CACHING  = 0,
  [ 중간 생략 ],
    }   INTERNETFEATURELIST;

#endif

문제인 즉, VS.NET 2005에 포함된 VC++ 헤더 파일에는 _WIN32_IE_IE60SP2 정의 자체가 없었을 뿐더러, 기존에는 _WIN32_IE 값이 다음과 같이 정의되어 있었습니다.

#define _WIN32_IE 0x0501

저는, 여차하면 마이그레이션이 실패하는 경우 다시 VS.NET 2005로 개발을 계속해야 했기 때문에 이 부분을 다음과 같이 정의하는 것으로 마무리 지었습니다.

#if (_CPPLIB_VER < 503)
#define _WIN32_IE_IE60SP2 0x0603
#endif

#ifndef _WIN32_IE   
#define _WIN32_IE _WIN32_IE_IE60SP2 
#endif

RTM 버전이 나와도 _CPPLIB_VER의 값이 503은 적어도 넘을 테니 별 상관없을 듯 보입니다.




자,,, 여기까지가 마이그레이션으로 인한 문제의 전부였습니다. 너무 재미가 없었나요?

그 외에, Orcas에서 솔루션 단위의 체크인/체크아웃을 할 때 비정상 종료 현상이 나타나기는 했지만 이 부분은 정확한 버그 재현이 힘들어서, 그냥 임의로 프로젝트 구조를 변경하는 식으로 해결을 해버린 탓에, 이와 관련해서는 이야기할 것이 없어져 버렸습니다.

시간 나실 때... 가벼운 마음으로 한번 마이그레이션을 해보시지요. 재미있는 "/MP" 옵션도 있으니... ^^







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







[최초 등록일: ]
[최종 수정일: 6/28/2021]

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

비밀번호

댓글 작성자
 




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/20253522닷넷: 2318. C# - (async Task가 아닌) async void 사용 시의 부작용파일 다운로드1
13883정성태2/12/20253266닷넷: 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/20253708닷넷: 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/20253731개발 환경 구성: 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  ...