欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長(zhǎng)資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          分享一個(gè)重要的Git技巧,能保護(hù)核心代碼!

          前段時(shí)間完成了一個(gè)核心代碼保護(hù)的功能,目標(biāo)在關(guān)鍵代碼被修改及時(shí)同步給其他人,避免沒經(jīng)過 review 就上線導(dǎo)致問題,提示的效果圖如下:

          分享一個(gè)重要的Git技巧,能保護(hù)核心代碼!

          在實(shí)現(xiàn)的過程中,用到一些平時(shí)使用不多的 Git 技巧,這篇文章來總結(jié)一下。

          如何獲取當(dāng)前提交用戶信息

          這個(gè)比較簡(jiǎn)單,通過 git config user.name 即可:

          04318deMacBook-Pro % git config user.name zhangshixin
          登錄后復(fù)制

          git config 保存了很多配置信息,其中常用的有自定義快捷鍵、用戶信息、項(xiàng)目地址、分支信息等:

          504318deMacBook-Pro % git config -l  //快捷鍵 begin >>> 我們可以定義自己的 git 快捷鍵 alias.st=status           alias.co=checkout alias.cb=checkout alias.p=pull alias.pr=pull alias.pu=push alias.cm=commit alias.br=branch alias.cm=commit alias.undo=reset alias.rbc=rebase alias.save=stash alias.pop=stash //快捷鍵 end <<< 我們可以定義自己的 git 快捷鍵  //用戶名稱和郵箱 begin >>> user.name=zhangshixin user.email=shixin.zhang@xxx.com //用戶名稱和郵箱 end <<<  //項(xiàng)目和分支信息 begin >>> remote.origin.url=git@gitlab.xxx:android/xxx.git remote.origin.fetch=+refs/heads/*:refs/remotes/origin/* branch.master.remote=origin branch.master.merge=refs/heads/master branch.Canary.remote=origin branch.Canary.merge=refs/heads/Canary //項(xiàng)目和分支信息 end <<<  pull.rebase=true    //默認(rèn) pull 是 merge 還是 rebase
          登錄后復(fù)制

          如何獲取當(dāng)前分支

          為了減少提示頻率,最好只檢測(cè)核心的分支的提交(包括 merge commit)。如何獲取當(dāng)前分支呢?有一個(gè)簡(jiǎn)單的方式:

          git symbolic-ref --short HEAD
          登錄后復(fù)制

          這句命令主要包括兩個(gè)關(guān)鍵字:symbolic-refHEAD

          symbolic-ref 可以讀取、修改和刪除符號(hào)引用。

          什么是符號(hào)引用呢?它表示一個(gè)以 refs 開頭的文件(比如 refs/heads/develop),這個(gè)文件保存著本地每個(gè)分支當(dāng)前所處 commit。

          我們可以打開 git 項(xiàng)目的 .git 文件夾,在其中的 refs/heads 文件夾中會(huì)保存各個(gè)分支當(dāng)前所指向的 commit:

          分享一個(gè)重要的Git技巧,能保護(hù)核心代碼!

          HEAD 指的是 .git/HEAD,就是一個(gè)文件,保存著當(dāng)前指向的符號(hào)引用:

          分享一個(gè)重要的Git技巧,能保護(hù)核心代碼!

          因此 git symbolic-ref --short HEAD 的含義就是讀取 .git/HEAD 文件的內(nèi)容,我這里就是 refs/heads/develop 文件,因此就得出當(dāng)前分支是 develop 分支。

          如何獲取本地未 push 的所有 commit

          有時(shí)候我們會(huì)在本地提交多次后再 push,因此在攔截 push 時(shí),需要獲取到當(dāng)前要 push 的所有 commit 信息,然后獲取每個(gè) commit 修改的文件。

          獲取要 push 信息可以通過 git log @{u}.. --oneline:

          504318deMacBook-Pro ShixinDemo % git log @{u}.. --oneline 4e4655b (HEAD -> master) 攔截跳轉(zhuǎn) f947180 修改文件
          登錄后復(fù)制

          git log 非常強(qiáng)大,它可以有這些使用場(chǎng)景:

          1. 獲取本地和遠(yuǎn)端的 commit 差異
          2. 獲取指定時(shí)間內(nèi)的提交記錄,可以具體到誰、什么時(shí)候、修改了哪些
          3. 獲取具體某次提交修改的文件

          上面我們使用的參數(shù) @{u}.. 就是表示獲取本地和遠(yuǎn)端的 commit 差異,然后 --oneline 表示不打印具體信息,只打印 short commit id 和 commit message。

          如果要獲取指定時(shí)間內(nèi)的提交記錄,可以這樣:

          git log --pretty="%an(%cd) %h - %s" --since="2022-09-01" --no-merges --name-status
          登錄后復(fù)制

          命令執(zhí)行結(jié)果:

          504318deMacBook-Pro ShixinDemo % git log --pretty="%an(%cd) %h - %s" --since="2022-09-01" --no-merges --name-status zhangshixin(Fri Dec 16 22:34:49 2022 +0800) 4e4655b - 攔截跳轉(zhuǎn)  M       app/src/main/java/com/example/heicdemo/MainActivity.kt zhangshixin(Fri Dec 16 22:34:30 2022 +0800) f947180 - 修改文件  M       .idea/gradle.xml M       .idea/misc.xml D       .idea/runConfigurations.xml A       android10_dem_heic_output.heic A       app/src/main/assets/android10_dem_heic_output.heic R100    app/src/main/res/drawable/mushroom.jpg  app/src/main/assets/mushroom.jpg A       app/src/main/assets/mushroom.webp M       app/src/main/java/com/example/heicdemo/MainActivity.kt A       app/src/main/res/drawable/mushroom.webp M       app/src/main/res/layout/activity_main.xml
          登錄后復(fù)制

          pretty 的參數(shù)用于指定打印的內(nèi)容和格式;since 參數(shù)用于指定查看時(shí)間范圍;no-merges 表示過濾掉 merge 時(shí)生成的額外 commit;name-status 表示展示出文件的修改狀態(tài)(M 表示修改;D 表示刪除;A 表示增加;R 表示重命名)。

          如何獲取每個(gè) commit 修改的文件

          知道 commit ID 后,可以通過 git show --pretty="" --name-only $commitId 獲取這個(gè) commit 影響的信息:

          04318deMacBook-Pro ShixinDemo % git show --pretty="" --name-only 4e4655b   app/src/main/java/com/example/shixindemo/MainActivity.kt
          登錄后復(fù)制

          git show 可以用來查看 commit 的 commit message 和修改的文件、文件具體內(nèi)容等信息。上面的代碼中我們使用了 name-only 參數(shù)表示只要查看修改的文件即可。

          總結(jié)

          這篇文章介紹了通過攔截 git push 時(shí),獲取當(dāng)前用戶、當(dāng)前分支、未 push 的 commit 和修改的文件等命令,通過組合這些命令,就可以實(shí)現(xiàn)一個(gè)核心代碼保護(hù)功能了!

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)