VShell 工具的 Git Rebase 與程式碼重構
本週,我有機會深入研究如何使用 git rebase,同時重構我的 VShell 工具的程式碼庫。我的主要任務是改進程式碼的結構和可維護性,同時遵守 DRY(不要重複自己)原則,這對於使程式碼更具可讀性、可維護性和更易於調試至關重要。此外,我遵循了重構目錄中概述的各種重構模式,例如提取函數、提取類別和重命名變數。
在深入探討我的重構工作的細節之前,我將為仍在熟悉這個強大的 Git 功能的開發人員提供 git rebase 流程的概述。
Git 變基概述
基本指令:
-
git rebase
:此指令將目前分支的提交移至指定分支的頂部,從而有效地重新確定目前分支的基礎。 git rebase
; :此指令將主題分支重新設定為基礎分支,而無需先檢出主題分支。
範例:通常,您會檢查主題分支並執行 git rebase,但此指令允許在保留基礎分支的同時進行變基。
衝突處理:
- git rebase --abort:取消 rebase 並將分支恢復到先前的狀態。
-
git add
:解決合併衝突後將已解決的衝突新增至暫存區。 - git rebase --continue:衝突解決後繼續 rebase 程序。
互動式變基:
- 使用 git rebase -i
;用於將多個提交壓縮為一個。 - 成功變基後,可以刪除主題分支,因為所有變更都已整合。使用 gitbranch -d
;刪除分支。
重要提示::
- 避免主分支變基,因為它會影響其他協作者。
- 僅在您的主題分支上重新建立基礎,以便在推送之前清理您的工作。
→ 在推動清理工作之前重新調整本地變更的基礎,但切勿重新調整已推送到某處的任何內容。
重構過程
建立重構分支
為了防止破壞當前工作程式碼,我基於主分支創建了一個單獨的重構分支。這使我能夠安全地嘗試更改。-
分析與重構程式碼
儘管我最初將模組化模式應用於 VShell 程式碼,但仍需要進一步改進以拆分更大的模組並創建更具可讀性的程式碼流。-
原始碼/伺服器:
- 我將重複的日誌記錄邏輯重構為handleDebugMessage() 函數,允許透過stderr 流進行集中日誌記錄。
- 我還在 ConfigHandler.js 中建立了一個新的 ConfigHandler 類別來處理配置 .toml 檔案處理。 getTomlFiles() 和 loadConfig() 方法被封裝到此類中,用於設定的模組化處理。
-
原始碼/伺服器:
-
ai_config/grogConfig.js:
- 從 chatCompletion AI 回傳回應的兩種方法在令牌使用檢索中存在重複。我將此邏輯提取到 getTokenUsage() 函數中,允許 readStream() 和 PromptGroq() 重複使用它。
- 此外,我修復了 PromptGroq() 中的拼字錯誤,並重新命名了溫度變數以便更清晰。
-
src/ai.js:
- 我將handleOutput() 函數移至模組handleOutputFile() 中以允許將來重複使用。
-
src/getFileContent.js:
- 此處需要進行最小的更改;我只是重命名了檔案路徑和變數名稱,以提高可讀性和清晰度。
重構後的 Git Rebase
在重構過程中進行了 11 次提交後,有必要對它們進行整合。為了保持提交歷史記錄乾淨,我使用以下命令執行了互動式變基:
git rebase main -i
VSCode,配置為我的 Git 編輯器,提示我壓縮提交。壓縮後,我進行了一次包含所有相關變更的提交。然後我使用 git commit --amend 更新提交訊息,而不是在合併到主分支之前建立新的提交。
Conclusion
This week's experience with git rebase has provided me with valuable insights. Rebase is an essential tool for maintaining a clean, linear commit history, free from unnecessary merges. By mastering git rebase, I am now able to organize commit messages efficiently, minimizing confusion and ensuring a streamlined development workflow.
The refactoring effort has improved the structure and maintainability of the VShell codebase. Applying key design patterns like extracting functions and classes, I have made the codebase more modular, reusable, and easier to work with moving forward.
以上是VShell 工具的 Git Rebase 與程式碼重構的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

探索前端中類似VSCode的面板拖拽調整功能的實現在前端開發中,如何實現類似於VSCode...
