--- Title: Stanley and the Death of Sourcemods Date: 2021-02-12 Modified: 2025-01-01 Category: gaming Tags: [steam, tsp, gamedev, fanwork] Ad: PC mods used to be better and I am a grumpy old man about it. also The Stanley Parable is there promo_image: i-hate-my-engine.jpg --- My first published, "successful" piece of game content was [The Raphael Parable](https://steamcommunity.com/app/221910/discussions/0/485622866453367258/), a little exploration game about wandering through an impossible office. I use the word "content", here because The Raphael Parable isn't a game per se, but it's a mod for the Steam release of [The Stanley Parable](https://store.steampowered.com/app/221910/The_Stanley_Parable/) that bootstraps the assets and mechanics to create a totally different game. A new version of The Stanley Parable is releasing soon: [The Stanley Parable: Ultra Deluxe](https://www.stanleyparable.com) is slated to be a remake with improved graphics, new endings, and console support. When I first saw this, I thought it would be a fun opportunity to go back to The Raphael Parable and tighten up some of the work that didn't age well (I slapped it together pretty quickly, in hindsight, and it shows in places) as a new mod for the new version of the game. !["I love my car, I just hate my engine" Unity logo mug](./i-hate-my-engine.jpg) *"I love my car, I just hate my engine"* Unfortunately, I quickly realized this was a non-starter for one simple reason: Unity. Ultra Deluxe is made by [crowscrowscrows](https://crowscrowscrows.com) in Unity, which unfortunately stops this iterative development in its tracks. Let me explain: ::: aside spoiler-free This article is spoiler-free for The Stanley Parable and everything else. ## The Weird Genealogy of The Raphael Parable The Stanley Parable itself started as a mod. The original published version is [a Half-Life 2 mod](https://www.moddb.com/mods/the-stanley-parable) from 2011, of which the 2013 Steam release is an [HD remix](https://steamcommunity.com/sharedfiles/filedetails/?id=95511356). The Source Engine, which Half-Life 2 is built on, makes it easy to author a set of new maps and release it as a "[sourcemod](https://developer.valvesoftware.com/wiki/File_structures_in_Valve_games)". Sourcemods are a fascinating artifact of Valve history, and function as a kind of mod support for source games built directly into the Steam client. Davey Wreden did exactly this to make The Stanley Parable; he took the basic 3D engine and a few generic office-themed assets and made a completely new experience. ![The original Stanley Parable](./tsp-classic.jpg) ![The HD remix](./tsp-doors.jpg) {: .side-by-side .align-top} *The original mod and the steam re-release* {: .image-caption} When writing the HD steam remake Davey again used Source, probably because he was familiar with the engine. (This time the engine from Portal 2, which was itself mostly based on Half-Life 2.) There's significantly more content and it's much more polished, but at the end of the day, just like the original mod was running on Half-Life 2, the Steam release of The Stanley Parable is essentially running on Portal 2. The Raphael Parable, then, is a mod of a mod. Really, due to how the Source engine is built, it's a mod of a mod of a mod of a mod, and so on, going all the way back to [Quake](https://web.archive.org/web/20060517235354/http://www.armadilloaerospace.com/n.x/johnc/recent%20updates/archive?news_id=290). It's a child of an ecosystem of iterative development, where games were built on top of each other for generations. ## Engines **The Source Engine is uniquely suited for extensibility.** [Valve designed the engine to be iterated on internally](https://en.wikipedia.org/wiki/Source_(game_engine)#History), and the full SDK [is provided for free](https://developer.valvesoftware.com/wiki/Source_Engine_Features#Source_SDK) via Steam to anyone who owns a Source engine Valve game, so it's extremely accessible and open. Levels are simply files that you can write and distribute very easily. (I'll get back to this point.) If you want to make a spin-off game or even a brand new game using a few of the same engine resources, you have the tools to make a sourcemod or a new game entirely. This model -- which you saw a lot up through the 2010s in games like Half-Life, Quake, and Doom -- is fundamentally different than how modern engines like Unity and Unreal work. While Unity projects [can be well-organized projects in their source form](https://learn.unity.com/tutorial/project-architecture-unity-project-folder-structure), Unity builds games into opaque binaries like traditional monolithic software. Assets are compressed and packed into proprietary archive files that are stored in as few pieces as possible. Games' code and script are compiled, and certainly not exposed by default. This makes modding a significantly more complicated undertaking. Unless the game developer explicitly built their game around it, there's no way add textures or levels or even substitute assets unless you're the original developer with the original source code. There's no forking off. If you want to modify an out-of-the-box Unity game, you *can*, but it's much harder. Code is compiled, so you'll need a disassembler and endless patience. And don't forget to use a codepoint patcher like fan-maintained [BepInEx](https://github.com/BepInEx), or else when the game updates it'll break. Forget level design tools or a development environment, you aren't getting any of those. Just skimming over my Steam library now, I can think of really interesting ways you could extend games like Antichamber, Downwell, Factorio, FEZ, Glitchspace, and The Turing Test, but there's really no way to. *Mods* aren't "dead" -- far from it -- but game engines are making design choices that discourage it. This isn't particularly unique to Unity either; the sad truth is no modern game engine is as easy to build on as Source was. There have been many games made in old, open engines like Source. Counter-Strike, Garry's mod, Antichamber, Sonic Robo Blast, MM8BDM, DOTA, and, of course, The Stanley Parable all forked off from existing games and became their own thing, but there's less and less opportunity for that now. And I haven't even begun to touch on accessibility or localization. Fan translations are tremendously valuable, and are made far easier when dialogue, voice audio, and text are exposed as editable files rather than precompiled hash. ![Sonic Robo 3D Blast, a Sonic fangame that runs on Doom!](https://www.youtube.com/watch?v=Ia097A0pKNM&feature=emb_logo) ## Files I think one of the key features that really makes a game naturally extensible is the way it physically stores files on the disk. For example, here's how sourcemods work: you download the mod and save it to `Steam\steamapps\sourcemods\`. That's it. Restart Steam and if you have the base game, the mod will show up in your list of installed games automatically. Run it and it'll fire up the game, patching in the mod files when appropriate. Maps for Source games are stored in the `maps` folder. You can put any BSP file you like in `common\Half-Life 2\hl2\maps`, fire up the game, run `map [file].bsp`, and you'll load into that level. Since each logical resource is stored as a file, it's easy to add levels or replace textures by simply replacing the files. Steam will even do this for you on-the-fly with sourcemods. Compare this to Unity games, where all the files and resources are thrown together in huge `.assets` archive files that are only readable with specialized user hacks. There's nothing close to logical segmentation, and arbitrary on-the-fly patching is a fever dream. This article is about sourcemods, but I'm such an adamant believer in the logical file approach that I want to talk about one of the games I think did modding best: Blockland. ### Blockland got it so right ![Blockland screenshot](./blockland.jpg) *Look, it's little baby Giovan* Blockland used to be one of my favourite games, back when it had an active community. It's a pre-Minecraft Lego-style building game, a bit like Roblox but populated with adults that hated each other.[^roblox] I need to write another article about Blockland some day, it was a really interesting experience. (Don't try to play it now, though, it's been unplayably broken for years.) [^roblox]: I assume this isn't what Roblox is like. I haven't played the game. The base game is pretty slim, but driven by a powerful "add-ons" system. Add-ons -- which were written in TorqueScript[^torquescript] and packaged in zip files -- defined almost every aspect of the game. Every block shape, every custom texture, every tool, every weapon, every vehicle, every particle, every scripting trigger. [^torquescript]: Orignally this article incorrectly called the addon language C# (because both formats use the same file extension) but I was [helpfully corrected](https://twitter.com/consoleSkunk/status/1374829679484358657). As I mention, C# isn't a great fit with addon-type systems because it's a compiled language, so Blockland addons using C# didn't make sense anyway. The few things the game ships with were *themselves add-ons* which could be selectively toggled or studied. If you wanted to build something for the game, you could just find how Blockland did it, make a copy, and start editing. Because the whole game was built around add-ons as first-class members there arose a thriving modding community. Users didn't even have to extract these addons; the game read and assembled everything at runtime. This made it them simple to handle and easy to distribute. I still love Blockland's add-on system. When I think of how to design a truly extensible game, it always comes back to mind. There are plenty of other games that use logical files excellently, of course -- Hack n' Slash, Haydee, Rimworld, Stellaris, Audiosurf 2, and Starbound, to name a few -- but the way Blockland treats the base game as modular add-ons has always made it stand out to me. ## Unity Bad? So, are Unity games like Ultra Deluxe preventing new creators from building on past work like they were able to, effectively pulling the ladder up behind them? Well, yes, but don't get angry at crowscrowscrows just yet. To be clear: you **definitely shouldn't still be making games in Source in 2020.** It's particularly good at the incremental design I've described in this article but it's really bad at a whole list of other, more important things. If you're making a game, you really need to be using something modern like Unity or [Godot](https://godotengine.org/) (or Game Maker for something simple) if you want to use an engine at all. I also can't give Source too much credit; it's very easy to author new levels and visual assets, but the mechanics of the 3D engine are much less flexible. Being developed with Unity lets Ultra Deluxe have much better game flexibility, as well as lighting, shaders, and console support. The fact that modern engines have shifted to a model that's less easy to extend than Source was for maps is just a modern reality, I certainly won't fault Ultra Deluxe for that. ![If someone tells you to use the Source engine, don't listen](./source-engine-bad.png) With the current tools, developers need to make the active choice to support modding or extending their game, which is a shame. Any mod support needs to be planned from the start, and extra resources budgeted accordingly. "Making your game moddable" is an extra step you have to take, and significantly increases the complexity of your project. Many developers do this, of course, and the Steam Workshop has become a great way of supporting extensibility in games. But for games like The Stanley Parable where there isn't an *obvious* use for moddability, there isn't the built-in support for extensibility that there used to be. From a developer perspective, picking on Unity again, making an extensible game isn't easy. Unity has a robust project management system with organized assets and design tools, but since it's precompiled there's no way of exposing *those* interfaces to users. If you google "Making a moddable unity game" you'll probably get [this thread](https://forum.unity.com/threads/making-a-moddable-game.312490/) from 2015 that covers some of the technical challenges. Since user content doesn't have access to the pre-compilation C# environment at runtime, Unity's default code pipeline makes first-class addons impossible. One common workaround has been to use [lua scripting](https://api.tabletopsimulator.com) for mods, but that's a major level of additional complication. Suffice it to say there is not a robust structure for automatically extensible games in Unity. Interestingly, a lot of modern games that *do* have robust mod support aren't made in common game engines. Gunpoint, Haydee, Starbound, and Stardew Valley, for example, aren't made in Unity, Unreal, or Godot. Stardew Valley was actually written from the ground-up in C# using XNA, which the developer has admitted [you probably shouldn't do.](https://community.playstarbound.com/threads/game-development-and-engine-decision.25210/#post-989009) It's counter-intuitive, but the modern quick-to-start, easy-to-prototype, high-compatibility game engines are inadvertently *worse* at modding than just doing everything from scratch. That just shouldn't be. In my opinion, it would be tremendously beneficial for game engines to have built-in tools for extensibility. From what I've seen, those systems don't exist in a robust form in modern engines, and that's a real deficiency. In my ideal world, structuring a game as to be easily extensible would be simple, easy, and the engine default. There's no pressing need for developers to manually make games like The Stanley Parable extensible, but if they weren't experimental projects like The Raphael Parable never could have existed. A fairly recent change to Unity has been the "addressables" module, which makes referencing custom assets slightly easier. Hopefully this represents an interest in making the engine more conducive to modding, but only time will tell. Meanwhile, good news for The Raphael Parable fans: a fellow called max_34 is working on a Stanley Parable mod called [The Stanley Parable: Ultimate Edition](https://www.moddb.com/mods/the-stanley-parable-ultimate-edition). From what I've heard, in addition to new levels, environments, and endings, it's going to include a remastered version of The Raphael Parable. That's going to be released some time after Ultra Deluxe, I think. As much fun as it is to see people enjoying what I made, seeing someone build on it is really something special. 🦆 # Related Reading - ["Making a Moddable Game?" Thread, 2015](https://forum.unity.com/threads/making-a-moddable-game.312490/){: .related-reading} - ["Mod Support comes to Robo Recall" Unreal Engine announcement](https://www.unrealengine.com/en-US/blog/mod-support-comes-to-robo-recall){: .related-reading} - ["Godot sandbox & modding support" github issue](https://github.com/godotengine/godot/issues/7753){: .related-reading} - ["Safe multiplayer modding" reddit thread](https://www.reddit.com/r/godot/comments/c78kwr/safe_multiplayer_modding/){: .related-reading} - ["Allow to import and load external assets at run-time" godot proposal](https://github.com/godotengine/godot-proposals/issues/1632){: .related-reading} - ["Managed Extensibility Framework (MEF)" on .NET docs](https://docs.microsoft.com/en-us/dotnet/framework/mef/){: .related-reading} - [Leadhead, "A Love Letter to The Source Engine" - YouTube](https://www.youtube.com/watch?v=9ojTBNfDKrw){: .related-reading} ![GranPC: @SophieSteak @giovan_h game mods are actually what got me initially involved with gamedev, and computing as a whole really! kind of sad that most games are extremely difficult to mod these days - even in some cases going out of their way to prevent it :(](https://twitter.com/GranPC/status/1464398806842327044) [The Forgotten City (2015 Skyrim Mod)](https://www.nexusmods.com/skyrim/mods/70219) which was developed into [The Forgotten City (2021)](https://store.steampowered.com/app/874260/The_Forgotten_City/) --- *Special thanks to [dom](https://twitter.com/zerstoerer) of crowscrowscrows for sending me the mug texture from [this trailer](https://www.youtube.com/watch?v=8MDu3xocHV0&t=10s) and for just talking to me in general*