electron/docs-translations/ko/development/build-instructions-windows.md
2015-09-01 09:57:43 +09:00

4.7 KiB

빌드 설명서 (Windows)

빌드전 요구 사항

현재 Windows를 설치하지 않았다면 modern.ie에서 사용 기한이 정해져있는 무료 가상머신 버전의 Windows를 받아 Electron을 빌드하는 방법도 있습니다.

Electron은 전적으로 command-line 스크립트를 사용하여 빌드합니다. 그렇기에 Electron을 개발하는데 아무런 에디터나 사용할 수 있습니다. 하지만 이 말은 Visual Studio를 개발을 위해 사용할 수 없다는 말이 됩니다. 나중에 Visual Studio를 이용한 빌드 방법도 제공할 예정입니다.

참고: Visual Studio가 빌드에 사용되지 않더라도 제공된 빌드 툴체인이 필수적으로 사용되므로 여전히 필요합니다.

코드 가져오기

git clone https://github.com/atom/electron.git

부트 스트랩

부트스트랩 스크립트는 필수적인 빌드 종속성 라이브러리들을 모두 다운로드하고 프로젝트 파일을 생성합니다. 참고로 Electron은 빌드 툴체인으로 ninja를 사용하므로 Visual Studio 프로젝트는 생성되지 않습니다.

cd electron
python script\bootstrap.py -v

빌드 하기

ReleaseDebug 두 타겟 모두 빌드 합니다:

python script\build.py

또는 Debug 타겟만 빌드 할 수 있습니다:

python script\build.py -c D

빌드가 모두 끝나면 out/D (디버그 타겟) 또는 out/R (릴리즈 타겟) 디렉터리에서 electron.exe 실행 파일을 찾을 수 있습니다.

64비트 빌드

64비트를 타겟으로 빌드 하려면 부트스트랩 스크립트를 실행할 때 --target_arch=x64 인자를 같이 넘겨주면 됩니다:

python script\bootstrap.py -v --target_arch=x64

다른 빌드 단계도 정확하게 같습니다.

테스트

프로젝트 코딩 스타일을 확인하려면:

python script\cpplint.py

테스트를 실행하려면:

python script\test.py

테스트 실행시 runas와 같은 네이티브 모듈을 포함하는데 이 모듈은 디버그 빌드에서 같이 사용할 수 없습니다. 하지만 여전히 릴리즈 빌드에선 사용할 수 있습니다.

릴리즈 빌드로 테스트를 실행하려면 다음 커맨드를 사용하면 됩니다:

python script\test.py -R

문제 해결

Command xxxx not found

만약 Command xxxx not found와 같은 형식의 에러가 발생했다면 VS2012 Command Prompt 콘솔로 빌드 스크립트를 실행해볼 필요가 있습니다.

Fatal internal compiler error: C1001

Visual Studio가 업데이트까지 완벽하게 설치된 최신버전인지 확인하세요.

Assertion failed: ((handle))->activecnt >= 0

Cygwin에서 빌드 할 경우 bootstrap.py 스크립트가 다음의 에러와 함께 빌드에 실패할 수 있습니다:

Assertion failed: ((handle))->activecnt >= 0, file src\win\pipe.c, line 1430

Traceback (most recent call last):
  File "script/bootstrap.py", line 87, in <module>
    sys.exit(main())
  File "script/bootstrap.py", line 22, in main
    update_node_modules('.')
  File "script/bootstrap.py", line 56, in update_node_modules
    execute([NPM, 'install'])
  File "/home/zcbenz/codes/raven/script/lib/util.py", line 118, in execute
    raise e
subprocess.CalledProcessError: Command '['npm.cmd', 'install']' returned non-zero exit status 3

이 버그는 Cygwin python과 Win32 node를 같이 사용할 때 발생합니다. 부트스트랩 스크립트에서 Win32 python을 사용함으로써 이 문제를 해결할 수 있습니다 (C:\Python27 디렉터리에 python이 설치되었다는 것을 가정하면):

/cygdrive/c/Python27/python.exe script/bootstrap.py

LNK1181: cannot open input file 'kernel32.lib'

32bit node.js를 다시 설치하세요.

Error: ENOENT, stat 'C:\Users\USERNAME\AppData\Roaming\npm'

간단하게 해당 디렉터리를 생성하면 문제가 해결될 겁니다:

mkdir ~\AppData\Roaming\npm

node-gyp is not recognized as an internal or external command

Git Bash로 빌드 했을 때 이러한 에러가 발생할 수 있습니다. 반드시 PowerShell이나 VS2012 Command Prompt에서 빌드를 진행해야 합니다.