| Age | Commit message (Collapse) | Author | 
|---|
|  | With emscripten builds we need to let emscripten own the main loop,
hence why play_run_slice() was added.
For non-emscripten builds nothing is different. | 
|  | In the interests of keeping things bisectable this is one big commit of
everything necessary to go from OpenGL 2.1 to OpenGL ES 2.0 in one fell
swoop.
There's a handful of annoying mechanical changes necessary in shaders like
removing the 'f' suffix on float constants e.g. 1.f becomes 1.0 etc.
This is primarily happening to enable emscripten builds | 
|  | Emscripten integration will want this function.
A few mechanical changes required to catch up with upstream
libplay API changes as well. | 
|  | On MacOS in particular it seems when executing sars via gui from
the downloaded .zip the cwd isn't being set to the containing
directory beforehand.  This prevents the assets from being found
at the correct location.
With this commit SDL_GetBasePath() is used to try find the
executable's containing directory.  When successful, a chdir() is
performed to this path in an effort to ensure the assets/ dir is
where expected in relative terms.
These are all done in a non-fatal best-effort fashion, simply
warning when failed.
An unfortunate side effect of this is when you're explicitly
running sars from somewhere else with a different relative
assets/ directory for development/testing purposes, it no longer
uses the inherited cwd.  Instead it will always move itself to
wherever the executable resides.  Maybe I'll add a flag for
controlling this behavior.
It's also unclear to me how safe assuming chdir() works will be
vs. platforms supported by SDL2.  Sure, chdir() is POSIX, but um,
SDL2 speaks to supporting platforms like PSP and Android.  I
doubt chdir() is available everywhere, and I wonder why there's
no SDL_chdir() in SDL_filesystem.h to hide this potential detail
alongside the SDL_GetBasePath() abstraction. | 
|  | - flash masked adult when hit by virus
- flash held baby and teepee when teepee pickup blocked by held
  baby  (and block teepee pickup when holding a baby) | 
|  | This just adds a basic flashing entity mechanism, but doesn't
make anything actually flash yet.
The intention is to make the adult flash briefly when hit by a
virus while masked, and to flash a held baby and teepee when
attempting to pickup the teepee while holding the baby. | 
|  | It might make sense to have a separate .wav for this, but since I
don't currently have anything to put there just use the same
wav. | 
|  | The icons grid was shifted left slightly... | 
|  | Until now keyboard movements could "cheat" by moving faster on
the diagonals.  Instead put all the movements through the same
normalizing introduced by the touch handling. | 
|  | lower likelihoods of the >1 quantities to make it a bit more
difficult | 
|  | This makes hoarding 256 rolls explode the rolls then infinitely
scroll+rotate them while showing the high score and waiting for
keypress. | 
|  | just adding an explicit cast | 
|  |  | 
|  | unimportant but arguably hygienic | 
|  | For now this just does the same thing as dying, I need
to either animate something interesting or add a .ans
to show something celebratory like the monkey sitting on
a mountain of TP. | 
|  | This shows the teeepee quantity alongside the TP sprite, with
a little fade+wiggle animation when the TP is collected. | 
|  | This shows a numeric display with an API for tracking a position
until released.  Once released the node self-animates and frees
itself from its own rendering function.  Post-release the node
stops accessing the tracking position, intended for allowing the
associated entity to become reused or discarded immediately upon
release.  For this to work smoothly the release must be accompanied
by a storing of the last position within the bonus node via the
provided pointer, which the bonus node's render function then uses
as the origin of its self-animating before destruction.
See comment at start of bonus-node.c for more information/issues.
This only adds the node without integrating into the game, a
subsequent commit will integrate into game.c.  Initial impetus
for adding this is making teepee quantities visible. | 
|  | Newer libstage enables the render_func to free its stage node via
return value.  This is useful for fire-and-forget style ephemeral
nodes that make for convenient autonomous stage nodes which
remove themselves after running their course.  Think bonus scores
and little visual effects...
Requires some mechanical changes to the existing render funcs,
but nothing functionally has really changed. | 
|  | In the interests of making it realistically possible to
completely fill the 256 spots of teepee icons as a winning
condition, there's now mega packs of rolls.
There will need to be some visible indication of qty added,
either numerically or with different graphics.  I'm leaning
towards just adding numeric quantity values like +3 or +36
over the roll which floats away when you take it. | 
|  | Windows builds were crashing after not even rendering the splash
screen properly.  Experience suggested this was probably the
cause, and testing in WINE has at least seemed confirm the fix. | 
|  | for now toilet paper is simply picked up by the adult and
accumulates as a pointless icon starting at the top left corner,
potentially filling the entire screen with enough hoarding;
obstructing the player's view of what's going on.
There's no points added for hoarding, it's completely pointless
and counterproductive. | 
|  | preparatory commit for a toilet paper hoarding game mechanic | 
|  | - make mask protection additive rather than absolute, so you can
  accumulate mask hit points
- raise the mask stage_t.layer 3->4 so it's less obscured | 
|  | simple removal of the now unused embedded assets | 
|  | This switches all existing art assets over to
runtime-loaded-and-rendered .ans assets.
gfx/*.h embedded assets will be removed in a subsequent commit | 
|  | These are derived from the original release assets where possible.
teepee.ans mask.ans are programmer art I slapped together,
adult-mask.ans and baby-hatted.ans are derived from the release
but modded quick and dirtily by myself. | 
|  | libansr is used to turn the ansi stream of bytes into an
in-memory representation of the screen's character contents.
From this in-memory representation (ansr_t) an RGBA pixel
rendering is produced in the form of a uint32_t array.  This is
then uploaded to the GPU via the existing tex.[ch] api.
The intention here is to replace all the compiled-in gfx/* RGBA
buffers with runtime-loaded-and-rendered .and files read from the
filesystem.  This enables faster iteration on the art without
involving recompilation, and smaller distribution of the builds.
Nothing functionally changes with this commit yet. It's only
introducing the functionality to the tree and adding it to the
build.
Subsequent commits will replace the various tex_new() callers in
the various -node.c listings with ansr_tex_new() equivalents.
Afterwards all of the headers in gfx/ will be removed in favor of
.ans assets.
One additional detail is there's now going to be a concept of
mask.ans files for controlling the alpha, since .ans alone
doesn't really suffice here.  Some ansi editors use methods like
space-padding from the left to place the actual content, and
there's no  obvious way to differentiate those space pads from
desired opaque background color cells vs. just transparent
locators.  So a separate mask.ans is supported where every
non-black pixel of the mask.ans will be opaque, and every black
pixel transparent, in the final tex_t output. | 
|  | adding the library to autotools | 
|  |  | 
|  | preparatory commit for using .ans files directly for sprites | 
|  | baby vs. mask: baby steals and wears mask as useless hat,
adult vs. mask: adult wears mask for 3 hits of virus protection
virus vs. masked adult: decrements mask hit points
virus vs. hatted baby: same as virus vs. unmasked baby
TODO:
- visible indication of how many remaining hits mask has
- maybe blink mask when one hit remains
- sfx for adult mask wearing and loss, baby mask stealing?
- sfx for virus vs. mask? | 
|  | gfx-adult-masked: adult wearing mask
gfx-baby-hatted: baby misusing mask as hat
gfx-mask: the mask powerup itself
This is a preparatory commit that doesn't actually change
anything functionally, just to avoid having giant .h files in
the powerup-adding commit. | 
|  | This must have been introduced accidentally when rearranging the
function.  Fortunately tex_node_new_mem() isn't really used by
anything except hungrycat.c so it's been relatively harmless. | 
|  | also s/frozen/captivated/ for consistency with sfx | 
|  | splash screen bypasses for the impatient
escape quits splash now as well | 
|  | Existing code wouldn't notice when a TV-attracted baby collided
with an existing inanimate infection (previously infected baby)
This commit adds a nested search in tv_search for the affected
baby case, to detect such collisions.  Note this required bumping
the max nested search for the ix2 from 1 to 2, comment updated to
reflect that. | 
|  | The existing code wouldn't handle when newly infected babies
overlapped with other uninfected babies, creating potential
outcomes where a stationary virus is left visibly touching an
uninfected baby.
This commit puts new infections on a list to be processed like
viruses after performing the per-virus search creating the new
infections.  Now when a newly infected baby is touching other
babies, those other babies become immediately infected as well. | 
|  | It's possible for babies to overlap and a virus to encounter them
simultaneously.  The existing code halted the search on the first
hit.  This commit changes things to continue the search and
infect all hits before resetting the infecting virus. | 
|  | Now nearby babies migrate towards the TV | 
|  | This name already doesn't quite reflect what's happening since
the addition of the TV.
There will be more non-viruses stuff added to this function only
making the existing name even more wrong.  Renaming for better
accuracy along with the associated timer's symbolic constants.
No functional changes... | 
|  | When a touch is active, the player progresses towards the touch
position.
The scaling of the touch coordinates is a bit oversized so you
can place the adult off-screen to rescue babies, without your
finger actually going off-screen. | 
|  | bpc = boxed projection coordinates, this basically comes from eon just
like the pillar/letter boxing code for fullscreen stuff did.
Previously I didn't need this part of that code, but the touch
coordinates are in ndc and those need to get transformed by the
projection transform's inverse. | 
|  | I feel like I've re-fixed this a dozen times now in various
projects because I haven't been submoduling m4f*.h | 
|  | Having these distinct is vestigial, they're no longer different
so merge them.  No functional difference. | 
|  | The bulk of this is mechanical wiring up of a projection_x to all
the nodes.
But this also introduces maintenance of the projection_x, with
aspect-ratio preservation in two of the modes: WINDOWED and
FULLSCREEN, with the previously default stretched-to-fill
fullscreen mode now relegated to a third FILLSCREEN winmode.
The default at startup is now an aspect ratio-preserving windowed
mode.
Simply press the 'f' key at any time to cycle through them.
This was mostly done in sars to provide a source-available test
for reproducing a fullscreen SDL2 bug I filed @
https://github.com/libsdl-org/SDL/issues/5139
Otherwise it's pretty silly to bother with doing anything on
sars...  but it is a handy little mule for such things. | 
|  | There was mention of an intention to add these in the README, but
never followed up.  Previously one had to find the pouet entry
and follow the download link to find assets for a self-made build. | 
|  | Newer libstage cleans up the parent/adopt conf naming a bit, fixup
relevant call sites to reflect that. | 
|  | Cosmetic change getting rid of a FIXME from the code | 
|  |  | 
|  | Even with the MSAA off there were occasional fringes showing up,
turns out it's because of the default GL texture wrap mode. |