发布你的第一个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++插件的大致流程。
- 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 数组属性和方法
- spring AOP之基于xml配置文件的方式来配置AOP
- 基于TypeScript封装Axios笔记(五)
- spring之操作数据库之使用JdbcTemplate和JdbcDaoSupport
- 修改Markdown神器[Typora]的主题样式
- 视频压缩原理入门
- spring之为什么要使用事务?(一)
- Mysql 如何实现全文检索,关键词跑分
- spring之操作数据库之使用NamedParameterJdbcTemplate(具名参数)
- 谷歌colab上安装百度paddlepaddle框架
- 谷歌colab运行paddlepaddle之手写数字识别
- 【python-leetcode112-树的深度遍历】路径总和
- spring之第一个spring程序
- 【python-leetcode437-树的深度遍历】路径总和Ⅲ
- 双指针--合并两个排序数组
- spring之事务的其它属性(隔离级别、回滚、只读、过期)(四)