给Electron提的Bug修复啦

大家好,我是老纪。

书接上回《抽丝剥茧:Electron与Node.js的奇葩Bug》,没有看过的读者老爷们推荐阅读一下。

我在ElectronGitHub上提的issue,现在已经关闭了。

我们再简单回顾下这个Bug的背景与产生原因:

  1. Node.js自v18.17.0起,为fs.readdir相关API(同步、异步回调与Promise)都新增了一个参数recursive,但事实上,同步和异步回调的API都有Bug,直到v18.19.0才修复。
  2. Electron v27的多个版本内置的Node.js使用v18.17v18.18,直到v29开始使用Node.js的v20,才没有这个Bug
  3. 由于Electron对fs进行了wrap处理,v29起虽然在大部分情况下没有问题,但是asar模式下内置资源路径的递归没有实现,仍会引发Bug,这也正是此次codebytere修复些问题时的标题:fix: support recursive readdir in Asar files#41582

我们看下codebytere的描述信息:

她其实做了两件事:

  1. 修复asar模式下使用recursive参数的Bug
  2. 规避fs.promises.readdir的性能风险。对于fs.promises.readdir的重写,不再是原来的fs.promises.readdir = util.promisify(fs.readdir),而是依赖于fs.promises.readdir的原生方法本身。原因是我上篇文章提到的,fs.readdir使用recursive参数的异步回调处理是同步的,可能会阻塞进程,有性能上的风险。

从她的代码提交上看,她又手写了两个同步异步的递归函数(代码是从Node.js里借鉴的):

不过我更倾向于把她的762行移到756行,这样可以在readdirRecursive中专注处理asar的逻辑,如果Node.js在这里再有什么Bug,可以随着版本的升级而修复,起码只会影响asar的部分。当然,目前这种修改,对于Electron而言,也无伤大雅,真要有了问题,也就是改多改少的区别了。像这么底层的东西,如果不是这样的API变更,通常是很健壮的。

我这个issue下还有两个开发者反馈遇到了同样的事情:

虽然这个问题关闭了,但新的版本还没有发出来。从目前的提交来看,这个修复只是针对Electron v29+,因为它即使合并到v27v28,由于对应的Node.js版本没有升级到v18.19,其同步和异步回调的API仍是有问题的。

相关推荐
奔跑的web.9 小时前
TypeScript Enum 类型入门:从基础到实战
前端·javascript·typescript
盐真卿9 小时前
python2
java·前端·javascript
梦梦代码精9 小时前
BuildingAI vs Dify vs 扣子:三大开源智能体平台架构风格对比
开发语言·前端·数据库·后端·架构·开源·推荐算法
seabirdssss10 小时前
《bootstrap is not defined 导致“获取配置详情失败”?一次前端踩坑实录》
前端·bootstrap·html
kgduu10 小时前
js之表单
开发语言·前端·javascript
谢尔登12 小时前
Vue3 响应式系统——computed 和 watch
前端·架构
愚公移码12 小时前
蓝凌EKP产品:主文档权限机制浅析
java·前端·数据库·蓝凌
欣然~14 小时前
法律案例 PDF 批量转 TXT 工具代码
linux·前端·python
一个小废渣14 小时前
Flutter Web端网络请求跨域错误解决方法
前端·flutter
符文师15 小时前
css3 新特性
前端·css3