gitbook init报TypeError [ERR_INVALID_ARG_TYPE]

问题

执行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的问题, 参考的链接)

环境

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);})

过程

  1. 执行gitbook init --debug 显示报错堆栈, 找到堆栈中报错的位置(\3.2.3\node_modules\graceful-fs\graceful-fs.js:91:12)(可以在这里处理传入的Promise解决问题,但是我认为这只是个工具类, 修改这里受影响的位置会很多);
  2. 此时我认为这个3.2.3的文件夹就是gitbook命令所在的文件夹;
  3. package.json中的main找到入口文件lib/index.js, 进而找到lib\init.js;
  4. 通过搜索日志输出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);})

你可能感兴趣的:(nodejs,npm,nodejs)