diff options
author | Zachary Scott <zachary@zacharyscott.net> | 2012-04-12 20:24:35 -0400 |
---|---|---|
committer | Nathan Rajlich <nathan@tootallnate.net> | 2012-04-12 18:32:01 -0700 |
commit | 46acb09ed83958e7f3f06b9548f73f245d503b9f (patch) | |
tree | 54645b331c1a021e208d95591af5e89379a51fab /doc | |
parent | 1444801374bafb9a467a7ddeb214a9f92b311b80 (diff) | |
download | android-node-v8-46acb09ed83958e7f3f06b9548f73f245d503b9f.tar.gz android-node-v8-46acb09ed83958e7f3f06b9548f73f245d503b9f.tar.bz2 android-node-v8-46acb09ed83958e7f3f06b9548f73f245d503b9f.zip |
docs: rewrite "addons" docs to use node-gyp
Closes #3100.
Closes #3101.
Diffstat (limited to 'doc')
-rw-r--r-- | doc/api/addons.markdown | 78 |
1 files changed, 37 insertions, 41 deletions
diff --git a/doc/api/addons.markdown b/doc/api/addons.markdown index ee9f20142e..df42815fbc 100644 --- a/doc/api/addons.markdown +++ b/doc/api/addons.markdown @@ -60,40 +60,38 @@ The `module_name` needs to match the filename of the final binary (minus the .node suffix). The source code needs to be built into `hello.node`, the binary Addon. To -do this we create a file called `wscript` which is python code and looks -like this: - - srcdir = '.' - blddir = 'build' - VERSION = '0.0.1' - - def set_options(opt): - opt.tool_options('compiler_cxx') - - def configure(conf): - conf.check_tool('compiler_cxx') - conf.check_tool('node_addon') +do this we create a file called `binding.gyp` which describes the configuration +to build your module in a JSON-like format. This file gets compiled by +[node-gyp](https://github.com/TooTallNate/node-gyp). + + { + "targets": [ + { + "target_name": "hello", + "sources": [ "hello.cc" ] + } + ] + } - def build(bld): - obj = bld.new_task_gen('cxx', 'shlib', 'node_addon') - obj.target = 'hello' - obj.source = 'hello.cc' +The next step is to generate the appropriate project build files for the +current platform. Use `node-gyp configure` for that. -Running `node-waf configure build` will create a file -`build/default/hello.node` which is our Addon. +Now you will have either a `Makefile` (on Unix platforms) or a `vcxproj` file +(on Windows) in the `build/` directory. Next invoke the `node-gyp build` +command. -`node-waf` is just [WAF](http://code.google.com/p/waf), the python-based build system. `node-waf` is -provided for the ease of users. +Now you have your compiled `.node` bindings file! The compiled bindings end up +in `build/Release/`. You can now use the binary addon in a Node project `hello.js` by pointing `require` to -the recently built module: +the recently built `hello.node` module: var addon = require('./build/Release/hello'); console.log(addon.hello()); // 'world' Please see patterns below for further information or -<https://github.com/pietern/hiredis-node> for an example in production. +<https://github.com/arturadib/node-qt> for an example in production. ## Addon patterns @@ -104,29 +102,27 @@ calls, and v8's [Embedder's Guide](http://code.google.com/apis/v8/embed.html) for an explanation of several concepts used such as handles, scopes, function templates, etc. -To compile these examples, create the `wscript` file below and run -`node-waf configure build`: +In order to use these examples you need to compile them using `node-gyp`. +Create the following `binding.gyp` file: - srcdir = '.' - blddir = 'build' - VERSION = '0.0.1' - - def set_options(opt): - opt.tool_options('compiler_cxx') + { + "targets": [ + { + "target_name": "addon", + "sources": [ "addon.cc" ] + } + ] + } - def configure(conf): - conf.check_tool('compiler_cxx') - conf.check_tool('node_addon') +In cases where there is more than one `.cc` file, simply add the file name to the +`sources` array, e.g.: - def build(bld): - obj = bld.new_task_gen('cxx', 'shlib', 'node_addon') - obj.target = 'addon' - obj.source = ['addon.cc'] + "sources": ["addon.cc", "myexample.cc"] -In cases where there is more than one `.cc` file, simply add the file name to the -`obj.source` array, e.g.: +Now that you have your `binding.gyp` ready, you can configure and build the +addon: - obj.source = ['addon.cc', 'myexample.cc'] + $ node-gyp configure build ### Function arguments |