136 lines
No EOL
3.9 KiB
Markdown
136 lines
No EOL
3.9 KiB
Markdown
# Build Instructions (Windows)
|
||
|
||
遵循下面的引导,在 Windows 上构建 Electron .
|
||
|
||
## 前提
|
||
|
||
* Windows 7 / Server 2008 R2 or higher
|
||
* Visual Studio 2013 with Update 4 - [download VS 2013 Community Edition for
|
||
free](https://www.visualstudio.com/news/vs2013-community-vs).
|
||
* [Python 2.7](http://www.python.org/download/releases/2.7/)
|
||
* [Node.js](http://nodejs.org/download/)
|
||
* [Git](http://git-scm.com)
|
||
|
||
如果你现在还没有安装 Windows , [modern.ie](https://www.modern.ie/en-us/virtualization-tools#downloads) 有一个 timebombed 版本的 Windows ,你可以用它来构建 Electron.
|
||
|
||
构建 Electron 完全的依赖于命令行,并且不可通过 Visual Studio.
|
||
可以使用任何的编辑器来开发 Electron ,未来会支持 Visual Studio.
|
||
|
||
**注意:** 虽然 Visual Studio 不是用来构建的,但是它仍然
|
||
**必须的** ,因为我们需要它提供的构建工具栏.
|
||
|
||
**注意:** Visual Studio 2015 不可用. 请确定使用 MSVS
|
||
**2013**.
|
||
|
||
## 获取代码
|
||
|
||
```powershell
|
||
$ git clone https://github.com/atom/electron.git
|
||
```
|
||
|
||
## Bootstrapping
|
||
|
||
bootstrap 脚本也是必要下载的构建依赖,来创建项目文件.注意我们使用的是 `ninja` 来构建 Electron,所以没有生成 Visual Studio 项目.
|
||
|
||
```powershell
|
||
$ cd electron
|
||
$ python script\bootstrap.py -v
|
||
```
|
||
|
||
## 构建
|
||
|
||
创建 `Release` 、 `Debug` target:
|
||
|
||
```powershell
|
||
$ python script\build.py
|
||
```
|
||
|
||
可以只创建 `Debug` target:
|
||
|
||
```powershell
|
||
$ python script\build.py -c D
|
||
```
|
||
|
||
创建完毕, 可以在 `out/D`(debug target) 或 `out\R` (release target) 下面找到 `electron.exe`.
|
||
|
||
## 64bit Build
|
||
|
||
为了构建64位的 target,在运行 bootstrap 脚本的时候需要使用 `--target_arch=x64` :
|
||
|
||
```powershell
|
||
$ python script\bootstrap.py -v --target_arch=x64
|
||
```
|
||
|
||
其他构建步骤完全相同.
|
||
|
||
## Tests
|
||
|
||
测试你的修改是否符合项目代码风格,使用:
|
||
|
||
```powershell
|
||
$ python script\cpplint.py
|
||
```
|
||
|
||
测试有效性使用:
|
||
|
||
```powershell
|
||
$ python script\test.py
|
||
```
|
||
在构建 debug 时为 Tests包含原生模块 (例如 `runas`) 将不会执行(详情 [#2558](https://github.com/atom/electron/issues/2558)), 但是它们在构建 release 会起效.
|
||
|
||
运行 release 构建使用 :
|
||
|
||
```powershell
|
||
$ 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 造成的 bug.解决办法就是使用 Win32 Python 执行 bootstrap 脚本 (假定你已经在目录 `C:\Python27` 下安装了 Python):
|
||
|
||
```powershell
|
||
$ /cygdrive/c/Python27/python.exe script/bootstrap.py
|
||
```
|
||
|
||
### LNK1181: cannot open input file 'kernel32.lib'
|
||
|
||
重新安装 32位的 Node.js.
|
||
|
||
### Error: ENOENT, stat 'C:\Users\USERNAME\AppData\Roaming\npm'
|
||
|
||
简单创建目录 [应该可以解决问题](http://stackoverflow.com/a/25095327/102704):
|
||
|
||
```powershell
|
||
$ mkdir ~\AppData\Roaming\npm
|
||
```
|
||
|
||
### node-gyp is not recognized as an internal or external command
|
||
|
||
如果你使用 Git Bash 来构建,或许会遇到这个错误,可以使用 PowerShell 或 VS2012 Command Prompt 来代替 . |