2012-03-15 07:39:15 +08:00
|
|
|
node-gyp
|
|
|
|
=========
|
|
|
|
### Node.js native addon build tool
|
|
|
|
|
|
|
|
`node-gyp` is a cross-platform command-line tool written in Node.js for compiling
|
2014-08-19 23:17:36 +08:00
|
|
|
native addon modules for Node.js. It bundles the [gyp](https://code.google.com/p/gyp/)
|
|
|
|
project used by the Chromium team and takes away the pain of dealing with the
|
2012-03-15 07:39:15 +08:00
|
|
|
various differences in build platforms. It is the replacement to the `node-waf`
|
|
|
|
program which is removed for node `v0.8`. If you have a native addon for node that
|
|
|
|
still has a `wscript` file, then you should definitely add a `binding.gyp` file
|
|
|
|
to support the latest versions of node.
|
|
|
|
|
2013-07-10 04:09:02 +08:00
|
|
|
Multiple target versions of node are supported (i.e. `0.8`, `0.9`, `0.10`, ..., `1.0`,
|
2012-03-15 07:39:15 +08:00
|
|
|
etc.), regardless of what version of node is actually installed on your system
|
|
|
|
(`node-gyp` downloads the necessary development files for the target version).
|
|
|
|
|
|
|
|
#### Features:
|
|
|
|
|
|
|
|
* Easy to use, consistent interface
|
|
|
|
* Same commands to build your module on every platform
|
|
|
|
* Supports multiple target versions of Node
|
|
|
|
|
|
|
|
|
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
|
|
|
You can install with `npm`:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
$ npm install -g node-gyp
|
|
|
|
```
|
|
|
|
|
|
|
|
You will also need to install:
|
|
|
|
|
|
|
|
* On Unix:
|
2013-05-31 01:19:45 +08:00
|
|
|
* `python` (`v2.7` recommended, `v3.x.x` is __*not*__ supported)
|
2012-03-15 07:39:15 +08:00
|
|
|
* `make`
|
|
|
|
* A proper C/C++ compiler toolchain, like GCC
|
|
|
|
* On Windows:
|
2012-12-22 00:42:29 +08:00
|
|
|
* [Python][windows-python] ([`v2.7.3`][windows-python-v2.7.3] recommended, `v3.x.x` is __*not*__ supported)
|
|
|
|
* Windows XP/Vista/7:
|
|
|
|
* Microsoft Visual Studio C++ 2010 ([Express][msvc2010] version works well)
|
2012-12-13 06:41:28 +08:00
|
|
|
* For 64-bit builds of node and native modules you will _**also**_ need the [Windows 7 64-bit SDK][win7sdk]
|
2013-02-07 00:39:27 +08:00
|
|
|
* If the install fails, try uninstalling any C++ 2010 x64&x86 Redistributable that you have installed first.
|
2012-12-22 00:42:29 +08:00
|
|
|
* If you get errors that the 64-bit compilers are not installed you may also need the [compiler update for the Windows SDK 7.1]
|
2013-05-31 01:19:45 +08:00
|
|
|
* Windows 7/8:
|
2012-12-22 00:42:29 +08:00
|
|
|
* Microsoft Visual Studio C++ 2012 for Windows Desktop ([Express][msvc2012] version works well)
|
2012-03-15 07:39:15 +08:00
|
|
|
|
2014-06-06 06:18:15 +08:00
|
|
|
If you have multiple Python versions installed, you can identify which Python
|
|
|
|
version `node-gyp` uses by setting the '--python' variable:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
$ node-gyp --python /path/to/python2.7
|
|
|
|
```
|
|
|
|
|
|
|
|
If `node-gyp` is called by way of `npm` *and* you have multiple versions of
|
|
|
|
Python installed, then you can set `npm`'s 'python' config key to the appropriate
|
|
|
|
value:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
$ npm config set python /path/to/executable/python2.7
|
|
|
|
```
|
|
|
|
|
2013-02-07 00:39:27 +08:00
|
|
|
Note that OS X is just a flavour of Unix and so needs `python`, `make`, and C/C++.
|
|
|
|
An easy way to obtain these is to install XCode from Apple,
|
|
|
|
and then use it to install the command line tools (under Preferences -> Downloads).
|
|
|
|
|
2012-03-15 07:39:15 +08:00
|
|
|
How to Use
|
|
|
|
----------
|
|
|
|
|
|
|
|
To compile your native addon, first go to its root directory:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
$ cd my_node_addon
|
|
|
|
```
|
|
|
|
|
|
|
|
The next step is to generate the appropriate project build files for the current
|
|
|
|
platform. Use `configure` for that:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
$ node-gyp configure
|
|
|
|
```
|
|
|
|
|
|
|
|
__Note__: The `configure` step looks for the `binding.gyp` file in the current
|
|
|
|
directory to processs. See below for instructions on creating the `binding.gyp` file.
|
|
|
|
|
|
|
|
Now you will have either a `Makefile` (on Unix platforms) or a `vcxproj` file
|
|
|
|
(on Windows) in the `build/` directory. Next invoke the `build` command:
|
|
|
|
|
|
|
|
``` bash
|
|
|
|
$ node-gyp build
|
|
|
|
```
|
|
|
|
|
|
|
|
Now you have your compiled `.node` bindings file! The compiled bindings end up
|
2012-05-27 13:36:04 +08:00
|
|
|
in `build/Debug/` or `build/Release/`, depending on the build mode. At this point
|
2012-03-15 07:39:15 +08:00
|
|
|
you can require the `.node` file with Node and run your tests!
|
|
|
|
|
|
|
|
__Note:__ To create a _Debug_ build of the bindings file, pass the `--debug` (or
|
|
|
|
`-d`) switch when running the either `configure` or `build` command.
|
|
|
|
|
|
|
|
|
2012-06-16 01:00:30 +08:00
|
|
|
The "binding.gyp" file
|
|
|
|
----------------------
|
2012-03-15 07:39:15 +08:00
|
|
|
|
|
|
|
Previously when node had `node-waf` you had to write a `wscript` file. The
|
|
|
|
replacement for that is the `binding.gyp` file, which describes the configuration
|
2012-06-16 01:00:30 +08:00
|
|
|
to build your module in a JSON-like format. This file gets placed in the root of
|
|
|
|
your package, alongside the `package.json` file.
|
|
|
|
|
|
|
|
A barebones `gyp` file appropriate for building a node addon looks like:
|
2012-03-15 07:39:15 +08:00
|
|
|
|
2013-05-31 01:19:45 +08:00
|
|
|
``` python
|
2012-03-15 07:39:15 +08:00
|
|
|
{
|
2012-03-29 10:36:44 +08:00
|
|
|
"targets": [
|
2012-03-15 07:39:15 +08:00
|
|
|
{
|
2012-03-29 10:36:44 +08:00
|
|
|
"target_name": "binding",
|
|
|
|
"sources": [ "src/binding.cc" ]
|
2012-03-15 07:39:15 +08:00
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2012-06-16 01:00:30 +08:00
|
|
|
Some additional resources for writing `gyp` files:
|
2012-03-15 07:39:15 +08:00
|
|
|
|
|
|
|
* ["Hello World" node addon example](https://github.com/joyent/node/tree/master/test/addons/hello-world)
|
|
|
|
* [gyp user documentation](http://code.google.com/p/gyp/wiki/GypUserDocumentation)
|
|
|
|
* [gyp input format reference](http://code.google.com/p/gyp/wiki/InputFormatReference)
|
2012-07-25 03:34:13 +08:00
|
|
|
* [*"binding.gyp" files out in the wild* wiki page](https://github.com/TooTallNate/node-gyp/wiki/%22binding.gyp%22-files-out-in-the-wild)
|
2012-03-15 07:39:15 +08:00
|
|
|
|
|
|
|
|
|
|
|
Commands
|
|
|
|
--------
|
|
|
|
|
|
|
|
`node-gyp` responds to the following commands:
|
|
|
|
|
2012-07-25 03:34:13 +08:00
|
|
|
| **Command** | **Description**
|
|
|
|
|:--------------|:---------------------------------------------------------------
|
|
|
|
| `build` | Invokes `make`/`msbuild.exe` and builds the native addon
|
|
|
|
| `clean` | Removes any the `build` dir if it exists
|
|
|
|
| `configure` | Generates project build files for the current platform
|
|
|
|
| `rebuild` | Runs "clean", "configure" and "build" all in a row
|
|
|
|
| `install` | Installs node development header files for the given version
|
|
|
|
| `list` | Lists the currently installed node development file versions
|
|
|
|
| `remove` | Removes the node development header files for the given version
|
2012-03-15 07:39:15 +08:00
|
|
|
|
|
|
|
|
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
|
|
|
(The MIT License)
|
|
|
|
|
|
|
|
Copyright (c) 2012 Nathan Rajlich <nathan@tootallnate.net>
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
a copy of this software and associated documentation files (the
|
|
|
|
'Software'), to deal in the Software without restriction, including
|
|
|
|
without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be
|
|
|
|
included in all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
|
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
|
|
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
|
|
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
|
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
|
|
|
|
|
|
|
|
[windows-python]: http://www.python.org/getit/windows
|
2012-09-25 23:28:55 +08:00
|
|
|
[windows-python-v2.7.3]: http://www.python.org/download/releases/2.7.3#download
|
2012-12-22 00:42:29 +08:00
|
|
|
[msvc2010]: http://go.microsoft.com/?linkid=9709949
|
|
|
|
[msvc2012]: http://go.microsoft.com/?linkid=9816758
|
|
|
|
[win7sdk]: http://www.microsoft.com/en-us/download/details.aspx?id=8279
|
2012-12-13 06:41:28 +08:00
|
|
|
[compiler update for the Windows SDK 7.1]: http://www.microsoft.com/en-us/download/details.aspx?id=4422
|