Setting up Source SDK Base 2013 Multiplayer: Difference between revisions
|  (→Step One: Installing Visual Studio:  Reworded mfc library not working on visual studio 2013 notice to make more clear) |  (→Step Three: Compiling the Source SDK and preparing project files:  clarified where properties window is at) | ||
| Line 93: | Line 93: | ||
| {{Note|The '''Everything''' solution also contains the '''Game''' solutions along with other tools.}} | {{Note|The '''Everything''' solution also contains the '''Game''' solutions along with other tools.}} | ||
| # Open '''everything.sln''' for the desired mode (Singleplayer or Multiplayer). | # Open '''everything.sln''' for the desired mode (Singleplayer or Multiplayer). | ||
| # Select the '''everything''' solution, located under the '''Solution Explorer''' list, then from the middle menu, right next to the '''Auto''' drop down menu, change '''Debug''' to '''Release'''. | # Select the '''everything''' solution, located under the '''Solution Explorer''' list, then from the middle menu, right next to the '''Auto''' drop down menu (the properties box/pane under the solution explorer), change '''Debug''' to '''Release'''. | ||
| # Right Click on the '''everything''' solution, then select '''Build Solution'''. | # Right Click on the '''everything''' solution, then select '''Build Solution'''. | ||
Revision as of 13:48, 13 October 2019

Key points
 Note:The Source SDK uses the Valve Project Creator in order to generate the required platform specific files.
Note:The Source SDK uses the Valve Project Creator in order to generate the required platform specific files. Note:If you want to create a simple, content-based mod, see this fully-compiled template.
Note:If you want to create a simple, content-based mod, see this fully-compiled template. Note:You can always edit code files with Notepad ++ or a similar program, and then compile under Visual Studio.
Note:You can always edit code files with Notepad ++ or a similar program, and then compile under Visual Studio.Setting Up (All Platforms)
Setting up the Source SDK Base
Install Source SDK Base 2013 (multiplayer or singleplayer depending on your mod) from Steam->Library->Tools or from the links below:
- Install Source SDK Base 2013 (SP) Singleplayer (AppID: 243730)
- Install Source SDK Base 2013 (MP) Multiplayer (AppID: 243750)
Getting the code
Method one: Using the GitHub Desktop client (Windows/OS X)
- Download and install the GitHub Desktop client
- Open the Source SDK git repo and click "Clone to desktop"
Method two: Using the command line (Windows/OS X/Linux)
- Download and install the git CLI. Linux users can download it with their distro's package manager (APT, Aptitude, DNF, Pacman, Synaptic...). Mac's users can download git here.
- Open the terminal/command prompt and run this command:
git clone https://github.com/ValveSoftware/source-sdk-2013.git
Method three: Downloading the ZIP archive
 Note:Note: You will need to update the code manually whenever changes are committed to the repo
Note:Note: You will need to update the code manually whenever changes are committed to the repoDownload from here
Setting up (Platform Specific)
Source SDK 2013 on Windows
Step One: Installing Visual Studio
 Note:Although Source SDK 2013 currently does NOT compile with Visual Studio 2015 (bug report) you can still use VS 2015 as IDE and compile the code with the VS 2013 toolset.
Note:Although Source SDK 2013 currently does NOT compile with Visual Studio 2015 (bug report) you can still use VS 2015 as IDE and compile the code with the VS 2013 toolset.Just install both VS 2013 and 2015, open the solution in VS 2015, and skip the dialog where VS 2015 tries to upgrade your projects.
You can also compile without Visual Studio, or using a different version.
- Download and install Visual Studio 2013.
- Download and install the Multibyte MFC Library.
 Note:The Multibyte MFC Library add-on doesn't work with Visual Studio Express 2013. The add-on installer doesn't detect Visual Studio Express 2013 as an install because Visual Studio Express 2013 doesn't support MFC.
Note:The Multibyte MFC Library add-on doesn't work with Visual Studio Express 2013. The add-on installer doesn't detect Visual Studio Express 2013 as an install because Visual Studio Express 2013 doesn't support MFC.Step Two: Installing the Microsoft Speech SDK
- Download the Microsoft Speech SDK
- Extract install files and run Microsoft Speech SDK 5.1.msi
- Copy C:\Program Files (x86)\Microsoft Speech SDK 5.1to<SDKROOT>\sp\src\utilsfolder or<SDKROOT>\mp\src\utilsfolder depending on your mod.
- Make sure that your directory looks like this : \sp\src\utils\sapi51 then should contain Bin Docs IDL etc. And not like this : \sp\src\utils\Microsoft Speech SDK 5.1\sapi51. If it's like the latter it will throw up error code 1 on compile.
- Open sphelper.h(located in :<SDKROOT>\sp\src\utils\sapi51\include) and fix the following errors:
Line 769 :
   const size_t ulLenVendorPreferred = wcslen(pszVendorPreferred); // no size_t
Line 1418 :
   static long CoMemCopyWFEX(const WAVEFORMATEX * pSrc, WAVEFORMATEX ** ppCoMemWFEX) // missing long
Line 2368 :
   const WCHAR * PropertyStringValue() const
   {
       // Search for the first NULL and return pointer to the char past it.
       SPDBG_ASSERT(eEventId == SPEI_PROPERTY_STRING_CHANGE);
       const WCHAR * psz = (const WCHAR *)lParam; // moved this from for init
       for (; *psz; psz++) {}
       return psz + 1;
   }
Line 2560 :
   SPPHONEID* pphoneId = (SPPHONEID*)((WCHAR *)dsPhoneId); // improper casting
Line 2634 :
   pphoneId += wcslen((const wchar_t *)pphoneId) + 1; // improper casting
Step Three: Compiling the Source SDK and preparing project files
- Navigate to <path-to-git>\sp\src\and run createallprojects.bat and creategameprojects.bat
- Navigate to <path-to-git>\mp\src\and run createallprojects.bat and creategameprojects.bat
 Note:The Everything solution also contains the Game solutions along with other tools.
Note:The Everything solution also contains the Game solutions along with other tools.- Open everything.sln for the desired mode (Singleplayer or Multiplayer).
- Select the everything solution, located under the Solution Explorer list, then from the middle menu, right next to the Auto drop down menu (the properties box/pane under the solution explorer), change Debug to Release.
- Right Click on the everything solution, then select Build Solution.
Notes
 Note:If something fails at the end, then simply rebuild the solution.
Note:If something fails at the end, then simply rebuild the solution. Note:The client.dll is going to be generated in
Note:The client.dll is going to be generated in <path-to-git>\sp\src\game\client\Release_mod_hl2 and <path-to-git>\sp\src\game\client\Release_mod_episodic Note:The server.dll is going to be generated in
Note:The server.dll is going to be generated in <path-to-git>\sp\src\game\server\Release_mod_hl2 and <path-to-git>\sp\src\game\server\Release_mod_episodic Note:The current Singleplayer branch will crash on startup, unless you are using the beta-branch of the Source SDK Base 2013. In Steam, go to Tools > Source SDK Base 2013 Singleplayer, right click > Properties > Betas to opt into the beta. This requirement will go away in the very near future. Without the beta, you get two popups about "Entry Point Not Found" in hl2.exe, and then the debugger breaks on engine.dll
Note:The current Singleplayer branch will crash on startup, unless you are using the beta-branch of the Source SDK Base 2013. In Steam, go to Tools > Source SDK Base 2013 Singleplayer, right click > Properties > Betas to opt into the beta. This requirement will go away in the very near future. Without the beta, you get two popups about "Entry Point Not Found" in hl2.exe, and then the debugger breaks on engine.dllStep Four : Building the shaders
See Source SDK 2013: Shader Authoring.
Source SDK 2013 on OS X
Step One : Requirements
- Get OS X Mavericks which is capable of running on a Virtual Machine.
- Install Xcode 5.0.2 (requires an Apple Developer ID account).
- You will also need to have the "Command Line Tools" installed. You can find this in Xcode Preferences -> Downloads -> Components window.
 Note:If you're trying to use a later macOS/Xcode combination, you should modify the
Note:If you're trying to use a later macOS/Xcode combination, you should modify the src/devtools/base.xcconfig file in order to generate more compatible project settings (the most important one being SDKROOT at the end). Warning:If you are using macOS Mojave or higher, building the Source SDK 2013 source code will be highly complicated due to Apple deprecating the 32 bits architecture. You will get an error/warning about updating the
Warning:If you are using macOS Mojave or higher, building the Source SDK 2013 source code will be highly complicated due to Apple deprecating the 32 bits architecture. You will get an error/warning about updating the ARCHS variable in Xcode to be something else than i386.Step Two : Generating the Xcode projects
Run the following scripts to generate project files.
 Note:You'll only need to run the scripts for the base gamemodes you're creating a mod for; sp for single player and mp for multiplayer
Note:You'll only need to run the scripts for the base gamemodes you're creating a mod for; sp for single player and mp for multiplayercd <SDK_ROOT>/sp/src ./createallprojects ./creategameprojects cd <SDK_ROOT>/mp/src ./createallprojects ./creategameprojects
games.xcodeproj and everything.xcodeproj will be generated in the src folder.
Step Three : Building
To compile the tools, server and client libraries open everything.xcodeproj and games.xcodeproj in Xcode and build the projects (Product -> Build).
 Note:Using a more modern environment will yield some errors when compiling.
Note:Using a more modern environment will yield some errors when compiling.Step Four : Binaries
When successfully built, client.dylib and server.dylib will be created and ready to use with the desired Source SDK Base 2013 branch (singleplayer or multiplayer).
Source SDK 2013 on Linux
 Note:Due to the usage of the Steam Client Runtime, a Debian based Linux distribution (Linux Mint, Ubuntu...) is recommended. Arch Linux based distributions (Antergos, Manjaro...) seems to work as well. You can take the risk of trying with another GNU/Linux distribution but keep in mind that you will have to adapt the commands and this tutorial may fail.
Note:Due to the usage of the Steam Client Runtime, a Debian based Linux distribution (Linux Mint, Ubuntu...) is recommended. Arch Linux based distributions (Antergos, Manjaro...) seems to work as well. You can take the risk of trying with another GNU/Linux distribution but keep in mind that you will have to adapt the commands and this tutorial may fail.Step One: Getting the basic C/C++ development tools
You should already have these, but to be sure, you can run the following command in a terminal:
sudo apt-get install build-essential
AMD64 (64 bits) users will need to download and install additional packages to target the i386 (32 bits) architecture, this can be done with this command in a terminal:
sudo apt-get install gcc-multilib g++-multilib
Step Two: Preparing the Source SDK 2013
Assuming you have already cloned the Source SDK 2013 through Git (or downloaded the ZIP file), just run the following commands (by replacing [SDK_ROOT] by the location of the Source SDK 2013, [GAME] by "sp" or "mp" depending on your mod and [SCRIPT] by either "./createallprojects" or "./creategameprojects"), go into :
cd [SDK_ROOT]/[GAME]/src [SCRIPT]
Depending on the script you ran, you will have a master Makefile called games.mak or everything.mak that will be generated in the src folder.
Step Three: Downloading, installing, setting up the Steam Client Runtime
The Steam Client Runtime will help you guarantee compatibility with most GNU/Linux distributions. It is recommended to install it in "/valve/steam-runtime", if you don't like this and wish to install the Steam Client Runtime elsewhere: symbolic link is your friend. We are going to assume you want to do the first option. Run the following commands in a terminal, make sure to replace "[USER]" by your login and "[GROUP]" by your group name:
cd / sudo mkdir valve cd valve sudo wget http://media.steampowered.com/client/runtime/steam-runtime-sdk_latest.tar.xz sudo tar xvf steam-runtime-sdk_latest.tar.xz sudo mv steam-runtime-sdk_2013-09-05 steam-runtime sudo chown <USER>:<GROUP> * -R
Run the "./setup.sh" script in the "steam-runtime" directory, select the "i386" architecture and one configuration of your choice, say "Yes" to everything related to updates.
Before compiling the SDK, you have to run the sandbox (chroot environement), this is done by running the "./shell.sh --arch=i386" script.
Step Four: Time to compile
 Note:If you're on Arch Linux, you'll have to install the
Note:If you're on Arch Linux, you'll have to install the dpkg AUR package to compile the game.In a terminal (like always), "cd" into the "sp" (singleplayer) or "mp" (multiplayer) directory of the SDK and the "src" directory, just run the following command to compile (replace [MAKEFILE] by "games.mak" or "everything.mak" depending on the one available to you):
make -f [MAKEFILE].mak
If everything went well, you should have the "client.so" and "server.so" files in the "game" directory to load with the appropriate Source SDK Base 2013. You can get more instructions on using the Steam Client Runtime by reading the "README.txt" file in the installed runtime directory.
 Note:If you have an error about "objcopy", edit the "devtools/gendbg.sh" file and change the "OBJCOPY" variable so it points to the default "objcopy" program, usually found at
Note:If you have an error about "objcopy", edit the "devtools/gendbg.sh" file and change the "OBJCOPY" variable so it points to the default "objcopy" program, usually found at /usr/bin/objcopy.Setting up on Steam
See Setup mod on steam.
Other information
Adding new files with the Valve Project Creator
- Add instructions on how to here.
- Open hl2.vpc with a text editor and edit this line or something.
VPC generates project files for all of the platforms that the SDK supports, so if you want to add files to your project in a way that will allow you to easily build on other platforms, consider using VPC. For example, to add a file to a multiplayer game, you could add a line to src/game/client/client_hl2mp.vpc.
Directory structure
- game - Runtime files for the mods themselves. Any mod content will go in here.
- src - All the source code for that kind of mod. The root of the src directory contains .sln or root level .mak files for building the source.
- common - A few files used by the server and client DLLs
- devtools - Scripts and utilities that are used to build the source. These are called by the makefiles and projects and you probably won't need to interact with them directly.
- game - All of the source code for the DLLs.
- client - Code used by client.dll (or client.dylib or client.so). There are also game-specific directories under here.
- server - Code used by server.dll. There are also game-specific directories under here.
- shared - Code used by both client.dll and server.dll.
- gcsdk - A couple of tools used to build the DLLs.
- lib - Binary versions of the libraries that the source code depends on. This is also the build target for vgui_controls, tier1, and mathlib.
- mathlib - Math utilities used by the game.
- public - Header files for all of the DLLs and libraries that are used by the game. Also includes a few source files.
- thirdparty - Third party libraries needed to build the source. At the moment this contains only the Google Protocol Buffers (protobuf) library.
- tier1 - Useful utility classes. Builds into tier1.lib
- utils - Various development utilities
- vgui2 - Source code for vgui_controls, which is used by client.dll.
Troubleshooting
Unable to find RegKey for .vcproj files in solutions (Windows)
- Install and update Visual Studio 2013. See Source SDK 2013 on Windows (Step One).
Or if you don't feel like downgrading to VS2013 you can try this alternative solution and see if works for you.
 Warning:Editing the Windows registry is dangerous. Changing something you don't know can break the Windows OS.
Warning:Editing the Windows registry is dangerous. Changing something you don't know can break the Windows OS.- As Found in the GitHub repository comments One of the ways that the issue can be solved is like this:
- Go to the windows registry editing 'regedit.exe' and navigate to:
- HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\VisualStudio\10.0\Projects\{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}
 
- Add the "project" and "{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}" registry keys if they don't already exist.
- Once inside, add a string key and name it DefaultProjectExtension.
- Right click on it and go into 'Modify'
- Set the data to vcproj and cick ok.
 
Once You finish It should look like this:
Now try run the .bat again and your .sln file should generate without issue!
MSB8008: Specified platform toolset (v120_xp) or (v120) is not installed or invalid (Windows)
- Select all Project Files
- Right-click on the file, then choose "Properties"
- Choose "Configuration Properties"
- Under "Platform toolset" this -> (v100)
(Project->Properties->Configuration Properties->General->Platform toolset = Visual Studio 2010(v100))
Issues with "min" or "max" from Steam Runtime when Compiling on Linux
If you get any issues mentioning "min" or "max" while compiling on Linux, it is because you are including something that references the STL, and Valve's macros for min and max are conflicting with it.
Usually GCC is pretty good about telling you which files in particular are erroring.
Go to those files, and surround the erroneous includes with:
#include "tier0/valve_minmax_off.h" <your include that uses STL> #include "tier0/valve_minmax_on.h"
This should allow you to compile. Make sure to only wrap the includes that are using the STL, as other, game-related includes may require the Valve min/max macro defines!