7.7 KiB
7.7 KiB
貢獻指南
構建 HMCL
環境需求
構建 HMCL 啟動器需要安裝 JDK 17 (或更高版本)。你可以從此處下載它: Download Liberica JDK。
在安裝 JDK 後,請確保 JAVA_HOME 環境變數指向符合需求的 JDK 目錄。
你可以這樣查看 JAVA_HOME 指向的 JDK 版本:
Windows
PowerShell:
PS > & "$env:JAVA_HOME/bin/java.exe" -version
openjdk version "25" 2025-09-16 LTS
OpenJDK Runtime Environment (build 25+37-LTS)
OpenJDK 64-Bit Server VM (build 25+37-LTS, mixed mode, sharing)
Linux/FreeBSD
> $JAVA_HOME/bin/java -version
openjdk version "25" 2025-09-16 LTS
OpenJDK Runtime Environment (build 25+37-LTS)
OpenJDK 64-Bit Server VM (build 25+37-LTS, mixed mode, sharing)
macOS
> /usr/libexec/java_home --exec java -version
openjdk version "25" 2025-09-16 LTS
OpenJDK Runtime Environment (build 25+37-LTS)
OpenJDK 64-Bit Server VM (build 25+37-LTS, mixed mode, sharing)
獲取 HMCL 原始碼
- 透過 Git 可以獲取最新原始碼:
git clone https://github.com/HMCL-dev/HMCL.git cd HMCL - 從 GitHub Release 頁面可以手動下載特定版本的原始碼。
構建 HMCL
想要構建 HMCL,請切換到 HMCL 專案的根目錄下,並執行以下指令:
./gradlew clean makeExecutables
構建出的 HMCL 程式檔位於根目錄下的 HMCL/build/libs 子目錄中。
除錯選項
Warning
本文介紹的是 HMCL 的內部功能,我們不保證這些功能的穩定性,並且隨時可能修改或刪除這些功能。
使用這些功能時請務必小心,錯誤地使用這些功能可能會導致 HMCL 行為異常甚至崩潰。
HMCL 提供了一系列除錯選項,用於控制啟動器的行為。
這些選項可以透過環境變數或 JVM 參數設定。如果兩者同時存在,那麼 JVM 參數會覆蓋環境變數的設定。
| 環境變數 | JVM 參數 | 功能 | 預設值 | 額外說明 |
|---|---|---|---|---|
HMCL_JAVA_HOME |
設定用於開啟 HMCL 的 Java | 僅對 exe/sh 生效 | ||
HMCL_JAVA_OPTS |
設定開啟 HMCL 時的預設 JVM 參數 | 僅對 exe/sh 生效 | ||
HMCL_FORCE_GPU |
設定是否強制使用 GPU 加速繪製 | false |
||
HMCL_ANIMATION_FRAME_RATE |
設定 HMCL 的動畫幀率 | 60 |
||
HMCL_LANGUAGE |
設定 HMCL 的預設語言 | 使用系統預設語言 | ||
-Dhmcl.dir=<path> |
設定 HMCL 的目前資料存放位置 | ./.hmcl |
||
-Dhmcl.home=<path> |
設定 HMCL 的使用者資料存放位置 | Windows: %APPDATA%\.hmclLinux/BSD: $XDG_DATA_HOME/hmclmacOS: ~Library/Application Support/hmcl |
||
-Dhmcl.self_integrity_check.disable=true |
檢查更新時不檢查程式完整性 | |||
-Dhmcl.bmclapi.override=<url> |
設定 BMCLAPI 的 API Root | https://bmclapi2.bangbang93.com |
||
-Dhmcl.discoapi.override=<url> |
設定 foojay Disco API 的 API Root | https://api.foojay.io/disco/v3.0 |
||
HMCL_FONT |
-Dhmcl.font.override=<font family> |
設定 HMCL 預設字體 | 使用系統預設字體 | |
-Dhmcl.update_source.override=<url> |
設定 HMCL 更新來源 | https://hmcl.huangyuhui.net/api/update_link |
||
-Dhmcl.authlibinjector.location=<path> |
設定 authlib-injector JAR 檔的位置 | 使用 HMCL 內置的 authlib-injector | ||
-Dhmcl.openjfx.repo=<maven repository url> |
添加用於下載 OpenJFX 的自訂 Maven 倉庫 | |||
-Dhmcl.native.encoding=<encoding> |
設定原生編碼 | 使用系統的本機編碼 | ||
-Dhmcl.microsoft.auth.id=<App ID> |
設定 Microsoft OAuth App ID | 使用 HMCL 內建的 Microsoft OAuth App ID | ||
-Dhmcl.microsoft.auth.secret=<App Secret> |
設定 Microsoft OAuth App 金鑰 | 使用 HMCL 內建的 Microsoft OAuth App 金鑰 | ||
-Dhmcl.curseforge.apikey=<Api Key> |
設定 CurseForge API 金鑰 | 使用 HMCL 內建的 CurseForge API 金鑰 | ||
-Dhmcl.native.backend=<auto/jna/none> |
設定 HMCL 使用的本機後端 | auto |
||
-Dhmcl.hardware.fastfetch=<true/false> |
設定是否使用 fastfetch 檢測硬體資訊 | true |