|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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. | 
| | 
| 
| 
| 
| | This brings the DLL size down to a quarter of what it was. Dunno why
Clang doesn't do this by default, but apparently it doesn't! | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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! | 
| | 
| 
| 
| 
| | They're still temporary, I promise, but this will make tweaking the
toolchain or turning debug builds on and off a lot simpler. | 
| | 
| 
| 
| | Chalk this up to improper testing and being tired and not using brain. | 
| | 
| 
| 
| | Breaks the Linux build because I can't file paths brain I need sleeping | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Just ask the engine for the game directory instead of doing the stupid
  argv sniffing hacks from the early days of trying to get the damn
  thing working.
- Also add some other path variables, functions and whatnot, and do some
  other minor tidying up.
- Also also, another damn copyright year, somebody please help me.
Unfortunate negative effect off this change: con_init() no longer
reports the game name, because it has to happen before gameinfo_init().
I've decided I don't really care, though. | 
| | 
| 
| 
| 
| | This also introduces some stuff for interacting with the current plugin
list. Other plugin management utilies are Coming Soon... | 
| | 
| 
| 
| 
| 
| 
| | Turns out creating the input window on the main thread means it actually
gets events from the game's event loop on the main thread which means we
don't have to do our own event loop at all and in fact doing so is kind
of broken and causes thread lockups and leaks and other such nonsense. | 
| | 
| 
| 
| | It's late, okay? | 
| | 
| 
| 
| 
| | It's archive so you can set m_rawinput 1, load SST via VDF and then
never think about it again. |