Compiling under VS2022: Difference between revisions
m (Github repo with particles.lib it's dead) |
m (Fix dead links to point towards the correct repo (seems to have transferred ownership?)) |
||
Line 9: | Line 9: | ||
This article is primarily based on these two GitHub repos | This article is primarily based on these two GitHub repos | ||
* https://github.com/ozxybox/source-mp13-vs2022 | * https://github.com/ozxybox/source-mp13-vs2022 | ||
* https://github.com/ | * https://github.com/SCell555/Source-PlusPlus | ||
== I'm starting from scratch! == | == I'm starting from scratch! == | ||
Line 20: | Line 20: | ||
The best solution is to go grab an edit of VPC that works for modern versions of Visual Studio. | The best solution is to go grab an edit of VPC that works for modern versions of Visual Studio. | ||
[https://github.com/ | [https://github.com/SCell555/Source-PlusPlus/blob/HEAD/src/devtools/bin/vpc.exe Such as this one] | ||
Another solution would be to add the registry keys VPC is looking for. | Another solution would be to add the registry keys VPC is looking for. | ||
Line 33: | Line 33: | ||
The best solution for this is to go grab an edit of '''particles.lib''' that's been fixed. | The best solution for this is to go grab an edit of '''particles.lib''' that's been fixed. | ||
[https://github.com/ | [https://github.com/SCell555/Source-PlusPlus/blob/HEAD/src/lib/public/particles.lib (Like this one)] | ||
If you're not a fan of that idea, one alternative could be telling VPC to allow multiple symbols to exist for the client project. This is not a great practice though! | If you're not a fan of that idea, one alternative could be telling VPC to allow multiple symbols to exist for the client project. This is not a great practice though! | ||
Line 46: | Line 46: | ||
== In Recap == | == In Recap == | ||
Do what [[Source_SDK_2013|this page]] asks you to do while ignoring any reference to Visual Studio 2013, fix the Registry keys problem with the fix from the same page, download '''particles.lib''' to {{path|<mp or sp>\src\lib\public}} from [https://github.com/ | Do what [[Source_SDK_2013|this page]] asks you to do while ignoring any reference to Visual Studio 2013, fix the Registry keys problem with the fix from the same page, download '''particles.lib''' to {{path|<mp or sp>\src\lib\public}} from [https://github.com/SCell555/Source-PlusPlus/blob/HEAD/src/lib/public/particles.lib this], and finally, replace {{file|memoverride|cpp}} located at {{path|<mp or sp>\src\public\tier0}} with [https://github.com/ozxybox/source-mp13-vs2022/blob/master/mp/src/public/tier0/memoverride.cpp this one]. Have fun making Source mods with updated software ;) |
Revision as of 03:24, 17 April 2024



With Visual Studio 2013 becoming older and harder to obtain, using Microsoft's (as of writing) actively supported and updated Visual Studio 2022 becomes a no-brainer. As it is not a officially-supported Integrated development environment in eyes of the Source SDK, some work is required to get it all functioning.
This article is primarily based on these two GitHub repos
I'm starting from scratch!
If you don't want to deal with setting up the project, or if you have problems compiling the source code because of certain errors, you can clone this repo since it's based on the official Source 2013 repo and has minimal changes, just to make it run without problems. Please disregard any "compile process successful but file not found" warning as it is meaningless.
Running VPC
If you don't have an older version of Visual Studio on your computer, VPC will fail to run, as it can't find certain registry keys specific to older versions.
The best solution is to go grab an edit of VPC that works for modern versions of Visual Studio. Such as this one
Another solution would be to add the registry keys VPC is looking for. You can follow this fix.
Once running the VPC scripts will need to be modified to support the newer toolsets.
Fixing particles.lib
Once everything's compiling, you'll hit a snag with particles.lib. It defines the symbol _hypot, and in VS 2022, that symbol is already getting used up.
The best solution for this is to go grab an edit of particles.lib that's been fixed. (Like this one)
If you're not a fan of that idea, one alternative could be telling VPC to allow multiple symbols to exist for the client project. This is not a great practice though! Example
Fixing memoverride.cpp
The main file that needs to be fixed for Source to work under VS 2022 is memoverride.cpp
.
In Recap
Do what this page asks you to do while ignoring any reference to Visual Studio 2013, fix the Registry keys problem with the fix from the same page, download particles.lib to <mp or sp>\src\lib\public
from this, and finally, replace memoverride.cpp
located at <mp or sp>\src\public\tier0
with this one. Have fun making Source mods with updated software ;)