|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is kind of a breaking change but the other code was obviously never
released or relied on by anyone - it will be pushed at the same time as
this in fact. It still seems worth having the original committed
separately to show the progression of development of the feature,
however. Technically the standalone vote cooldown resetting could also
be added back if ever desired however there doesn't seem to be that much
of a use case for that at the moment.
This feature ought to be a lot more convenient now as it allows for
resetting back to a set starting point no matter where the player is in
a run. It isn't universally useful as All Campaigns Legacy solo runs
require switching to a different type of server and Main Campaigns co-op
runs require restarting the game after Swamp Fever to work around the
god mode bug, however it is still useful in a good few situations.
Unfortunately this turned out to be pretty complex to implement, first
requiring a bunch of interop with valve's rather wacky KeyValues stuff,
and then requiring a bunch of especially difficult reverse engineering
of L4D1 v1.0.0.5 because it doesn't use said KeyValues stuff and does
something else completely different instead.
A side effect of all this work is that the nag removal hack is now part
of the KeyValues stuff in kvsys.c, which is kind of a comfier place for
it than just kind of dumped in the middle of sst.c. | 
| | 
| 
| 
| 
| 
| | Might as well return the length since we have it anyway. Also this maybe
fixes the totally busted Linux code but it's still untested and probably
doesn't work for reasons that will be discovered later on. | 
| | 
| 
| 
| | Pointed out by Bill. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | In most versions of L4D2, players cannot call a vote (e.g. switch
campaign, change difficulty, restart campaign) more than once every 3
minutes. This makes resetting on a first map a pain, usually requiring
reloading the map to reset the vote state.
This new sst_l4d_vote_cooldown_reset command empties the list of
structures tracking vote callers, allowing all players to vote again
immediately. This should make resetting runs a lot easier on versions
without unlimited votes. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This is actually required for an upcoming feature to work, as an
instruction scan bumps into a xorps instruction.
Still not supporting SSE3 or later, or AVX, although at this point it
seems that that would be relatively easy to add, as this thing has kept
growing on an incremental case-by-case basis. | 
| | |  | 
| | 
| 
| 
| 
| | For the record, most of this wasn't Bill's fault. I shouldn't be
fixing up patches in the middle of the night. :^) | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Use const in more places where it makes sense - not absolutely
  everywhere because it can get a bit annoying
- Make all the instruction search loops a bit more readable by casting
  the function pointer into a temporary variable to loop over
- Add a few more doc comments and fix a typo or two
- Make that RTTI thing flexibly-sized, finally
- Don't include gamedata.h in vcall.h for no reason; consequently
  include gamedata.h in a bunch of places where it was implictly pulled
  in before
- Fix dbg_toghidra() and ent_getedict() having mismatched return types
  between their headers and respective source files
- Remove that one broken, hacky, secret Portal non-feature that probably
  nobody even ended up using; it can be implemented properly later if
  required | 
| | 
| 
| 
| 
| 
| | This still isn't totally complete, or used anywhere yet, but it's been
sitting here for literally months, so it might as well get committed so
there's one less thing to deal with later. | 
| | 
| 
| 
| | This is a surprise tool that will help us later! | 
| | |  | 
| | 
| 
| 
| 
| 
| | Adds tags for L4D2 2147 and Portal 3420. Committer's note: really the
gamedata system might benefit from improvement in the future to support
things like numerical ranges, but this will do for now. | 
| | |  | 
| | 
| 
| 
| 
| 
| | In both the engine and SST it's used in more places than just console
printing, so it makes more sense to give it a more appropriate nanme and
location. | 
| | |  | 
| | |  | 
| | 
| 
| 
| | I need to write a pre-commit hook to check this or something. | 
| | 
| 
| 
| | This has been a known issue for a long time. Let's finally fix it! | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | These were never actually used before or this would have been caught
sooner, but as they're being used in some in-progress code this
obviously needs fixed now.
The virtual table indices in use were wrong for some engines due to the
funny thing Windows does with reverse-ordered overloads. The code for
building the plugin's own virtual tables explicitly accounts for this
but calling into existing cvars failed to do so, due to a skill issue.
This fix is kind of inelegant and stupid but making it elegant and
non-stupid is less of a priority at the moment. It should happen
eventually with future improvements to the gamedata system, for some
definition of "should," "eventually," and "future." | 
| | 
| 
| 
| | Removes the mem_store functions because they're never used anywhere. | 
| | 
| 
| 
| | Note: fixes.c was changed this year, so correct the copyright year too. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Nobody seems to have been affected by this in the wild yet, thank
goodness. Will probably be a while before there's an actual release, so
hopefully people will continue not to be affected.
I suppose it's only an issue for paths longer than 128 characters, so
it's not too likely to matter under normal circumstances... | 
| | |  | 
| | |  | 
| | 
| 
| 
| | Thanks Bill for figuring out what the problem was. | 
| | 
| 
| 
| | This was an accidental regression in an earlier refactoring. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | Thanks Aciidz for pointing out the strings with no newline in them, and
thanks Clang for warning me I wasn't using a function for ages while I
was too lazy to delete it. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Another big one. Here's a list of things:
- Since the upcoming C23 standardises typeof(), use it as an extension
  for the time being in order to allow passing arbitrary types as
  macro/codegen parameters. It wouldn't have been a big leap to do this
  even without standardisation since it's apparently an easy extension
  to implement - and also, to be honest, this project is essentially glued
  to Clang anyway so who cares.
- Likewise, bool, true and false are becoming pre-defined, so
  pre-pre-define them now in order to get the benefit of not having to
  remember one header everywhere.
- Really ungodly/amazing vcall macro stuff now allows us to call C++
  virtual functions like regular C functions. It's pretty cool!
- Events can now take arbitrary parameters and come in two types:
  regular events and predicates.
All this makes the base code even uglier but makes the feature
implementation nicer. In other words, it places more of the cognitive
burden on myself and less on other people who might want to contribute.
This is a good tradeoff, because I'm a genius. | 
| | 
| 
| 
| | Shoutouts to Lokki for accidentally reporting this bug. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | This is for somewhat later. I'd always planned to use it - it existed
already in earlier private repos, in fact. I just didn't bother to
import it here in case it wouldn't actually be needed, but with the way
current plans are going, it's definitely going to be needed, so here it
is. | 
| | 
| 
| 
| | Spotted by Bill the other day. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Only if the code page in question is that of the system, obviously;
Source itself will fail to start otherwise anyway.
This fixes issues for at least one Russian user who'd named a "Games"
folder "Игры," which I am told roughly translates to "Games" (and also
exactly translates to "Games"). | 
| | 
| 
| 
| | Copyright note: the stuff Bill wrote is all still in the other file. | 
| | 
| 
| 
| 
| 
| | Committer's note: this is somewhat adapted from Bill's original code,
written a while back, but he gets full credit for actually doing the
hard part. | 
| | 
| 
| 
| | Also centralise NEXT_INSN macro, into its own header at least for now. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | Some of the alias stuff was kind of stolen from earlier figuring-out
Bill did. More Bill code is also on the way. :^) | 
| | |  | 
| | 
| 
| 
| 
| 
| | It'll be less confusing not to have development builds versioned the
same as existing releases. That's probably obvious, but I'm still new to
this releasing software business! |