GTAV_BuildGuide/README.md

256 lines
12 KiB
Markdown
Raw Normal View History

2024-03-20 02:37:20 +08:00
![Icon](https://github.com/WH0LEWHALE/gtav-sourcecode-build-guide/assets/146978592/39674bde-9c2e-4800-99e5-7fc3a05a08f4)
2024-03-20 02:38:09 +08:00
# GTA V Modified Source Code Build Guide
2024-03-19 22:03:02 +08:00
2024-03-22 01:18:44 +08:00
Github edition with fixed links and added some files and features!<br>Based on this [rentry.co](https://www.rentry.co/gtavbuildguide) tutorial, But this tutorial is better than that.<br>
2024-03-19 03:31:31 +08:00
2024-03-20 09:25:31 +08:00
**Working Status:** Working and Tested by me!
2024-03-19 03:31:31 +08:00
2024-03-20 02:38:24 +08:00
## Requirements
2024-03-19 21:40:03 +08:00
### Base
2024-03-22 01:14:00 +08:00
- Minimum 150GB Free Space
2024-03-19 21:40:03 +08:00
- GTA V Files from Steam, Epic Games or Social Club (Minimum v2699)
2024-03-19 03:48:33 +08:00
- GTAVSP.7z<br>
2024-03-22 01:15:42 +08:00
**Want to have the source code? [See Here](/misc/gtavsourcecodelinks.txt) for the links and magnet.**<br>
2024-03-19 03:48:33 +08:00
You can verify the authenticity of the file by its SHA1 hash: `ca39323730ed644fa534a2946506d4287f92a799`<br>
To verify with 7-Zip, right click the file and select `7-Zip > CRC SHA > SHA1`<br>
Archive password: `Mi76#b>9mRed`
2024-03-19 03:34:58 +08:00
- [update.rpf and update2.rpf from GTA V build 2699](https://mega.nz/folder/O1UFlaAB#mqhLDQT7p77sMUnANJDjmA/file/Ph9FlQSK)
2024-03-19 21:40:03 +08:00
### Dependencies
2024-03-22 00:57:14 +08:00
- Windows 10/11
- [Enterprise LTSC 2021](https://archive.org/download/Windows10EnterpriseLTSC202164Bit/en-us_windows_10_enterprise_ltsc_2021_x64_dvd_d289cf96.iso) Recommended
2024-03-22 02:34:41 +08:00
- If u dont want to use Enterprise, you can still build the game without any problems without Enterprise.
2024-03-19 21:40:03 +08:00
- [Visual Studio 2012](https://files.dog/MSDN/Visual%20Studio%202012/en_visual_studio_ultimate_2012_x86_dvd_2262106.iso)
2024-03-22 01:20:09 +08:00
- [Update 4 for Visual Studio 2012](https://files.dog/MSDN/Visual%20Studio%202012%20Update%204/mu_visual_studio_2012_update_4_x86_dvd_3161759.iso)
2024-03-19 21:40:03 +08:00
- [DirectX SDK June 2010](https://download.microsoft.com/download/A/E/7/AE743F1F-632B-4809-87A9-AA1BB3458E31/DXSDK_Jun10.exe)
2024-03-22 00:47:17 +08:00
- [Incredibuild 4.0](https://xoreax-incredibuild.software.informer.com/4.0/)
2024-03-19 21:40:03 +08:00
- [7-Zip](https://7-zip.org/a/7z2301-x64.exe)
- [OpenIV](https://openiv.com/WebIV/guest.php?get=1)
### Miscellaneous
2024-03-20 02:37:20 +08:00
- [Rush Patches](https://github.com/WH0LEWHALE/gtav-sourcecode-build-guide/files/14641602/rush_patches-master.zip)
- [DLL Patches](https://github.com/WH0LEWHALE/gtav-sourcecode-build-guide/files/14641382/dll_patches.zip)
2024-03-19 03:31:31 +08:00
2024-03-19 03:45:30 +08:00
## Prebuilt Files
2024-03-22 01:16:48 +08:00
- [Shaders](https://github.com/WH0LEWHALE/gtav-sourcecode-build-guide/files/14649717/common.zip)
2024-03-19 03:31:31 +08:00
- [Scripts](https://drive.google.com/file/d/1AVMC_MBPpqKp0BIrOI-_lLq98QmwRn46/view)
> [!NOTE]
2024-03-21 23:42:04 +08:00
> It is recommended to create a virtual machine for this build process,<br>although the build process can be done on your Real PC.<br>
2024-03-20 22:03:52 +08:00
> VMWare/Hyper-V are recommended to run the VM due to their performance.
2024-03-19 03:31:31 +08:00
## Prerequisite Setup
2024-03-20 09:44:13 +08:00
1. Install DirectX SDK June 2010
2024-03-22 00:02:22 +08:00
2. Install 7Zip
3. Install Visual Studio 2012
2024-03-22 01:12:37 +08:00
- Uncheck all optional components in the installer **except "Microsoft Foundation Classes for C++"** to save space, none of them are needed for the build.
2024-03-22 00:02:22 +08:00
4. Install Update 4 for Visual Studio 2012
5. Install Incredibuild 4.0 (Only needed for compiling shaders and scripts)
2024-03-22 01:07:25 +08:00
- If you encounter the error that the installer is "Blocked by your administrator", follow these steps:
1. Hold Shift and right click the `incredibuild4_0.exe` file, select "Copy as path"
2. Open Command Prompt as Administrator
3. Paste the path and press Enter
- Select to install "Incredibuild Agent", "Incredibuild Coordinator", and the extension for Visual Studio
2024-03-22 00:02:22 +08:00
6. Install OpenIV
7. Create X:\ drive by following these steps at the bottom
2024-03-22 03:12:35 +08:00
1. Open Command Prompt
2. Create a new folder called "GTA" to the Desktop
3. Run `net use X: \\localhost\c$\<Path to working folder for build> /persistent:yes`
2024-03-22 03:11:30 +08:00
- Example: `net use X: \\localhost\c$\Users\abcd\Desktop\GTA /persistent:yes`
2024-03-22 03:12:35 +08:00
8. Create the folder `X:\gta5` and copy all folders from `GTAVSP.7z\GTA V Source` into it
2024-03-22 01:12:37 +08:00
- By the end, you should have the folders `X:\gta5\src`, `X:\gta5\script`, and `X:\gta5\tools_ng`. If the paths are different or some folders are missing, try re-extracting or moving as needed.
2024-03-22 03:12:35 +08:00
9. Right click the folder `X:\gta5`, select "Properties", uncheck "Read-only", click Apply then OK
10. Copy all folders in `dll_patches.zip` to `X:\gta5\tools_ng\bin`, make sure to overwrite when copying
11. Open Command Prompt as Administrator and run the following commands, then close:
2024-03-19 03:31:31 +08:00
```batch
setx /m RS_TOOLSROOT X:\gta5\tools_ng
setx /m DXSDK_DIR "C:\Program Files (x86)\Microsoft DirectX SDK (June 2010)"
setx /m RS_CODEBRANCH X:\gta5\src\dev_ng
2024-03-22 03:57:26 +08:00
setx /m RS_PROJECT gta5
2024-03-19 03:31:31 +08:00
```
2024-03-22 03:12:35 +08:00
12. To ensure changes are finalized, restart build machine.
2024-03-19 03:31:31 +08:00
2024-03-19 03:45:30 +08:00
## Patching The Source Code
2024-03-19 03:31:31 +08:00
1. Open `rush_patches-master.zip`
2. Copy `game` and `rage` folders to `X:\gta5\src\dev_ng`, make sure to overwrite when copying
3. (OPTIONAL) To skip launcher requirement for running the game, copy `game` and `rage` folders from `OPTIONAL_FIXES` to the same folder
2024-03-19 03:45:30 +08:00
## Building The Game Binary
2024-03-19 03:34:38 +08:00
1. Run `X:\gta5\src\dev_ng\game\VS_Project\load_sln_unity_2012.bat`
2024-03-22 01:12:37 +08:00
- If prompted with "How do you want to open this file?", check "Always use this app to open .sln files" and click OK.
2024-03-19 03:31:31 +08:00
2. Once the solution loads, open the dropdown menu that says "Debug" at the top, select "Configuration Manager"
3. Change "Active Solution Platform" to "x64" and close the configuration window
4. Hold Ctrl key and click all projects under "GameLibs" and "Rage", right-click and select "Properties"
5. In the "Configuration" dropdown, select "All Configurations"
6. Select `C/C++ > All options`, under "Look for options or switches", search "err" and set "Treat Warnings as Errors" to "No (/WX-)", then click "Apply" and "OK"
2024-03-22 01:12:37 +08:00
- For faster compiles, search "mul" and set "Multiprocessor Compilation" to "Yes (/MP)".
- If you get the error `C1060: Compiler is out of heap space` during build, come back to the above setting and turn it off.
2024-03-19 03:31:31 +08:00
7. Right-click the "game" project and select "Properties" and do step 5 again
8. Change build the type at the top of the window from "Debug" to "BankRelease"
2024-03-22 01:12:37 +08:00
9. At the top of the window, select `Build > Build Solution` and wait for build to finish.
10. Copy output binary to game folder.
2024-03-19 03:31:31 +08:00
> [!NOTE]
2024-03-22 01:07:25 +08:00
> Building shaders and scripts can be skipped using the prebuilt files above. These steps are here to allow modding or for those who prefer to build from source as much as possible.
2024-03-19 03:31:31 +08:00
2024-03-19 03:45:30 +08:00
## Building Shaders
2024-03-19 03:31:31 +08:00
1. Under "Shaders", right click the "shaders_rc" project and click "Build"
2024-03-22 02:31:28 +08:00
- If you building in "BankRelease", Dont forget to build shaders with "Release Win32 4.0" in **Configuration Manager**.
2024-03-22 00:57:14 +08:00
- Also, the same thing needs to apply to "shaders_dependency", Change "Debug" to "Release" in **Configuration Manager**
2024-03-22 00:59:33 +08:00
- **If you compiling with Debug, then ignore the steps at the top and continue reading the tutorial.**
2024-03-19 03:31:31 +08:00
2. (OPTIONAL) Build low quality shaders
2024-03-22 01:07:25 +08:00
1. Right click the "shaders_rc" project and click "Properties"
2. Select `Configuration Properties > NMake`
3. Under "General", change all command lines from ending with `win32_40.bat` to ending with `win32_40_lq.bat`, then click "Apply" and "OK"
4. Rebuild shaders
3. Copy `X:\gta5\titleupdate\dev_ng\common` to game directory
2024-03-19 03:31:31 +08:00
2024-03-19 03:45:30 +08:00
## Building Game Scripts
2024-03-19 03:31:31 +08:00
1. Open Command Prompt
2. Run the following commands:
```batch
X:
cd X:\gta5\src\dev_ng
setenv
cd ..\..\tools_ng\bin\RageScriptEditor
ragScriptEditor
```
3. In the editor, select `File > Open Project` and open `X:\gta5\script\dev_ng\singleplayer\GTA5_SP.scproj`
4. Select `Compiling > Intellibuild > Build Project`
2024-03-19 03:45:30 +08:00
## Patching Game Assets
2024-03-19 03:31:31 +08:00
1. Run OpenIV, select "Windows"
2. Select the game folder and click "Continue"
3. Open `GTA V\update\update2.rpf\x64\levels\gta5\script`
4. Click the "Edit mode" button, and copy `X:\gta5\titleupdate\dev_ng\x64\levels\gta5\script\script.rpf` to the OpenIV window
2024-03-22 01:12:37 +08:00
5. [IMPORTANT] Fix Story Mode
2024-03-19 03:31:31 +08:00
1. Open `GTA V\update\update.rpf\common\data` and make sure "Edit Mode" is enabled
2. Under "XML Text Files", right-click `gameconfig.xml` and click "Edit"
3. Under "Search", type "51000"
4. Change the value of `51000` to `53000`
5. Click "Save"
6. Close OpenIV
7. From `rush_patches-master.zip`, copy all files in the `ARCHIVEFIX` folder to a separate location
8. Open `<GAME FOLDER>\update`, and drag `update.rpf` and `update2.rpf` onto `ArchiveFix.exe`
9. Close both windows
2024-03-19 03:45:30 +08:00
## Running The Game
2024-03-19 03:31:31 +08:00
1. In the game directory, create a file named `launch.bat` and add these contents:
```batch
cd %~dp0
game_win64_bankrelease.exe -noSocialClub -nokeyboardhook -nonetlogs
```
2. (OPTIONAL) Add additional arguments:
2024-03-21 07:48:24 +08:00
- `-kbgame` - Start game with game keyboard enabled.
- `-output` - Show console log of game.
- `-rag` - Enable support for RAG, the internal game debugging tool.
- `-ragUseOwnWindow` - Use it with `-rag` parameter to make game run outside of RAG Render Window.
2024-03-22 00:28:32 +08:00
- `-DoReleaseStartup` - Start real Story Mode on launch, Ignore if it says unknown parameter/command.
2024-03-22 01:12:37 +08:00
- `-sc_DisableForbiddenVehicleRemoval` - This parameter allows DLC and Other Cars without getting removed.
2024-03-21 07:48:24 +08:00
- Additional standard game arguments can be added as well.
2024-03-19 03:31:31 +08:00
3. (OPTIONAL) Launch RAG with the following commands in Command Prompt
```batch
X:
cd X:\gta5\src\dev_ng
setenv
cd ..\..\tools_ng\bin\rag
rag
```
2024-03-20 22:03:52 +08:00
4. (OPTIONAL) If your game is from Steam, Copy [Goldberg](https://gitlab.com/Mr_Goldberg/goldberg_emulator/-/jobs/4247811310/artifacts/download) patch into game directory, make sure to overwrite
2024-03-19 03:31:31 +08:00
5. Run `launch.bat`
## Debug Build Controls
```
Legend:
LCTRL -- Left control.
RCTRL -- Right control.
LALT - Left alt.
RALT - Right alt.
LSHIFT - Left shift
RSHIFT - Right shift.
Main keybinds:
2024-03-20 17:54:31 +08:00
CTRL + TAB -> Switch between game keyboards. Available are debug, marketing, game and replay.
2024-03-19 03:31:31 +08:00
Debug Keybinds:
Backtick ---> Toggle scene information.
Ins (Numpad) ---> Remove debug screen information.
Del (Numpad) ---> Creates a copy of you.
Page up (Numpad) ---> Toggle CPU information.
CTRL + Del (Numpad) ---> Creates a copy of you and sets as your main.
CTRL + Num lock (Numpad) ---> Freezes the game. (literally)
ALT + Enter (Numpad) ---> Fullscreen.
Page up / Page down ---> Change game weather.
Scroll Lock ---> Appears "Streaming paused" message.
Break (Pause break) ---> Freezes the game. (literally)
A ---> Toggle AI display info variants.
B ---> Toggle render info.
D ---> Enable/Disable debug pad.
G ---> Teleport (mouse)
H ---> Health cheat
I ---> Show navmeshes
J ---> Skip to next segment of mission
N ---> Appears your character name in minimap and weird red sphere. (It's AI Walking).
O ---> Toggles minimap on the screen.
Q ---> Changes current character model.
R ---> Navigation info, ambient vehicle info
S ---> Reload shaders
U ---> Spawns a vehicle.
V ---> Invincibility
W ---> Gives a specific amount of all weapons in the game.
X ---> Toggles character clothes info.
Z ---> Mission Debug Menu
F1 ---> Toggle Peds/Cards/Objects/Physics instances and lights info.
F2 ---> AI Combat debug info.
F3 ---> Decrease Wanted Level
F5 ---> Teleports to random location.
F8 ---> FAMILY_CONTROLLER / PLAYER_SWITCH STATE INFORMATION
F9 ---> GAMEFLOW STATE INFORMATION
F10 ---> FRIEND_CONTROLLER STATE INFORMATION
F11 ---> RANDOM EVENTS DEBUG DISPLAY
F12 ---> SCRIPT METRICS DEBUG INFO.
CTRL + A ---> Remove AI display info.
CTRL + B ---> Remove box modifier gui.
LCTRL + C ---> Get all available promotions.
RCTRL + C ---> Show prop hitboxes.
CTRL + D ---> Opens filter menu.
CTRL + F ---> Toggle prop/vehicle information like life ratio.
CTRL + G ---> #UNKNOWN
CTRL + I ---> Toggle mouse relative debug info.
Ctrl + N ---> Show player/vehicle tags.
Ctrl + P ---> Toggle information about promps and show character's hitbox.
Ctrl + T ---> Clear Mission trigger
Ctrl + U ---> Spawns or teleports a vehicle. #PARTIALLYKNOWN
RCTRL + Right/Left arrow key ---> Increase/Decrease timescale.
Ctrl + Shift + C ---> Prop hitboxes.
Ctrl + Shift + H ---> Spawn a human.
Ctrl + Shift + R ---> Init telemetry. #PARTIALLYKNOWN
Ctrl + Shift + P ---> Spawns a car.
ALT + A ---> Toggle vehicle information.
ALT + C ---> Cycle through Camera Debug Displays
ALT + G ---> Change game shader.
ALT + H ---> Toggle shader information.
ALT + M ---> Position zoom.
ALT + O ---> Toggle overdraw info.
ALT + T ---> Toggle texture view gui.
ALT + W ---> Show every prop's hitbox.
ALT + X ---> Removes power cables.
SHIFT/CTRL + B ---> Toggle collision debug info.
SHIFT + H ---> Teleports to your house.
SHIFT + K ---> LowTierGod. (Kills the player.)
SHIFT + O ---> Toggle Overview gui.
SHIFT + P ---> Change characters model in vehicle.
SHIFT + R ---> Toggle peds info.
SHIFT + T ---> Change trigger zone.
SHIFT + U ---> Spawns a vehicle and makes your driver auto.
Ctrl + Alt + I ---> Toggle weapon/inputs information.
```