Skip to main content

Indie game storeFree gamesFun gamesHorror games
Game developmentAssetsComics
SalesBundles
Jobs
TagsGame Engines

punniche

13
Posts
A member registered Jun 07, 2023 · View creator page →

Creator of

Recent community posts

Either your hardware or your driver doesn't support Vulkan, if it's the latter, try updating your graphics drivers, this is out of my control, sorry! It would be nice to have a better error message though.

The floatiness of the jump is intentional. By the way, I appreciate you giving feedback but I don't really plan on adding anything new to the game, only bug fixes, it was meant to be a prototype to ship quickly as a demo for the engine, I'm working on something else now, sorry! Thanks for playing!

I plan to add fire effects (and change how fire works mechanically, so things take a while to burn and blacken and shrink as they do) and smoke, as well as a particle system in general to show which ways the wind is blowing.

Exciting! This could become a very cool fluidsim sandbox at the very least!

Thanks for playing!

afterimages keeping a silhouette of part of the level up after the lights go out

That is indeed pretty cool!

the moving platforms are a little wonky

Yeah, I noticed things get weird when a platform pushes down the player, it's just because I didn't really decide what should happen in that scenario (whether to kill the player or have the platform be stopped by him), so I just intentionally kept it as is, using this quirk to get through the last level is actually intentional design.

Oddly relaxing, nice demo. I found myself drawing things with it. Would be cool to have some visual feedback to show that things are burning.

Works as expected!

Very cool game, I love the pile of brass that builds up as you play through the level!

  • It was fun to notice myself getting gradually more adept at the controls (there are quite a few) and having more fluid and natural flow/gameplay. I think it'd be very fun to watch a glitchless speedrun of the game.
  •  The amount of platforming mixed in with the actual shooting enemies part is excessive for my taste, I felt like it just kills the "trance" I would be in while killing enemies, it's like I would go from pure unadulterated fun to "oh right, I'm playing a video game and I have to finish this level", but maybe that's just because I'm bad at the platforming aspect. The GEDG level was much nicer in this regard.
  • I wasn't initially sure if the swarm of flies was a visual effect or enemies you're supposed to kill.
  • A more visual indicator of when the flying bugs are attacking the player would be nice.
  • I gave up on killing the void lord (I got pretty close though!) because I had to restart the level every time I died, I just didn't want to do the platforming parts again after having already done them a couple of times, maybe that's just because I'm bad at the game and that you're not really expected to die in that level.
  • The chainsaw could use some animation to show it's active, but I assume that's still work-in-progress.

UPDATE:

I shipped a new build that now does MEM_COMMIT incrementally, this should not make any difference with regards to the actual memory usage, but it should be helpful if your system's page file is small or non-existent. If anyone is curious enough to look at the difference, they can use https://learn.microsoft.com/en-us/sysinternals/downloads/vmmap, the working set (i.e the amount of physical memory that's actually used) should still be the same (it shows ~32MB on my machine), while as the amount of committed memory should be much lower.

I also doubled the player acceleration speed and made the hitbox thinner (also, the game now always sets its working directory to the directory where the executable is located, regardless of where you launch it from).

(5 edits)

Thanks for playing!

The darkness gimmick in general sucks

Yeah, I understand how it can be irritating, but I tried to make it the least irritating I could while still having it be there (making everything predictable, having it not be a side-scroller so everything stays in the same place despite movement).

slow acceleration

Really? The acceleration duration is about half a second from idle to max speed, which I find to be reasonably responsive, maybe that's still too much for some players.

floatiness

The floatiness is intentional, I like having a lot of air control when jumping, but yeah, I can see how it feels odd if you're used to a certain kind of platformer.

hitboxes

I felt the same about them while making the game, they are "correct" in the sense that the pixels are actually touching each other, but it doesn't really feel fair. Maybe I'll tweak the player hitbox so that it's a bit thinner.

1.6GB declared RAM usage

In case someone is curious about this:

Most of that should not be resident and should never use up physical memory, in reality, the game uses about 40-50MB for everything, which is not great, but not terrible either, it's just not something I've spent time optimizing. A lot of virtual memory is reserved upfront for linear arena allocators, basically I just reserve a big buffer of virtual (non-resident) memory and I keep allocating stuff with it without freeing anything until I reset the whole thing, the small fraction of the reserved memory that I'm actually using is paged-in by the OS through page faults and becomes resident memory that actually uses system resources, I have two main arenas, one that gets reset every frame and another that gets reset every level. Currently, the frame arena alone reserves exactly 1GB.

This could be problematic on Windows  if your page file size is too small, since, as opposed to Linux, it doesn't overcommit memory, so if the program reserves 1GB, it has to guarantee at all costs that  1GB will be available and usable somewhere , which in practice means that it takes up space in the system's temporary on-disk page file, if your system for some reason doesn't have a page file, or the page file is too small or too full, it'll have no choice but to make the entirety of the reserved buffer resident in memory.

If you would like more information on this, see https://web.archive.org/web/20180402190240/http://ourmachinery.com/post/virtual-memory-tricks#obscenely-big-array.

There actually is way to emulate memory overcommitting on Windows by manually handing page faults (see https://learn.microsoft.com/en-us/windows/win32/memory/reserving-and-committing-memory) so that reserved memory only takes up virtual address space (of which you have terabytes on a modern x64 system) instead of also having to be reserved in the page file. Alternatively I could just incrementally do MEM_COMMITs as necessary behind a check in my Alloc function, or just lower the upper bound when reserving virtual memory, which I might end up doing.

it works fine now

I can provide more information on the issue in case someone reading this is curious or is also writing a Vulkan engine:

This turned out to be a pretty tame "bug": basically, the program was trying to call a null function pointer returned from vkGetDeviceProcAddr for a specific recently-added Vulkan function because it was not supported, I wasn't checking that the function pointer that was returned was valid because I just assumed the target hardware supported Vulkan 1.3 without even checking for that either, to fix this, I now check the return value of every call of vkGetDeviceProcAddr, and I make sure that the GPU that's used supports my target Vulkan version, this still wouldn't have been enough to allow the game to run in this specific case because the root issue is that the hardware or driver in this case does not support Vulkan 1.3, which I guess means that Vulkan 1.3 support is not as common as I thought, so I just spent some time lowering the minimum Vulkan version to 1.1 by using less recent features, which should be much more widely supported.

Should be fixed in new release, I'd appreciate if you can confirm!

(1 edit)

Damn. Serves me right for not writing any crash dump code I guess.
I've uploaded a new version that dumps a stacktrace in log.txt when it crashes, if you could send me one (ideally the log file in its entirety) that'd be great.

That seems like a good solution, I'll implement it next time I ship a build.

By "nosy" I meant that the program would be looking through stuff it's not supposed to look through, but the solution you suggested avoids that.

Thanks for the nice words!

1.  I'm open to the shipping linux builds (all of my code is platform agnostic, it shouldnt take much to compile it to linux), but the main issue is that I don't want to ship untested linux builds, i'll definitely ship them if I get a proper linux testing setup going.

2. The problem with that is that it requires walking up the directory tree in a way that personally seems nosy and undesirable to me, I don't like it when programs that I run do things I dont expect them to do.