This guide aims to get you setup in the repo and able to build the code.
- Clone / download this project
- IDE: Download Rider or Visual studio. Use Rider if you do not want to waste tons of time resizing things or trying to switch between folder paths and solution paths. Visual Studio is not intuitive or user friendly.
- (optional) Unity: Download Unity Hub
- Unity is only required if you are changing scripting related to the prefabs
- Running things
- Open the whole project with Rider. Typically you can double click on ValheimRAFT.sln to open it
- Unity -> Open the ValheimRaftUnity folder and install the Unity 2020 version
- Install AssetBundle Browser from github master url
or release url. Since it's not updating master is okay.
- copy paste https://github.com/Unity-Technologies/AssetBundles-Browser.git into the input under this interface in Unity. Window > Package Manager > (click plus arrow > click add package from giturl
- Compiling with the current branch libs folder
- You will not need to do anything. These libs are pre-built off the latest supported valheim, jotunn, bepinex.
- Skip this step If -
- you need to fix an issue after valheim updates, you will need to update, re-publicize, download newer bepinex and harmony references etc.
- Manual Compiling
- Do not reference the libs folder
- In the valheim.targets folder change the paths of PropertyGroup with "LocalPaths" label. Make the paths match your install folders for BepInExPlugins, BepInExPath to get to Harmony and BepInEx.dll and the game folder
- alternatively just copy paste and override all the libs folders from the GameDirectory and download the new Jotunn and other required dependencies.
- Create a
.props
file at the top level of the project
Add the following data.
<PropertyGroup Label="LocalPaths">
<BepInExPath><USER_HOME_DIR>\AppData\Roaming\r2modmanPlus-local\Valheim\profiles\valheim_mod_debugging\BepInEx\core</BepInExPath>
<ManagedDataPath>C:\Program Files (x86)\Steam\steamapps\common\Valheim\valheim_Data\Managed</ManagedDataPath>
</PropertyGroup>
Alternatively copy pasting the Valheim\valheim_Data\Managed and other require dependencies into "libs" will make this step unnecessary.
Publicizing manually is not needed. There is a nuget package that handles this for us. We can drop the valheim reference into the libs folder or map to the game directory and the publicizer will automatically update the lib.
If nuget or your IDE Rider/Visual Studio do not install the provided nuget package then you may need to run nuget restore
Publicizer for assembly_valheim steps.
- Alternatively To publicize, copy all the dependencies required into a separate folder.
- Install https://github.com/CabbageCrow/AssemblyPublicizer and run the GUI tool on that folder.
- Rename the __publicized assemblies back to their original names.
- Move those assemblies to the libs folder under ValheimRaft.
- Click compile. It should work.