electron/docs/tutorial/using-native-node-modules.md

63 lines
2.1 KiB
Markdown
Raw Normal View History

2015-09-01 02:22:06 +00:00
# Using Native Node Modules
2013-09-09 07:35:57 +00:00
2015-04-16 03:31:12 +00:00
The native Node modules are supported by Electron, but since Electron is
using a different V8 version from official Node, you have to manually specify
2015-04-16 03:31:12 +00:00
the location of Electron's headers when building native modules.
2015-09-01 02:22:06 +00:00
## Native Node Module Compatibility
Since Node v0.11.x there were vital changes in the V8 API. So generally all
2015-09-01 02:22:06 +00:00
native modules written for Node v0.10.x won't work for newer Node or io.js
versions. And because Electron internally uses __io.js v3.1.0__, it has the
same problem.
To solve this, you should use modules that support Node v0.11.x or later,
[many modules](https://www.npmjs.org/browse/depended/nan) do support both now.
For old modules that only support Node v0.10.x, you should use the
2015-09-01 02:22:06 +00:00
[nan](https://github.com/rvagg/nan) module to port it to v0.11.x or later
versions of Node or io.js.
2015-09-01 02:22:06 +00:00
## How to Install Native Modules
Three ways to install native modules:
### The Easy Way
2015-09-01 02:22:06 +00:00
The most straightforward way to rebuild native modules is via the
[`electron-rebuild`](https://github.com/paulcbetts/electron-rebuild) package,
which handles the manual steps of downloading headers and building native modules:
```sh
npm install --save-dev electron-rebuild
2015-09-01 02:22:06 +00:00
# Every time you run npm install, run this
npm run electron-rebuild
```
2015-09-01 02:22:06 +00:00
### The node-gyp Way
2015-04-16 03:31:12 +00:00
To build Node modules with headers of Electron, you need to tell `node-gyp`
where to download headers and which version to use:
2013-08-14 22:43:35 +00:00
```bash
$ cd /path-to-module/
$ HOME=~/.electron-gyp node-gyp rebuild --target=0.29.1 --arch=x64 --dist-url=https://atom.io/download/atom-shell
2013-08-14 22:43:35 +00:00
```
2015-04-16 03:31:12 +00:00
The `HOME=~/.electron-gyp` changes where to find development headers. The
`--target=0.29.1` is version of Electron. The `--dist-url=...` specifies
where to download the headers. The `--arch=x64` says the module is built for
2015-05-01 18:28:17 +00:00
64bit system.
2013-08-14 22:43:35 +00:00
2015-09-01 02:22:06 +00:00
### The npm Way
2013-08-14 22:43:35 +00:00
2015-09-01 02:22:06 +00:00
You can also use `npm` to install modules. The steps are exactly the same with
Node modules, except that you need to setup some environment variables:
2013-08-14 22:43:35 +00:00
```bash
2015-05-04 03:13:43 +00:00
export npm_config_disturl=https://atom.io/download/atom-shell
export npm_config_target=0.29.1
export npm_config_arch=x64
2015-04-16 03:31:12 +00:00
HOME=~/.electron-gyp npm install module-name
```