首页 > 其他分享 >给webpack提了一个pr之后......

给webpack提了一个pr之后......

时间:2023-04-15 10:31:42浏览次数:64  
标签:pr git ...... deterministic webpack 提交 commit id


前言

我不是标题党啊,是真的给webpack提了一个pr,提交之后,脑子里就是一句话:“纸上学来终觉浅,绝知此事要躬行”。

欲知来龙去脉,听我娓娓道来。

给webpack提了一个pr之后......_git

pr 如下,<https://github.com/webpack/webpack/pull/16292>,目前还是unreviewed状态。

给webpack提了一个pr之后......_git_02

\

\ 阅读此文章你将会了解以下知识点,

  • webstrom 调试webpack源码过程
  • webpack优化->deterministic 属性作用
  • 如何提给开源仓库pr
  • 如何修改commit 信息
  • 如何合并commit 信息
  • EasyCLA开源协议签署遇到的问题

看到 = 学会,如果对屏幕前的大帅比大漂亮有帮助的话,点个赞什么的就太好了!

给webpack提了一个pr之后......_github_03

背景

那是一个周五的晚上,11.左右,大部分人都准备休息了,我正在做山月的linux训练营,赶巧,山月在webpack训练营里,圈出一处webpack的源码,8行左右吧。说到,此处有优化空间,可以提pr。\

给webpack提了一个pr之后......_webpack_04

\盯着这段代码,我看了半天,没有上下文,一脸懵圈。大部分人,没有看过源码,直接看肯定看不出毛病,我也是这部分人的一部分。\

\ 后来找了一个做前端的朋友一起看,寻取帮助,他刚刚团建完到家,毫无学习状态。\ \ 我知道有些路注定要一个人走,自己调试webpack源码吧。

调试

我是用的工具是webstorm。

首先我在node_modules中webpack目录下,全局搜索,迅速定位到图示函数。

不得不说,webstorm 的搜索功能真是嘎嘎强!\定位到文件,lib/ids/DeterministicModuleIdsPlugin.js下,看代码不一定知道是什么逻辑,不过看名字却很清楚了,是处理DeterministicModuleIds的一个插件函数。

先简单说说Deterministic

deterministic

正巧,最近刚刚在webpack 训练营学习了Deterministic\正好复习一遍。

这是一个webpack 优化项

optimization: {
    moduleIds: 'deterministic',
    chunkIds: 'deterministic'
}

在生产环境下,二者将被 webpack 默认配置为 deterministic。

这说明这个配置项非常nice,webpack 已经帮我们用了,那聪明的你肯定要问了,它是干什么的呢?

告知 webpack 当选择moduleId 和chunkId时需要使用哪种算法

deterministic在不同的编译中不变的短数字 id(最少三位)。有益于长期缓存。

\ 翻译翻译就是=>

\生成确认的id,这样可以有效避免由于模块引入的顺序改变而导致的产物大面积更改的问题,每个module/chunk都有自己确定的 id。

举例说明

比如在某项目某文件中,引入A模块,第一行import(A)过了一段时间,需要引入B,新的模块,一般来说我们会放在模块引入最下面,但是有个菜鸟,他在第一行增加import(B),import(A)就放在了第2行,并提交构建。

那么新增B,导致A,以及以前原有模块(我叫它们A+),引入顺序都发生了变化,导致模块id发生变化,进而导致文件打包出来的文件名发生变化。

聪明的你,肯定要问了,这有问题吗。其实没啥大问题!不会有任何异常。\\但是有没有更好的解决方案,有!\ \ deterministic 这个配置项就可以帮助我们,无论新增或者减少模块,把原有的模块对应的moduleId 和chunkId 每次打包出来都一样。

这样我们就可以有效的利用浏览器缓存了。\\当然了,不做也可以,大不了新增模块,所有chunk都发现了变化,打开页面慢一点而已。

给webpack提了一个pr之后......_git_05

现在其实也已经可以不关心了,因为webpack已经是默认配置了。

我只是大概说了下deterministic的作用,关于deterministic的原理,等后面有余力了,再整一篇。

开始调试

说了这么多,就是为了铺垫,现在我们开始调试。\在webpack训练营的demo中,有这么一个例子,正好用到了deterministic。

//build.js
const path = require('path')
const webpack = require('webpack')
const normalConfig = {
  entry: './index.js',
  mode: 'none',
  output: {
    filename: '[name].[id].[contenthash].js',
    chunkFilename: '[name].[id].[contenthash].chunk.js',
    path: path.resolve(__dirname, 'dist/normal'),
  },
  optimization: {
    runtimeChunk: {
      name: entrypoint => `runtime-${entrypoint.name}`,
    },
    chunkIds: 'deterministic',
    moduleIds: 'deterministic'
  }
}

f1().run((err, stat) => {
  console.log(JSON.stringify(stat.toJson(), null, 2))
})

我使用的开发工具是webstorm,调试代码特别的方便。\在f1函数处,点击一下打上断点。

给webpack提了一个pr之后......_git_06

进入到node_modules的webpack/lib/ids/DeterministicModuleIdsPlugin.js

打上断点\

给webpack提了一个pr之后......_webpack_07

\右键build.js,选择调试build.js,打开webpack 调试界面,代码此时已经运行到我们的我们设置的第一个断点处\

给webpack提了一个pr之后......_git_08

\\

给webpack提了一个pr之后......_webpack_09

\点击 >>| 按钮,直接运行到下一个断点处,可以看到圈出来的代码,usedIds 是一个set,用来存放moduleId\原代码逻辑是,先获取了原usedIds的长度size,插入新的id,如果发现size没变,说明id 重复了,如果size变了,则说明id 没有重复。\

给webpack提了一个pr之后......_github_10

\其实就是想判断usedIs中有没有id,没有必要绕这么一大圈用size来判断,可以直接用has来判断id 在不在usedIds中。时间复杂度一样,还不用额外声明变量。

所以对上述代码进行改写\改写前

(module, id) => {
    const size = usedIds.size;
    usedIds.add(`${id}`);
        if (size === usedIds.size) {
            conflicts++;
            return false;
        }						    
    chunkGraph.setModuleId(module, id);    
    return true;
},

改写后

(module, id) => {
    if (usedIds.has(`${id}`) {
        conflicts++;
        return false;
    }
    usedIds.add(`${id}`);
    chunkGraph.setModuleId(module, id);
    return true;
},

创建提交pr

  • fork,webpack仓库到自己github仓库
  • git clone 到本地
  • 从main分支拉过来,新建一个靠谱的分支 feature
  • 修改代码
  • git add . 提交信息
  • git commit -m "XXXX" 填写靠谱的描述信息
  • git push --set-upstream origin feature
  • 此时登陆github 就会看到自己fork的仓库出现一个Compare & pull request\
  • 点击,进入webpack仓库代码提交合并页面,仿照以前的提交的git log 格式,填写信息,之后,点击 create pull request\
  • 创建pr之后,就成功了,我们就可以在webpack源码仓库看到提交的pr了。

给webpack提了一个pr之后......_github_11

如何修改commit

当我们提交之后,发现自己commit 信息提交的不合适,或者有歧义,如何修改呢?

  • git log之后,可以看到你之前提交过的git历史:
  • 接下来,在bash里输入wq退出log状态,执行:

给webpack提了一个pr之后......_git_12

  • git commit --amend

这时bash里会出现以下内容:

给webpack提了一个pr之后......_git_13

  • 键入i 进入输出模式。修改commit 信息
  • 修改完毕之后,:wq 保持修改
  • 此时git log 已经能看到我们的修改了

给webpack提了一个pr之后......_github_14

  • git push -f 提交修改

如何合并commit

因为是给源码提pr,所以当时很慎重,我分几次提交,导致有3次commit,山月老师建议合并成一次,自己开发随心所欲惯了,忽然要合并几次提交,就非常生疏,特意查了一下,所以记录一下。

  • git log,获取commit id
  • 如果需要合并最近两个,需要获取倒数第3个commitId\
  • git rebase -i e0108eeb2972553d

给webpack提了一个pr之后......_git_15

  • 按照默认顺序,可以将除第一个提交外,都使用 fixup 或 squash 进行标记,最终你将得到这些commit向上合并,最终变成一个,提交信息是 pick 标记的信息。
  • pick:使用此提交不做操作
  • squash:将指定的提交合并到上边的pick请求中,保留提交信息
  • fixup:与 squash 类似,但不保留提交信息
  • 把不需要的记录 改成fixup ,:wq保存
  • git push origin --force

完成上述操作之后,整个git提交记录就会完全改变了,而且是不可逆操作,当然这也意味着rebase操作是有一定风险的,如果你不太清楚需要做什么的话就不要做。

签署EasyCLA

一个开源协议,承诺自己的代码可供开源使用\

给webpack提了一个pr之后......_github_16

这里需要注意,自己提交信息中的邮箱作者信息,需要和签署的邮箱一致,如果不一致,即使签署依然显示无效。\而我这里遇到的问题就是邮箱作者信息用的是公司gitLab的邮箱信息,所以github识别不到。

如何修改邮箱作者信息

git commit --amend --author="otheruser <otheremail@qq.com>"
git rebase --continue
git push -f origin

总结

以上就是我提交pr的来龙去脉,至于提交pr的意义大家自己体会。

如果对屏幕前的大帅比大漂亮有帮助的话,点个赞什么的就太好了!

无论pr 会不会被merge,这都是webpack 团队事情了,对于我而言,从这个过程中,其实用到的知识点很多,都会细碎,也很简单,一但连贯起来。我遇到了很多很多问题,所以才深深感觉到“纸上学来终觉浅, 绝知此事要躬行”。

看再多博客知识视频,不如自己动手操作一次!

参考

<https://zhuanlan.zhihu.com/p/100243017>\<https://wangbjun.site/2022/coding/git-rebase.html>\<https://oschina.gitee.io/opensource-guide/>

标签:pr,git,......,deterministic,webpack,提交,commit,id
From: https://blog.51cto.com/u_16051001/6192244

相关文章

  • springboot连接不同数据库的写法
    MySQL当url连接不指定/数据库名可以访问到mysql服务器上有权限的任何库,但是所有sql需要加上库名前缀.pom<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency>配置spring:datasource:driver-class-n......
  • SpringBoot 集成 MybatisPlus 九——逻辑删除
    1逻辑删除的概念逻辑删除不会在数据库中删除数据,只是通过一个字段用来标识被删除的记录,数据仍然保存在数据库中。在实际的工作当中,因为数据非常重要,为了防止因用户误操作删除数据后无法恢复的问题,我们通常不会对数据做物理删除,即将数据从数据库中直接删除。而是多采用逻辑删除的方......
  • typescript vue3 VueDraggable 报错 Uncaught TypeError: Cannot read properties of
    UncaughtTypeError:Cannotreadpropertiesofnull(reading'element')nnotreadpropertiesofnull(reading'index')错误写法就是说子组件需要用div包着,你用其他东西,他无法添加key,然后就会报错。<template#item="{element}"><Todo:detail=......
  • c++primer15面向对象程序设计
    除了“构造函数”和“析构函数”,父类的所有成员函数,以及数据成员,都会被子类继承!:补充赋值运算符继承问题(链接) 成员函数如果没被声明为虚函数,其解析过程发生在编译时而非运行时。       派生类引用或者指针向基类引用或者指针自动类型转换:参考能够在一个赋值......
  • SpringSecurity过滤器-CsrfFilter
    CsrfFilter是为了防御CSRF攻击的。CSRF攻击请参考松哥手把手教你在SpringBoot中防御CSRF攻击!soeasy!。CsrfFilter的源码在要学就学透彻!SpringSecurity中CSRF防御源码解析说的很清楚了。 在这里是对LazyCsrfTokenRepository的使用做个总结。 CsrfFilter#doFilterI......
  • SpringBoot常用注解
    本文整理了SpringBoot常用注解,主要讲解这些注解的用法,并附上一致思维导图。SpringBoot常用注解组件相关注解@Controller用于修饰MVC中controller层的组件,SpringBoot中的组件扫描功能会识别到该注解,并为修饰的类实例化对象,通常与@RequestMapping联用,当SpringMVC获取到请求时......
  • ArcGIS Pro SDK 切换所有图例项的自动可见性
    protectedvoidsetLegend(){varlyt=LayoutView.Active?.Layout;if(lyt==null)return;QueuedTask.Run(()=>{vardef=lyt.GetDefinition();va......
  • 解决Spring Boot jar包启动日志输出中文乱码
    在使用slf4j做日志输出时,打jar包运行后,会出现中文乱码问题,只需要将logback-spring.xml配置文件中的<charset>标签注释即可,如图:  解释: 如果不配置logback-spring.xml或resource文件夹下没有logback-spring.xml文件,则springboot使用默认的配置,那么部署jar包,java-jarxxx.......
  • HDU 5443 The Water Problem RMQ
    题目:http://acm.hdu.edu.cn/showproblem.php?pid=5443题意:给定一个数组,查询区间最大值思路:RMQ模板题#include<iostream>#include<cstdio>#include<cstring>#include<algorithm>#include<cmath>#include<queue>usingnamespacestd;constint......
  • Weka数据挖掘Apriori关联规则算法分析用户网购数据
    全文链接:http://tecdat.cn/?p=32150原文出处:拓端数据部落公众号随着大数据时代的来临,如何从海量的存储数据中发现有价值的信息或知识帮助用户更好决策是一项非常艰巨的任务。数据挖掘正是为了满足此种需求而迅速发展起来的,它是从大量的、不完全的、有噪声的、模糊的、随机的数据......