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

CoreFx, CoreCLR 빌드 시 "error CS0518: Predefined type 'System.Object' is not defined or imported" 오류 해결 방법

CoreFx, CoreCLR 빌드 시에,

.NETCore = CoreFX + CoreCLR
; https://www.sysnet.pe.kr/2/0/2884

"Couldn't find a matching group" 또는 "error CS0518: Predefined type 'System.Object' is not defined or imported"라는 오류 메시지를 만날 수 있습니다.

E:\corefx>build.cmd
  Restoring build tools...
  System.Collections.Immutable -> E:\corefx\bin\Windows_NT.AnyCPU.Debug\System.Collections.Immutabl  e\System.Collections.Immutable.dll
E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\packageresolve.targets(42,5): warning : Unable to resolve the assets of System.Runtime: Couldn't find a matching group [E:\corefx\src\Microsoft.Win32.Primitives\src\Microsoft.Win32.Primitives.csproj]
E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\packageresolve.targets(42,5): warning : Unable to resolve the assets of System.Runtime.InteropServices: Couldn't find a matching group [E:\corefx\src\Microsoft.Win32.Primitives\src\Microsoft.Win32.Primitives.csproj]
E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\packageresolve.targets(42,5): warning : Unable to resolve the assets of System.Resources.ResourceManager: Couldn't find a matching group [E:\corefx\src\Microsoft.Win32.Primitives\src\Microsoft.Win32.Primitives.csproj]
CSC : error CS0518: Predefined type 'System.Object' is not defined or imported [E:\corefx\src\Microsoft.Win32.Primitives\src\Microsoft.Win32.Primitives.csproj]
E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\packageresolve.targets(42,5): warning : Unable to resolve the assets of System.ComponentModel: Couldn't find a matching group [E:\corefx\src\System.ComponentModel.Primitives\src\System.ComponentModel.Primitives.csproj]
E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\packageresolve.targets(42,5): warning : Unable to resolve the assets of System.Resources.ResourceManager: Couldn't find a matching group [E:\corefx\src\System.ComponentModel.Primitives\src\System.ComponentModel.Primitives.csproj]
E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\packageresolve.targets(42,5): warning : Unable to resolve the assets of System.Runtime: Couldn't find a matching group [E:\corefx\src\System.ComponentModel.Primitives\src\System.ComponentModel.Primitives.csproj]
CSC : error CS0518: Predefined type 'System.Object' is not defined or imported [E:\corefx\src\System.ComponentModel.Primitives\src\System.ComponentModel.Primitives.csproj]

build.cmd와 같은 폴더에 있는 msbuild.log 파일을 보면 csc.exe를 직접 실행할 수 있는 명령행 로그를 볼 수 있고, 이를 찾아 직접 실행해봐도 역시 마찬가지 오류가 발생하는 것을 확인할 수 있습니다.

// FrameworkPathOverride = C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETPortable\v4.5\Profile\Profile7
// FrameworkRegistryBase = Software\Microsoft\.NETPortable
// HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\12.0_Config\SupportedRuntimesForFxFamily\.NETPortable

cd E:\corefx\src\Microsoft.Win32.Primitives\src

E:\corefx\src\Microsoft.Win32.Primitives\src>"C:\Program Files (x86)\MSBuild\12.0\bin\Csc.exe" /noconfig /unsafe+ /nowarn:1701,1702 /nostdlib+ /define:DEBUG;TRACE;SIGNED /reference:"C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETPortable\v4.5\Profile\Profile7\mscorlib.dll" /debug+ /debug:full /delaysign+ /keyfile:E:\corefx\packages\Microsoft.DotNet.BuildTools.1.0.25-prerelease-00017\lib\MSFT.snk /optimize- /out:E:\corefx\bin\obj\Windows_NT.AnyCPU.Debug\Microsoft.Win32.Primitives\Microsoft.Win32.Primitives.dll /target:library /utf8output Interop\Interop.cs System\ComponentModel\Win32Exception.cs E:\corefx\src\Common\src\Interop\Windows\Interop.Libraries.cs E:\corefx\src\Common\src\Interop\Windows\mincore\Interop.FormatMessage.cs System\ComponentModel\Win32Exception.Windows.cs E:\corefx\bin\obj\Windows_NT.AnyCPU.Debug\Microsoft.Win32.Primitives\_AssemblyInfo.cs Microsoft (R) Visual C# Compiler version 12.0.31101.0
for C# 5
Copyright (C) Microsoft Corporation. All rights reserved.

error CS0518: Predefined type 'System.Object' is not defined or imported


이와 관련해서 검색해 보면, 다행히 답이 나옵니다. ^^

Corefx build fails when Xamarin PCL profiles are installed
; https://github.com/dotnet/corefx/issues/449

즉, Xamarin이 설치한 Portable Class Library에 대한 빌드 프로파일 설정이 영향을 미친 것입니다. 어쩔 수 없습니다. Xamarin 측이든 마이크로소프트든 이 문제를 해결하기 전까지는 Xamarin 측의 프로파일 파일을 제거해야 합니다.

그래도 Xamarin 제품을 설치 제거하는 것은 좀 그러하니... ^^; 다음과 같이 기존 Profile 폴더를 일단 백업 시켜 두고,

robocopy "C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETPortable\v4.5\Profile" "e:\netportable_profile_backup" /S

이렇게 Xamarin.Android.xml, Xamarin.iOS.xml 파일을 삭제해 주시면 됩니다.

cd "C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETPortable\v4.5\Profile"
del /s Xamarin.Android.xml
del /s Xamarin.iOS.xml

이후, 다시 cmd.exe 창을 띄우고 CoreClr, CoreFx의 build.cmd를 실행해 주면 Test 프로젝트까지 아주 깨끗하게 빌드되는 것을 확인할 수 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/13/2015]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  128  129  130  131  [132]  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
1845정성태1/26/201536869Windows: 101. 제어판의 "Windows 자격 증명 관리(Manage your credentials)"를 금지시키는 방법
1844정성태1/26/201533889오류 유형: 269. USB 메모리의 용량이 비정상적으로 보여진다면? [7]
1843정성태1/24/201525234VC++: 87. 무시할 수 없는 Visual C++ 런타임 함수 성능
1842정성태1/23/201549010개발 환경 구성: 255. 노트북 키보드에 없는 BREAK 키를 다른 키로 대체하는 방법
1841정성태1/21/201522602오류 유형: 268. Win32 핸들 관련 CLR4 보안 오류 사례
1840정성태1/8/201530934오류 유형: 267. Visual Studio - CodeLens 사용 시 CPU 100% 현상
1839정성태1/5/201523337디버깅 기술: 69. windbg 분석 사례 - cpu 100% 현상 (2)
1838정성태1/4/201544069기타: 49. 윈도우 내레이터(Narrator) 기능 끄는 방법(윈도우에 파란색의 굵은 테두리 선이 나타난다면?) [4]
1837정성태1/4/201530168디버깅 기술: 68. windbg 분석 사례 - 메모리 부족 [1]
1836정성태1/4/201530078디버깅 기술: 67. windbg - 덤프 파일과 handle 정보
1835정성태1/3/201530944개발 환경 구성: 254. SQL 서버 역시 SSL 3.0/TLS 1.0만을 지원하는 듯!
1834정성태1/3/201555549개발 환경 구성: 253. TLS 1.2를 적용한 IIS 웹 사이트 구성
1833정성태1/3/201531875.NET Framework: 490. System.Data.SqlClient는 SSL 3.0/TLS 1.0만 지원하는 듯! [3]
1832정성태1/2/201523524오류 유형: 266. Azure에 응용 프로그램 게시 중 로그인 오류
1831정성태1/1/201532251디버깅 기술: 66. windbg 분석 사례 - cpu 100% 현상 (1) [1]
1830정성태1/1/201531584오류 유형: 265. svchost.exe 프로세스(IP Helper: IPHLPSVC)의 CPU 100% 현상
1829정성태12/16/201435243VC++: 86. Windows Vista부터 바뀐 Credential Provider 예제 분석 (2) [2]파일 다운로드1
1828정성태12/15/201431867VC++: 85. Windows Vista부터 바뀐 Credential Provider 예제 분석 (1) [4]파일 다운로드1
1827정성태12/12/201428088VC++: 84. CredUIPromptForWindowsCredentials Win32 API 사용법 정리
1826정성태12/11/201432397.NET Framework: 489. Socket.Listen에 전달된 backlog 인자의 의미 [6]
1825정성태12/11/201480162.NET Framework: 488. TCP 소켓 연결의 해제를 알 수 있는 방법 [10]파일 다운로드1
1824정성태12/10/201429363.NET Framework: 487. Socket.Receive 메서드의 SocketFlags.Peek 동작을 이용해 소켓 연결 유무를 확인? [8]파일 다운로드1
1823정성태12/10/201426645.NET Framework: 486. Java의 ScheduledExecutorService에 대응하는 C#의 System.Threading.Timer [2]
1822정성태12/3/201428096개발 환경 구성: 252. Xamarin 라이선스 관리 [8]
1821정성태12/1/201435658VS.NET IDE: 96. Visual Studio에서 /* ~ */ 주석을 위한 단축키(매크로)
1820정성태11/23/201423153.NET Framework: 485. Mono Profiler에서 IL 코드 변경이 가능할까? - 두 번째 이야기파일 다운로드1
... 121  122  123  124  125  126  127  128  129  130  131  [132]  133  134  135  ...