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)
10900정성태2/19/201622084.NET Framework: 548. Linq는 결국 메서드 호출! [3]파일 다운로드1
10899정성태2/17/201623401개발 환경 구성: 282. kernel32.dll, kernel32legacy.dll, api-ms-win-core-sysinfo-l1-2-0.dll [1]
10898정성태2/17/201621918.NET Framework: 547. PerformanceCounter의 InstanceName 지정 시 주의 사항파일 다운로드1
10897정성태2/17/201621271디버깅 기술: 76. windbg 분석 사례 - 닷넷 프로파일러의 GC 콜백 부하
10896정성태2/17/201622383오류 유형: 320. FATAL: 28000: no pg_hba.conf entry for host "fe80::1970:8120:695:a41e%12"
10895정성태2/17/201621201.NET Framework: 546. System.AppDomain으로부터 .NET Profiler의 AppDomainID 구하는 방법 [1]
10894정성태2/17/201621889오류 유형: 319. Visual Studio에서 찾기는 성공하지만 해당 소스 코드 정보가 보이지 않는 경우
10893정성태2/16/201620606.NET Framework: 545. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까? - 두 번째 이야기
10892정성태2/16/201621148오류 유형: 318. 탐색기에서 폴더 생성/삭제 시 몇 초 동안 멈추는 현상
10891정성태2/16/201624220VC++: 95. 내 CPU가 MPX/SGX를 지원할까요? [1]
10890정성태2/15/201624077.NET Framework: 544. C# 5의 Caller Info를 .NET 4.5 미만의 응용 프로그램에 적용하는 방법 [5]
10889정성태2/14/201620403.NET Framework: 543. C++의 inline asm 사용을 .NET으로 포팅하는 방법 - 두 번째 이야기파일 다운로드1
10888정성태2/14/201618714.NET Framework: 542. 닷넷 - 특정 클래스가 로드되었는지 여부를 알 수 있을까?
10887정성태2/3/201619420VC++: 94. MPX(Memory Protection Extensions) 테스트파일 다운로드1
10886정성태2/3/201620658개발 환경 구성: 281. Intel MPX Runtime Driver 수동 설치
10885정성태2/2/201620353오류 유형: 317. Sybase.Data.AseClient.AseException: The command has timed out.
10884정성태1/11/201621577개발 환경 구성: 280. 닷넷에서 SAP Adaptive Server Enterprise 데이터베이스 사용파일 다운로드1
10882정성태1/6/201620869Windows: 113. 윈도우의 2179, 26143, 47001 TCP 포트 사용 [1]
10881정성태1/3/201622230오류 유형: 316. 윈도우 10 - 바탕/돋음 체가 사라져 한글이 깨지는 현상 [2]
10880정성태12/16/201519998오류 유형: 315. 닷넷 프로파일러의 오류 코드 정보
10879정성태12/16/201521948오류 유형: 314. Error : DEP0700 : Registration of the app failed. error 0x80070005
10878정성태12/9/201524996디버깅 기술: 75. UWP(유니버설 윈도우 플랫폼) 앱에서 global::System.Diagnostics.Debugger.Break 예외 발생 시 대응 방법
10877정성태12/9/201529367VC++: 93. std::thread 사용 시 R6010 오류 [2]
10876정성태11/26/201525490.NET Framework: 541. SignedXml을 이용한 ds:Signature만드는 방법 [3]파일 다운로드1
10875정성태11/26/201530443개발 환경 구성: 279. signtool.exe의 다중 서명 기능 [2]
10874정성태11/26/201526414개발 환경 구성: 278. 인증서와 인증서를 이용한 코드 사인의 해시 구분
... [121]  122  123  124  125  126  127  128  129  130  131  132  133  134  135  ...