|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | 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! | 
| | |  | 
| | |  | 
| | 
| 
| 
| | Preparing for release, I spose! | 
| | 
| 
| 
| 
| 
| | You can widen the text field to read the whole thing, but that's not
immediately obvious. Let's just shorten the text and make it nice and
concise so people can figure out what to do more easily. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Currently only works in 3420 and 5135 and uses hardcoded offsets with a
byte pattern sanity check. Future work includes making it more widely
compatible, and also doing the crazy thing I wanted to do but gave up on
wherein the actual textures and stuff get patched in memory to sync up
all the colours.
Oh also, a couple of vtables were erroneously made executable, so I went
ahead and fixed that while I was at it. | 
| | |  | 
| | |  | 
| | 
| 
| 
| | Meh, whatever. | 
| | 
| 
| 
| 
| | A stupid, stupid bug I'd probably never have caught for years and years.
Thanks Evan Lin in the Portal Discord for pointing it out! | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | People want to be able to write a scheduled-release passphrase to demos
to prove that said demos were recorded during a timeboxed event. Ideally
this is something that'd be part of the custom demo data and general RTA
run management stuff that's planned, but of course that doesn't exist
yet. When it does exist, we'd probably want rid of this nonsense, so
it's marked hidden and I don't plan to document it anywhere "official."
It's just here for people who really need it in the short term. | 
| | |  | 
| | 
| 
| 
| | This is how it should've been to begin with, but I was lazy. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | I still haven't bothered to flesh out all the possible indices for
GetEngineBuildNumber but we're back to being able to use it to detect
The Last Stand (as a result of some old version testing Aciidz did -
thanks again!). This means we can do away with the terrible map file-
based hotfix. Also, turns out sst_l4d_testwarp doesn't work if the
plugin gets loaded early via VDF because certain SendTable offsets start
out negated, so we work around that too now. | 
| | |  | 
| | 
| 
| 
| 
| 
| | This was the simplest way I could think of to solve this issue. Thanks
again Aciidz for pointing the issue out, and thanks Turtle Rock for
shipping such a broken game. | 
| | |  | 
| | 
| 
| 
| 
| | This is part of some other WIP but might be useful in general so might
as well be committed on its own. | 
| | 
| 
| 
| | Idiotic problems require idiotic solutions. | 
| | |  | 
| | 
| 
| 
| 
| | Don't want people hitting a bind by accident and invalidating their runs
instantly. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | This was a lot more code than expected, but it might be finally close to
time to release the next beta...
We'll see if any more rabbit holes present themselves to jump into,
though. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - A bunch of stuff is now defined in one header, engineapi.h
- engineapi.c is responsible for setting up any interfaces/stuff that's
  used in more than one place
- mkgamedata is pretty much rewritten and now supports nested
  conditionals
- gamedata variables no longer have the gamedata_ prefix because it was
  just annoyingly long all the time
- vcall macros are somewhat revamped and support dynamic (gamedata)
  indices
- Portal 1 FOV can be set anywhere from 75-120 using fov_desired -
  tested in both the main versions currently used by runners
- A few typos were also fixed ("intput," "writeable," "indexes") | 
| | 
| 
| 
| | It's amazing how long these things can go unnoticed. | 
| | |  | 
| | 
| 
| 
| 
| 
| | I'd noticed this at some point but it didn't seem to matter, and now all
of sudden it does matter because magic. The hook just stopped working
suddenly. | 
| | |  | 
| | 
| 
| 
| | This was dumb. | 
| | 
| 
| 
| | Default gamedata values actually work the way they're supposed to now. | 
| | |  | 
| | |  | 
| | 
| 
| 
| | Thanks Aciidz for helping test this. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | - Demo recording can now be started before connecting to a server
- The overall demo-number-preserving logic is a lot simpler and should
  work even if the plugin is reloaded or something
- As an added feature, recording to a nonexistent directory will produce
  an error instead of silently failing | 
| | 
| 
| 
| 
| | No idea when the next release will happen yet, but this might as well
happen now to avoid forgetting later. | 
| | 
| 
| 
| 
| 
| 
| 
| | They're literally always defined thusfar, and it's always possible to
include specific headers for other stuff. So, rather than litter the
source with defines (which might not even work in the likes of os.h if
some other system header already decided to define/include stuff), let's
just define it at the build script level. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | hook_inline() uses the new x86_len() function to get instruction lengths
instead of doing full-blown disassembly, which should be a tiny bit
quicker, and also removes the next for about 90KiB of lookup tables and
such in the final binary. The code-digging logic in demorecord is also
rewritten to be opcode-based rather than mnenmonic based. In general,
going forward the plan is to always rely on opcodes and thus avoid a
bunch of disassembly work every plugin load.
udis86 is still in the tree for now to provide dbg_asmdump(), but it's
only compiled into debug builds and left out of releases completely. As
such, the whole BSD licence statement is also gone from the distribution
LICENCE files. There's now also a dbg_toghidra() which spits out a
rebased address to look stuff up for proper reverse engineering, which
might be more useful than dbg_asmdump() anyway. If nobody ends up using
the latter ever again, udis86 could get chucked completely. We'll see.
Also shoehorned into this commit are a couple more forgotten copyright
year bumps and some general minor cleanup here and there, because I
couldn't be bothered wading through all the diff hunks. Oh, and
makebindist.bat now makes an effort to make the zip file timestamps
predictable/reproducible. That should be a different commit for sure,
but oh well too bad. | 
| | |  | 
| | 
| 
| 
| 
| 
| | Thanks Aciidz and Bill for spotting these.
Lesson (ostensibly) learned: Don't program while sleep-deprived! |