Microsoft MVP성태의 닷넷 이야기
.NET Framework: 507. CoreFx 빌드하는 방법 [링크 복사], [링크+제목 복사],
조회: 24794
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

CoreFx 빌드하는 방법

지난 글에서 CoreCLR에 대한 빌드 방법을 소개했고,

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

기존에 Xamrin이 설치된 경우 빌드 실패가 발생하는 현상도 설명했습니다.

CoreFx, CoreCLR 빌드 시 "error CS0518: Predefined type 'System.Object' is not defined or imported" 오류 해결 방법
; https://www.sysnet.pe.kr/2/0/2886

이제 CoreFX를 빌드해 볼까요? CoreFX는 .NET Framework로 치면 mscorlib.dll을 제외한 다른 클래스 라이브러리를 포함하고 있는 모듈들입니다. 역시 소스코드가 공개되었으니 아래의 github에서 .zip 파일로 다운로드 받거나,

dotnet/corefx 
; https://github.com/dotnet/corefx

아니면 git clone 명령어로 내려받으시면 됩니다.

E:\corefx>"C:\Program Files (x86)\Git\bin\git" clone https://github.com/dotnet/corefx.git .
Cloning into '.'...
remote: Counting objects: 2689, done.
remote: Total 2689 (delta 0), reused 0 (delta 0), pack-reused 2689
Receiving objects: 100% (2689/2689), 2.18 MiB | 564.00 KiB/s, done.
Resolving deltas: 100% (1480/1480), done.
Checking connectivity... done.
Checking out files: 100% (736/736), done.

보다시피, 저는 E:\corefx 폴더에 압축을 풀었습니다. 빌드는 다음의 문서에 따라 환경 구성하고 빌드합니다.

Developer Guide
; https://github.com/dotnet/corefx/wiki/Developer-Guide

근데, 사실 할 것이 없습니다. ^^ CoreClr은 cmake, DIA SDK가 필요했지만 CoreFX는 Visual Studio만 필요하기 때문입니다. 그래서 다운로드 받은 위치에 있는 build.cmd만 실행해 주시면 됩니다.

E:\corefx>build.cmd
  Restoring build tools...
  System.Collections.Immutable -> E:\corefx\bin\Windows_NT.AnyCPU.Debug\System.Collections.Immutable\System.Collections.Immutable.dll
  Microsoft.Win32.Primitives -> E:\corefx\bin\Windows_NT.AnyCPU.Debug\Microsoft.Win32.Primitives\Microsoft.Win32.Primitives.dll
  System.Collections.NonGeneric -> E:\corefx\bin\Windows_NT.AnyCPU.Debug\System.Collections.NonGeneric\System.Collections.NonGeneric.dll
  System.Collections.Concurrent -> E:\corefx\bin\Windows_NT.AnyCPU.Debug\System.Collections.Concurrent\System.Collections.Concurrent.dll
  System.ComponentModel.EventBasedAsync -> E:\corefx\bin\Windows_NT.AnyCPU.Debug\System.ComponentModel.EventBasedAsync\System.ComponentModel.EventBasedAsync  .dll

...[생략]...

  Discovering: Axes.Tests
  Discovered:  Axes.Tests
  Starting:    Axes.Tests
  Finished:    Axes.Tests

  === TEST EXECUTION SUMMARY ===
     Axes.Tests  Total: 35, Errors: 0, Failed: 0, Skipped: 0, Time: 0.148s

    2 Warning(s)
    2 Error(s)
Time Elapsed 00:01:40.66
Build Exit Code = 1

중간에 있는 2개의 실패는, Microsoft.Win32.Registry.Tests 등의 테스트에서 실패한 것인데... 그냥 넘어가겠습니다. ^^

한가지 좀 귀찮은 것이 있다면 프로젝트 별로 각각의 폴더에 복사되기 때문에 여러 개의 DLL을 참조하려면 꽤나 귀찮은 작업이 필요하게 됩니다. 일단은 임시로 다음과 같은 PowerShell 스크립트를 실행해 주시면 e:\corefx\debug 폴더에 모이게 할 수 있습니다.

cls

$basePath = "E:\corefx\bin\Windows_NT.AnyCPU.Debug"
$targetPath = "E:\corefx\debug"

$files = Get-ChildItem -Name -Path $basePath  -Recurse -File -Filter System.*.dll -Exclude *.Tests.dll | sort Name


ForEach ($file in $files)
{
    if ($file.IndexOf(".Tests\") -eq -1)
    {
        $filePath = $basePath + "\" + $file
        Copy-Item $filePath -Destination $targetPath

        $filePath

        $pdbPath = [System.IO.Path]::ChangeExtension($filePath, ".pdb")
        if ([System.IO.File]::Exists($pdbPath))
        {
            Copy-Item $pdbPath -Destination $targetPath
        }
    }
}




제가 2대의 컴퓨터에서 빌드해봤는데, 하나는 아무런 오류없이 잘 되었지만 한 대의 PC에서는 다음과 같이 xunit.runners 패키지 처리 단계에서 오류가 발생했습니다.

E:\corefx>build.cmd
  Unable to resolve dependency 'xunit.runners (≥ 2.0.0-beta4-build2738)'.
E:\corefx\build.proj(80,5): error MSB3073: The command ""E:\corefx\bin\tools\NuGet.exe" install Microsoft.DotNet.BuildTools -Prerelease -Version 1.0.13-prerelease -o " E:\corefx\src\packages\ " -ConfigFile "E:\corefx\src\nuget\NuGet.Config"" exited with code 1.

검색해 보면 이것을 수작업으로 처리했다고 나옵니다.

build.cmd can fail to install xunit.runners package? #130
; https://github.com/dotnet/corefx/issues/130

그래서 다음과 같이 한번 실행해 주면 해결됩니다.

E:\corefx>"E:\corefx\bin\tools\NuGet.exe" install xunit.runners -Prerelease -Version 2.0.0-beta4-build2738 -o " E:\corefx\src\packages\ " -ConfigFile "E:\corefx\src\nuget\NuGet.Config"
 Installing 'xunit.runners 2.0.0-beta4-build2738'.
 Successfully installed 'xunit.runners 2.0.0-beta4-build2738'.




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







[최초 등록일: ]
[최종 수정일: 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)
1797정성태11/4/201421089오류 유형: 255. 이벤트 로그 - The Adobe Flash Player Update Service service entered the stopped state.
1796정성태10/30/201428353개발 환경 구성: 249. Visual Studio 2013에서 Mono 컴파일하는 방법
1795정성태10/29/201430211개발 환경 구성: 248. Lync 2013 서버 설치 방법
1794정성태10/29/201425751개발 환경 구성: 247. "Microsoft Office 365 Enterprise E3" 서비스에 대한 간략 소개
1793정성태10/27/201426853.NET Framework: 474. C# - chromiumembedded 사용 - 두 번째 이야기 [2]파일 다운로드1
1792정성태10/27/201426920.NET Framework: 473. WebClient 객체에 쿠키(Cookie)를 사용하는 방법
1791정성태10/22/201426376VC++: 83. G++ - 템플릿 클래스의 iterator 코드 사용에서 발생하는 컴파일 오류 [5]
1790정성태10/22/201421089오류 유형: 254. NETLOGON Service is paused on [... AD Server...]
1789정성태10/22/201425008오류 유형: 253. 이벤트 로그 - The client-side extension could not remove user policy settings for '...'
1788정성태10/22/201426299VC++: 82. COM 프로그래밍에서 HRESULT 타입의 S_FALSE는 실패일까요? 성공일까요? [2]
1787정성태10/22/201435050오류 유형: 252. COM 개체 등록시 0x8002801C 오류가 발생한다면?
1786정성태10/22/201436548디버깅 기술: 65. 프로세스 비정상 종료 시 "Debug Diagnostic Tool"를 이용해 덤프를 남기는 방법 [3]파일 다운로드1
1785정성태10/22/201425836오류 유형: 251. 이벤트 로그 - Load control template file /_controltemplates/TaxonomyPicker.ascx failed [1]
1784정성태10/22/201432680.NET Framework: 472. C/C++과 C# 사이의 메모리 할당/해제 방법파일 다운로드1
1783정성태10/21/201426720VC++: 81. 프로그래밍에서 borrowing의 개념
1782정성태10/21/201423717오류 유형: 250. 이벤트 로그 - Application Server job failed for service instance Microsoft.Office.Server.Search.Administration.SearchServiceInstance
1781정성태10/21/201424784디버깅 기술: 64. new/delete의 짝이 맞는 경우에도 메모리 누수가 발생한다면?
1780정성태10/15/201428323오류 유형: 249. The application-specific permission settings do not grant Local Activation permission for the COM Server application with CLSID
1779정성태10/15/201423450오류 유형: 248. Active Directory에서 OU가 지워지지 않는 경우
1778정성태10/10/201421886오류 유형: 247. The Netlogon service could not create server share C:\Windows\SYSVOL\sysvol\[도메인명]\SCRIPTS.
1777정성태10/10/201424902오류 유형: 246. The processing of Group Policy failed. Windows attempted to read the file \\[도메인]\sysvol\[도메인]\Policies\{...GUID...}\gpt.ini
1776정성태10/10/201421730오류 유형: 245. 이벤트 로그 - Name resolution for the name _ldap._tcp.dc._msdcs.[도메인명]. timed out after none of the configured DNS servers responded.
1775정성태10/9/201423291오류 유형: 244. Visual Studio 디버깅 (2) - Unable to break execution. This process is not currently executing the type of code that you selected to debug.
1774정성태10/9/201429805개발 환경 구성: 246. IIS 작업자 프로세스의 20분 자동 재생(Recycle)을 끄는 방법
1773정성태10/8/201433369.NET Framework: 471. 웹 브라우저로 다운로드가 되는 파일을 왜 C# 코드로 하면 안되는 걸까요? [1]
1772정성태10/3/201422179.NET Framework: 470. C# 3.0의 기본 인자(default parameter)가 .NET 1.1/2.0에서도 실행될까? [3]
... 121  122  123  124  125  126  127  128  129  130  131  132  133  [134]  135  ...