aboutsummaryrefslogtreecommitdiff
path: root/src
Commit message (Collapse)AuthorAgeFilesLines
* Get it sort-of-mostly working in "Old Engine" HL2HEADmasterGravatar Michael Smith 2025-10-017-264/+579
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | While we're at it, come up with a way for certain gamedata matches to be Windows-only. Somewhat reduces ifdef usage, although does not entirely remove it of course. Tested in HL2 2707. Haven't tested other HL2 builds, or Episode 1. Doesn't seem to work in DMoMM yet either; not sure why. A big list of stuff still to fix follows. Hidden cvars are currently an issue. We still need to figure out what to do with the flag bits because FCVAR_HIDDEN just doesn't exist in OE and there's some other flag with the same value instead. We also need to do something about the flag setting in fixes.c since HIDDEN is again not a thing, and also DEVONLY is not a thing either. When the plugin is autoloaded, all the initial log text gets eaten, because there's some stupid crap we have to do to trick the engine into displaying coloured text otherwise it just won't. Not even stuff from Warning(). Very stupid, but Hayden already figured out a solution, so that'll be done in another upcoming commit. Apparently raw mouse input breaks the menu. We might need to bump up the priority on making that hook only be active when there's no UI open - something I wanted to do anyway due to the demo drive issues. Big thanks to Hayden for doing a lot of the initial groundwork on this, particularly the cvar registration stuff. He gets a copyright notice in con_.c even though I ended up doing a lot of stuff differently because quite a bit of his work is still in there. Don't blame him for the self-modifying code though, that was my crazy idea. Sorry, but, in my defence... Well, it works.
* Fix a bad error message in dbg.cGravatar Michael Smith 2025-09-291-1/+1
|
* Handle con_colourmsg this pointer inside con_.cGravatar Michael Smith 2025-08-102-27/+47
| | | | | | | | This is more prep for OE, as it will allow us to change how the call is forwarded for the other ABI (albeit in what looks like it'll be a fairly involved way) without requiring a bunch of extra code at every call site. It's maybe a little less efficient since the global has to be loaded every time, but coloured logging isn't exactly a bottleneck.
* Tidy up some extensions and remove some ifdefsGravatar Michael Smith 2025-08-037-30/+21
| | | | | | | | | | | | | | | | | | | | | Since this codebase is already extremely nonportable, I've decided to relax the obsessive ifdef-else-error usage around all the extensions. From now on, if there's no alternative to using an extension, we can just use that extension. If it's possible to do something in a relatively portable way, we can still try to do that in order to make the code somewhat reusable, in contexts where that makes sense. I also decided to use langext.h for naked functions and tail calls. If that's used in another codebase build with a different compiler, those just won't work, but that's fine. The benefit is really just that there's less ceremony in places where those are used, because it's likely there'll be a few more such places in the future, and it gets annoying reading all the double-underscore stuff all over the place. I still kind of want to do something about all the _WIN32 ifdefs too, but I've realised that doing so will lead to almost nothing actually being built on Linux. Then again, none of it currently runs on Linux so I guess that's a moot point. Will worry about it later, anyway.
* Use shorter spellings of __asm and __attributeGravatar Michael Smith 2025-08-039-20/+20
| | | | | | | Turns out, there's no need for the trailing underscores. Plus, glibc does some stupid stuff with __attribute__ for non-GCC compilers. Not that that matters here, but it seems like a good practice just to use the forms that never have such problems. And it's shorter too.
* Switch to Intel assembly syntaxGravatar Michael Smith 2025-08-033-8/+8
|
* Add an abstraction for hooking v1 and v2 commandsGravatar Michael Smith 2025-08-024-50/+130
| | | | | | | | | | | This is a step towards making command hooks work in OE, once OE is supported. Not the most ideal or efficient thing in the world, but it works okay until we come up with something better, I suppose. Not a fan of the argv copying but avoiding that would make the API a lot less ergonomic. Not the easiest problem to solve, really...
* Make additional use of untyped command callbacksGravatar Michael Smith 2025-08-028-27/+18
|
* Set up for 0.15Gravatar Michael Smith 2025-07-312-5/+5
| | | | | Don't worry about the fact I typed l4 instead 14 for the last release btw. No idea how that happened but I guess it doesn't matter anyway.
* Prepare update string and set zip date for 0.14v0.14-BETAGravatar Michael Smith 2025-06-271-2/+1
|
* Add a way to cancel "ISG" in Portal runsGravatar Willian Henrique 2025-06-271-0/+152
| | | | | | | | | | | | | | | | | | This is a stopgap solution approved by the Portal moderators until we have a better way to handle timing and verifying closing/restarting the game mid-run. Essentially, the agreed-upon short-term solution is to somewhat emulate restarting the game by simply turning off the glitch and sending the player back to the main menu. Committer's note: this wasn't added to the Linux compile script since it doesn't work and I honestly just couldn't be bothered adding in the usual ifdef-errors. And in fact I'm starting to wonder if we should just be leaving out features that don't work on Linux to avoid all the ifdefs, but that can happen later because the main goal of committing this is to get a release out, so I don't want to faff about with that right now.
* Fix indexing edge case in mkgamedataGravatar Michael Smith 2025-06-271-1/+3
| | | | | | | | | | This took longer to debug than one might like to admit. In some very specific cases, the loop condition would fail before the return condition, causing the rest of the logic to proceed with out-of-bounds accesses to indents and exprs (which are zero-initialised), in turn leading to garbage getting dumped into the generated header. The garbage in question would be line 0, and [argv[0]
* Add memset to wincrt.cGravatar Michael Smith 2025-06-271-0/+17
| | | | | The code I'm about to commit appears to generate a call to this. Funny we never needed it until now...
* Abstract over con_var layout changes from OE to NEGravatar Michael Smith 2025-06-217-64/+108
| | | | | This doesn't allow us to support OE in and of itself but is part of the groundwork necessary to do so in the future.
* Separate our command callbacks from Source'sGravatar Michael Smith 2025-06-219-55/+53
| | | | | | This improves the ergonomics of a few different things, and sets us up somewhat for the fact OE had a different interface for commands too (it was v1 only and had a separate API call for getting the args).
* Bump version to 0.14 for the next release cycleGravatar Michael Smith 2025-06-212-4/+4
|
* Prep 0.13 release... alreadyv0.13-BETAGravatar Michael Smith 2025-06-082-6/+6
|
* Improve the plugin_load/plugin_unload hooksGravatar Michael Smith 2025-06-072-43/+50
| | | | | | | | | | | Most notably, don't just silently return when no parameter is provided; allow the default handler to print the usual error message. Also, don't raise the PluginLoaded/PluginUnloaded events when nothing has actually happened. And rearrange the v1/v2 union so we don't need to spell out `v2.common`. Error message issue pointed out by Evan Lin - thanks!
* Mildly optimise some console variable stuffGravatar Michael Smith 2025-06-062-35/+28
| | | | | | Turns out, some stuff that was done virtually and/or indirectly and/or conditionally to match the engine never really needed to be done as such. Considering this codebase is in fact not part of the engine.
* Fix features continuing to init when preinit failsGravatar Michael Smith 2025-06-031-4/+4
| | | | | I think this might actually be the last of the gluegen regressions now, for real, maybe, perhaps.
* Set up for a 0.12 releasev0.12-BETAGravatar Michael Smith 2025-06-012-5/+6
|
* Check for a null srvdll in sst_dbg_sendtablesGravatar Michael Smith 2025-06-011-0/+4
| | | | | Avoids crashing if we couldn't get the interface for whatever reason. Apparently bill ran into such a case.
* Fix bad returns missed in the feature init rewriteGravatar Michael Smith 2025-06-013-5/+5
|
* Fix broken condition for hiding failed featuresGravatar Michael Smith 2025-05-301-3/+6
| | | | I inverted the condition, d'oh!
* Bump versions and dates yet againGravatar Michael Smith 2025-05-112-5/+5
| | | | On the plus side, SST's release cadence has never been so lively!
* Fix the broken broken addon check fixGravatar Michael Smith 2025-05-111-31/+24
| | | | | | | | | | Sorry Hayden. My next project for SST is a testing system. Because I *royally* screwed up this release cycle. Anyway I just inlined that function because it was evidently a sufficient source of confusion that I managed to totally screw up basically every part of call boundary. Truly catastrophically bungled the thing. I must have been really tired...
* Fix a stupid typoGravatar Michael Smith 2025-05-101-1/+1
| | | | Inconsequential at the moment, but still worth fixing.
* Fix L4D1 crash for yet another immediate bugfix releasev0.10-BETAGravatar Michael Smith 2025-05-093-20/+6
| | | | | Every. Single. Time. And having screwed up the zip dates was just a bonus I suppose.
* Improve the memcpy/memcmp functions a bitGravatar Michael Smith 2025-05-051-8/+21
| | | | | | I think memcpy might have been returning the wrong thing before, actually, but I guess it didn't matter in practice. Who the hell uses the return value from memcpy?
* Add some useful info printouts to debug buildsGravatar Michael Smith 2025-04-306-50/+240
| | | | | | | | | | | | | | | | | | | | Specifically when building in debug mode, we now: * Display all features on load, including skipped and internal ones, sorted by internal name instead of display name. * Print the names of all matched gametype tags after the feature list. * Add an sst_dbg_getcmdcb command to get the address of a command callback for quick breakpoint insertion or Ghidra lookup. * Add an sst_dbg_sendtables command to dump out the full ServerClass tree to help get names for entprops.txt. Note: this output is very long so you'll likely need to log console output to a file to be able to read it all. There's a bunch of developer experience and debug help stuff I want to get done eventually. This is just a very small piece, but it's a start.
* Fix all the brokenness I introduced to l4daddonGravatar Michael Smith 2025-04-301-34/+34
| | | | | | | | | | | | | | | | | | | | | | | | With apologies to Hayden, whose code was mostly fine until my quest to make it neater ended up bungling stuff. I wanted it reviewed and tested before pushing it anywhere public but people have limited free time - how dare they!!!! - and at some point I kind of impatiently just sent it because I had a pile of unrelated changes I didn't want to untangle. I didn't really know how to reproduce the bad performance myself to test the fix here properly, so I was kind of unfairly relying on him to do it, even though he'd already tested his own code and made sure it worked *before* I decided to break it. My bad. Don't worry though, I was never actually going actually release SST in such a broken state. I mean, I have released it in worse states before, but I wasn't gonna do it on this occasion. :^) Now this is definitely done correctly, I think, and I've done yet another pass over the comments, I'm pretty confident that 0.9 is around the corner. Just a few more commits of entirely non-user facing stuff to get out of the way first...
* Add type-safety to virtual calls and accessorsGravatar Michael Smith 2025-04-1727-256/+267
| | | | | | | | | | | | This probably should have been the design from the start. It's still possible to use void pointers, and this is done in a couple of places for simplicity, but wherever possible, we have actual structs for things now. Additionally, in places where vtables are fiddled with, e.g. vtable hooks, we have actual struct definitions with vtable pointers so there's need for pointer-casting horror.
* Add missing REQUIRE_GAMEDATA things to demorecGravatar Michael Smith 2025-04-162-3/+8
| | | | | | These gamedata entries are always available, but there's no reason not to check for them in case that changes in future. As-is now, the checks will be trivial for the compiler to optimise out.
* Remove iflush() from inline hooking codeGravatar Michael Smith 2025-04-161-21/+0
| | | | | | | | | | | | | I had this hunch that Intel's strong memory model wouldn't actually require anything like this, and some cursory research suggests this is correct even across threads, or at least definitely within the same thread which is what we care about. I kind of don't know why FlushInstructionCache() even exists in that case. Maybe it's for other architectures or maybe it's just for the benefit of debuggers. Microsoft's documentation helpfully asserts that it is necessary to call it even though it isn't, and doesn't elaborate further. Of course.
* Rework API for inline hookingGravatar Michael Smith 2025-04-1611-129/+216
| | | | | | | | | | | | | This both simplifies and complicates things, but probably hopefully maybe simplifies things overall. Certainly in cases like the L4D1 demo thing where there's 3 inline hooks at once, it seems simpler to be able to batch the fallible stuff to avoid rollbacks. In cases where you only need one hook, it's a bit more verbose, but what can you do. Thanks bill for discussing this with me pretty exhaustively and giving a lot of good input. I think both of us still kind of hate it actually.
* Refrigerate one more errorGravatar Michael Smith 2025-04-161-1/+1
|
* Fix major idiocy in inputhud (and hud kinda)Gravatar Michael Smith 2025-04-162-2/+5
| | | | Also pointed out by bill. D'oh, guess I'm fired.
* Fix minor idiocy in msg.cGravatar Michael Smith 2025-04-161-2/+2
| | | | | | | | | | I had at one point tried to macrofy the repetitive functions. After being talked down from that madness, I LSP-expanded all the macros out and went through rewriting the crazy expressions into constants. Except those two for some reason, because I'm blind I guess. Thanks bill for pointing this out.
* Update info in the readme and a few commentsGravatar Michael Smith 2025-04-124-4/+4
|
* Fix mistakes I made integrating Hayden's old codeGravatar Michael Smith 2025-04-092-9/+9
| | | | | Doesn't matter how many history rewrites I do before pushing my local branch, there will always be something I still got wrong.
* Put some error paths in the fridgeGravatar Michael Smith 2025-04-084-104/+115
|
* Fix the infamous Swamp Fever "god mode glitch"Gravatar Hayden K 2025-04-072-0/+17
| | | | | | | | | | | | | | | | | | Turns out this was fixed in version 2112 (October 2012), so it was fairly easy to isolate in Ghidra (I had previously thought this was fixed by TLS). The CDirector::FinaleEscapeState member is used in CDirector::IsFinaleWon (and maybe another function, I don't remember). Prior to Valve's fix, the value was never reset to 0 after finishing a campaign, so when the Swamp (or Crash Course) "minifinale" events ran, the game would behave as though the player was entering the end-of-finale cutscene and block votes, make players invincible etc. 2112 fixed this bug by setting the member back to 0 in CDirector::Reset, so here we just set it to 0 when quickreset is used, since that is essentially the recommended way to start a run at this point. Now co-op hosts won't need to restart their game after finishing a campaign anymore!
* Remove years from copyright headersGravatar Michael Smith 2025-04-0785-114/+114
| | | | | | | | They're legally unnecessary as far as I know, and kind of annoying to maintain on a long-term basis. This was done with the consent of all 3 other contributors, in case anyone was wondering.
* Fix quickreset not working on L4D1 ApartmentsGravatar Hayden K 2025-04-072-1/+3
| | | | | | Confusingly, the old matchmaking interface refers to No Mercy as apartments (plural), but refers to the first level as apartment (singular). Good meme.
* Write the update notes for 0.9Gravatar Michael Smith 2025-04-061-1/+12
|
* Make Steam L4D1 demos backwards-compatibleGravatar Hayden K 2025-04-061-0/+186
|
* Add portable unreachable macro, just for funGravatar Michael Smith 2025-04-061-2/+3
| | | | | | This isn't useful to us at all, but might be useful to someone else. I always try to write code for multiple compilers for this reason, even if SST ultimately still requires Clang.
* Tweak a couple of bits of whitespaceGravatar Michael Smith 2025-04-062-2/+2
|
* Add feature to remove the chat rate limitGravatar Hayden K 2025-04-061-0/+88
| | | | | This probably works for basically every game, but it was only tested for L4D/L4D2/L4D:S/Portal 2.
* Add L4D1_1015plus and L4D1_1022plus gametype tagsGravatar Hayden K 2025-04-062-2/+16
| | | | | | | | | | 1022 is the update that adds Mac support and introduces some of the already known vtable changes (this update is similar to 2040 for L4D2 in that regard), the tag will also see some use in some upcoming features. The 1015 tag is questionably necessary, but will be used for at least one feature (it's also the update that adds the newer matchmaking interfaces used in l4dreset.c, but having the tag available doesn't help anything there).