Setting up Source SDK Base 2013 Multiplayer: Difference between revisions
| Line 285: | Line 285: | ||
|      pphoneId += wcslen((const wchar_t *)pphoneId) + 1; // improper casting |      pphoneId += wcslen((const wchar_t *)pphoneId) + 1; // improper casting | ||
| </code> | </code> | ||
| Building now might generate an error "unresolved symbol _IID_IspPhoneticAlphabetSelection". This was perhaps caused because you had already built and the partial build is broken. This could be fixed by rebuilding the "phonemeextractor" project. | |||
| == Setting up protobuff == | == Setting up protobuff == | ||
Revision as of 09:15, 6 December 2013
To get started, you will need to grab the source code from the Valve Software Source SDK repository on GitHub. Then you will be able to build the software and then build great and wonderful mods!
Obtaining the Code
GitHub provides a number of ways to obtain and update the code. Here's a review of the main ways to get the code, but GitHub Help is a great resource to learn more about using Git and the added features of GitHub.
Via Repository
The easiest way to keep updated on the latest released code is to use Git to obtain the repository. Git itself is a CLI for all platforms, but GitHub also provides installers that install both the CLI version and a GUI to help manage your repositories.
GitHub Client (Windows & Mac)
- Obtain the GitHub client.
- Install the GitHub client.
- Visit the Source SDK 2013 repository in your browser and click the "Clone in Desktop" button.
- This will open the GitHub client. Follow the instructions to clone the desktop onto your computer.
 
When you wish to update the code, you may do so by hitting the "Sync" or "Sync Branch" button in the repository.
Git CLI (All Platforms)
Detailed instructions on how to set up Git on any platform, including updating the repository, are provided by GitHub.
With the CLI installed, you can obtain the code using a line similar to this:
> git clone git@github.com:ValveSoftware/source-sdk-2013.git
Via Download
You may also download a ZIP bundle. This will give you the latest release, but you will need to manually download and update the code. If you also plan on contributing code back to the repository, you will need to follow the above Git instructions with a separate instance of your local files.
- Visit the Source SDK 2013 repository in your browser.
- Click the "Download ZIP" button.
Platform Specific Build Instructions
Creating Project & Makefiles
The 2013 SDK uses the Valve Project Creator (VPC) to generate platform-specific project files and makefiles. These files are platform specific and are required in order to build the SDK. Once you complete this step, there will be no need to run this step again unless an update requires new project files.
Windows
# Single Player Project > <SDK_ROOT>/sp/src/creategameprojects.bat > <SDK_ROOT>/sp/src/createallprojects.bat # Multiplayer Project > <SDK_ROOT>/mp/src/creategameprojects.bat > <SDK_ROOT>/mp/src/createallprojects.bat
This step will create Visual Studio Project (.vcxproj) and Solution (.sln) files in the SRC directory.
Note: If you do not have Visual Studio installed, you will receive errors in the above process.
Mac OS X & Linux
# Single Player Project > <SDK_ROOT>/sp/src/creategameprojects # Multiplayer Project > <SDK_ROOT>/mp/src/creategameprojects
On Mac OS X, this will create both `.mak` and Xcode project files in the SRC directory.
On Linux, `.mak` will be generated in the SRC directory.
Information about VPC
For more information on how to use VPC, look at the scripts themselves or run the following command on any platform:
> <SDK_ROOT>/<gameType>/src/devtools/bin/vpc /help
Note on Git Repository & Ignored Files
All these generated files from VPC are listed in the .gitignore file and ignored for commits in the repository. Individuals wanting to pull request changes should be aware of this while pushing changes.
Windows
Prerequisites
To build the Source SDK 2013 on Windows you will need Microsoft Visual Studio 2010 with Service Pack 1. It's also possible to use Visual Studio 2012 with the Visual Studio 2010 compiler by not "updating" the project settings to the new compiler.
If you want to build the phonemeextractor project you will need to download SAPI 5.1 from Microsoft. We aren't able to ship the Speech SDK with the Source SDK. Just put the sapi51 directory under src/utils/ and phonemeextractor will be able to link.
Building
Remember to create project & make files first!
- Open the "everything" solution file for the project type you wish to make.
- everything.sln
 
- Build the above solution.
- Open the solution file for the game you are building the mod for.
- games.sln
 
- Build the above solution.
At this point you should have client.dll and server.dll to load with the Source Engine game you based the mod on.
Building Shaders
If you are adding shaders in your mod you will need to build the runtime shader files on Windows.
- Open a command prompt and CD to one of the following:
- sp/src/materialsystem/stdshaders(for single player mods)
- mp/src/materialsystem/stdshaders(for multiplayer mods)
 
- Duplicate the file build<gamename>shaders.batand rename the file tobuildmyshaders.bat
COPY /B build<gamename>shaders.bat buildmyshaders.bat
- Open the file buildmyshaders.batin your text editor of choice.
- Change the variable SDKBINDIRto the location of the client data from Steam. This location may be different depending on your game's install location.
set SDKBINDIR=<steaminstallpath>\SteamApps\common\Source SDK Base 2013 Singleplayer\bin
- Run buildmyshaders.bat
For more information on authoring shaders in the Source SDK, see Shader Authoring.
Mac OS X
Environment & Tools Setup
Mac OS X, you will need Xcode 4.2 installed. You will also need to have "Command Line Tools" installed. You can find this at:
XCode Preferences -> "Downloads" -> "Components"
Building The Tools
Remember to create project & make files first!
To run the tools, run this command under Terminal:
> make -f games.mak
When successfully built, you should have client.dylib and server.dylib files to load with the Source SDK Base 2013 of your choice.
Linux
Steam Client Runtime
To build the Source SDK 2013 on Linux you will need the Steam Client Runtime.
- Download the Steam Client Runtime.
- Run the following commands to extract the runtime:
> tar xvf steam-runtime-sdk_latest.tar.xz > cd steam-runtime-sdk_<version>
Replace <version> with the version you just unpacked.
> ./setup.sh
Pick your architecture and debug/release preferences. Then answer Y to everything else.
> ./shell.sh --arch=i386
SDK Build
Remember to create project & make files first!
With the above prerequisite installed, run the following:
> make -f games.mak
At this point you should have client.so and server.so files to load with the Source SDK Base 2013 of your choice. More instructions on using the Steam runtime can be found in README.txt in the installed runtime directory.
Code Organization
Naming Conventions
The Source SDK is split into two directories at the root for <gameType>, followed by source for <gameName>. If you are building a single player mod, use the "sp" directory. If you are building a multi-player mod you should base yourself on the code in the "mp" directory.
- <gameType>
- sp (singleplayer)
- mp (multiplayer)
 
- <gameName>
- hl2 (Half-Life 2)
- episodic (Half-Life 2 Episodes)
- hl2mp (Half-Life 2: Deathmatch)
 
Each directory has a matching Source SDK 2013 Base appID to use to get the base mod files:
- Source SDK Base 2013 Singleplayer
- Client AppID: 243730
 
- Source SDK Base 2013 Multiplayer
- Client AppID: 243750
- Server AppID: 244310 (see SteamCMD for instructions on how to install this one)
 
These two base apps are very similar, differing mostly in update schedule. The Singleplayer base will only update with HL2 and the Episodes do, which isn't very often. The Multiplayer base will update a few times a year to incorporate engine changes from TF2 and Counter-Strike: Source. None of these updates should break mod compatibility.
Directory Structure
Under each of these directories is a very similar directory structure:
- game - Runtime files for the mods themselves. Your 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.
 
We recommend that you follow the conventions here as you add files for your own mod.
Common Errors
Common errors encountered in SDK 2013. Please use Discussion before posting other solutions.
RegKey Errors While Generating Project Files
"ERROR: Unable to find RegKey for .vcproj files in solutions."
This problem is usually caused by missing file extensions associations in the your system registry.
Visual Studio 2010
 Warning:Make sure to have 2010 Visual Studio Service Pack 1 or later installed.
Warning:Make sure to have 2010 Visual Studio Service Pack 1 or later installed.- Open Registry Editor
- Windows key + R
- Type 'regedit' without quotes and then hit Enter.
 
- Navigate to one of the following registry keys, based on the operating system you're currently using:
# For 32-bit (x86) Operating Systems:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\10.0\Projects\{60dc8134-eba5-43b8-bcc9-bb4bc16c2548}
# For 64-bit (x64) Operating Systems:
HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\VisualStudio\10.0\Projects\{60dc8134-eba5-43b8-bcc9-bb4bc16c2548}
- At the key, you will need to create a new string value.
- Navigate to: New > String Value
- Fill out the following information:
- Name: DefaultProjectExtension
- Value: vcproj
 
- Name: 
- Click "OK" to save the registry key.
 
Visual Studio 2012
A tool has been created by a member of the community to fix this type of error on Visual Studio 2012. Use at your own risk. Download source from GitHub (AutoIt v3 is needed).
vgui_controls Doesn't Compile
This problem is usually fixed by obtaining a fresh copy from the SDK distribution. If you're using a local GitHub repository, do a Sync (pull) on your repository. Otherwise you can download and reapply the ZIP file.
Compiling Source SDK 2013 with Visual Studio 2012
Valve recommends that mod creators should use Visual Studio 2011 with Service Pack 1 to create a mod. However, this section describes how to compile a mod using Visual Studio 2012. Follow the guide on this page up until the Windows - Prerequisites section. In the Windows - Prerequisites section, it recommends that the mod creator does not update the Visual Studio projects and touches on the fact that the mod creator will have to obtain sapi.lib from Microsoft's Speech SDK. This section will describe instead how to 1. update the Visual Studio projects, 2. obtain the Speech SDK library in more detail, 3. build the necessary protobuf library and 4. finishing up when compiling with the Source SDK 2013 with Visual Studio 2012.
Updating the Visual Studio Projects
Open everything.sln in either the source-sdk-2013\sp\src or source-sdk-2013\mp\src directory depending on if your mod is a single player or multiplayer mod, respectively. A prompt should appear asking if you want to update the VC++ compiler and libraries for each project in the solution. More details of this process can be found here. Click the "Update" button to update the projects and solution.
Building the solution now will cause a number of compiler errors including "missing sapi.lib" and "_MSC_VER: value '1600' doesn't match value '1700'". The following sections should fix these errors.
Setting up Microsoft Speech SDK (SAPI)
The Source SDK requires the Microsoft Speech SDK but doesn't come with it for licensing reasons. Download the Speech SDK 5.1 from here. This should download the SpeechSDK51.exe file. Run this and it should unzip contents to a selected folder. One of the contents it unzips is Microsoft SDK 5.1.msi. Running this with the default settings should create a directory in "C:\Program Files (x86)" called "Microsoft Speech SDK 5.1". Copy the "Microsoft Speech SDK 5.1" directory into the "src/utils" directory and rename it "sapi51".
Compiling now shows a number of errors in the "sphelper.h" file. There is more than one way to fix these errors. This section will describe how to fix them manually.
Change the following lines t have the code shown below.
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
Building now might generate an error "unresolved symbol _IID_IspPhoneticAlphabetSelection". This was perhaps caused because you had already built and the partial build is broken. This could be fixed by rebuilding the "phonemeextractor" project.
Setting up protobuff
Finishing Up
Releasing on Steam
If you have a Source Engine game that you are interested in releasing on Steam, please read this FAQ for more details.