问题
执行gitbook init
报错TypeError [ERR_INVALID_ARG_TYPE]: The "data" argument must be of type string or an instance of Buffer, TypedArray, or DataView. Received an instance of Promise
(途中出现过cb.apply
的问题, 可以执行清理(node cache verify
)和卸载(npm uninstall -g gitbook-cli
)和安装(node install -g gitbook-cli
)试试)
环境
gitbook 3.2.3; npm 8.1.2; ; node v16.13.1; window 10
解决方案
将\3.2.3\lib\init.js
中第71行附近的return fs.writeFile(filePath, summary.toText(extension));
修改为return summary.toText(extension).then(stx=>{return fs.writeFile(filePath, stx);})
过程
- 执行
gitbook init --debug
显示报错堆栈, 找到堆栈中报错的位置(\3.2.3\node_modules\graceful-fs\graceful-fs.js:91:12
)(可以在这里处理传入的Promise解决问题,但是我认为这只是个工具类, 修改这里受影响的位置会很多); - 此时我认为这个
3.2.3
的文件夹就是gitbook
命令所在的文件夹; - 在
package.json
中的main
找到入口文件lib/index.js
, 进而找到lib\init.js
; - 通过搜索日志输出
create
找到创建summary
的位置; 使用console.log
输出summary.toText(extension)
的结果, 发现是Promise
, 尝试添加then
方法并输出入参, 感觉就是文件内容, 于是将return fs.writeFile(filePath, summary.toText(extension));
修改为return summary.toText(extension).then(stx=>{return fs.writeFile(filePath, stx);})