发布你的第一个nodejs c++插件
之前分享了如何写一个nodejs的c++插件。今天分享一下如何发布一个c++插件。
github:https://github.com/theanarkh/learn-to-write-nodejs-addons
环境
1 ubuntu18.04。 2 安装nodejs v12和npm install node-gyp -g。
写代码
写一个测试的例子。test.cc
// hello.cc using N-API
#include <node_api.h>
namespace demo {
napi_value Method(napi_env env, napi_callback_info args) {
napi_value greeting;
napi_status status;
status = napi_create_string_utf8(env, "world", NAPI_AUTO_LENGTH, &greeting);
if (status != napi_ok) return nullptr;
return greeting;
}
napi_value init(napi_env env, napi_value exports) {
napi_status status;
napi_value fn;
status = napi_create_function(env, nullptr, 0, Method, nullptr, &fn);
if (status != napi_ok) return nullptr;
status = napi_set_named_property(env, exports, "hello", fn);
if (status != napi_ok) return nullptr;
return exports;
}
NAPI_MODULE(NODE_GYP_MODULE_NAME, init)
} // namespace demo
binding.gyp
{
"targets": [
{
"target_name": "test",
"sources": [ "./test.cc" ]
}
]
}
然后执行npm init。内容如下
{
"name": "test-addons",
"version": "1.0.1",
"description": "",
"main": "./build/Release/test.node",
"scripts": {
"test": "echo "Error: no test specified" && exit 1",
"install": "node-gyp rebuild"
},
"author": "",
"license": "ISC",
"gypfile": true
}
我们主要看和插件相关的两个配置
"main": "./build/Release/test.node",
"gypfile": true
main定义了插件的入口,因为我们没有为用户提供js的api。而是直接提供.node文件,所以这里定义的路径为插件的路径。gypfile标记这个包是一个c++插件,用户在使用npm安装这个包的时候,就会执行node-gyp rebuild,针对用户系统环境,生成对应的二进制代码。有些文章介绍了需要在scripts的值里加入"install": "node-gyp rebuild",npm文档说了如果包下面有.gyp文件的话,默认就会执行这个rebuild操作。
"scripts":{"install": "node-gyp rebuild"} If there is a binding.gyp file in the root of your package and you have not defined an install or preinstall script, npm will default the install command to compile using node-gyp.
一切准备就绪,我们可以执行npm publish发布了(记得先登录npm)。
测试
我们首先安装这个包。npm install test-addons --unsafe-perm(该参数可参考https://segmentfault.com/q/1010000019365121/),然后写代码测试一下。
var addon = require("test-addons/build/Release/test");
console.log(addon.hello());
我们发现,这样显然很麻烦。所以我们最好还是在包里为用户提供js模块的接口。我们在包里增加index.js
var addon = require("./build/Release/test");
module.exports = addon;
修改测试代码
var addon = require("test-addons");
console.log(addon.hello());
这就是编写和发布一个nodejs c++插件的大致流程。
- spring boot 登录注册 demo (四) -- 体验小结
- jenkins 时区设置
- 什么样的密码才是安全的?
- MAC本遭遇ARP攻击的处理办法
- nodejs 语法学习(持续更新)
- Django——模板层(template)(模板语法、自定义模板过滤器及标签、模板继承)
- - Templates should only be responsible for mapping the state to the UI. Avoid placing tags with side
- Django - - - -视图层之视图函数(views)
- fiddler mock ==> AutoResponder
- 基于Node.js开发跨平台窗口程序
- Django视图层之路由配置系统(urls)
- java String时间转为时间戳
- linux 简易启动脚本
- 2017年我国大数据产业发展五大新突破
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- LeetCode30|翻转单词顺序
- LeetCode28|最后一个单词的长度
- VS2015创建UWP报“vstemplate文件引用的向导类”错误
- 政采云趣味题
- LeetCode40|有序数组中的单一元素
- 搭建简易的物联网服务端和客户端-Cortana控制(十七)
- LeetCode39|找树左下角的值
- LeetCode38|根据字符出现频率排序
- 搭建简易的物联网服务端和客户端-Nodejs_PM2(十八)
- spring boot 项目中自动执行 sql 语句
- 搭建简易的物联网服务端和客户端-邮件通知(十九)
- LeetCode37|两颗二叉搜索树中所有元素
- LeetCode45|数组中重复的数据
- 搭建简易的物联网服务端和客户端-网络控制(二十)
- LeetCode44|在每个树行中找最大值