Terrario, a Terraria rewrite for the calculator
Posté le 10/07/2020 16:05
2021 Casio Awards winner, thanks everyone!
Hi. I noticed a while ago there weren't any games like Terraria or Minecraft available for Casio calculators. For the past while I've been working on rewriting Terraria in C for the SH4 calculators using gint. I'm not sure when if ever I'll finish it, since it is a fairly big project, so I've decided to put it here for now.
Here are a few screenshots of the progress so far (some may be out-of-date):
Main menu
Gameplay
Inventory
Crafting
Equipment
A visualisation of a generated world (click for full detail)
The game runs at 30FPS. Worlds are 1000x250 tiles large (640x250 on the 35+E II / GIII).
The control scheme and a crafting guide can be found in the game's About menu.
This forum page is updated regularly with the latest release of the game, as well as a changelog in the comments.
If you aren't sure what an item does, feel free to search it up on the
official Terraria wiki.
Most recent update:
Jungle and a bunch of content.
Up next:
Who knows?
The attached file contains the latest build of the game, as well as instructions and a screenshot compiling script and map tool.
The source code repository as well as early builds of the game can be found at
this GitHub repo and
its Gitea mirror. Obviously, expect bugs in these early builds, though I take care to remove the major ones I find before releasing.
Due to the very large world, the save files for this game are big. Make sure you have at least 450kB of storage space before installing the addin (300kB on Graph 35+E II), and try to keep at least 300kB free afterwards. Tampering with the files in the TERRARIO folder will corrupt the save, so don't do that. The game will warn you if you have low storage space available, so that you can optimise your storage.
NOTE: You must have a Graph 35+ E, Graph 35+E II, fx9860GII, or fx9750GIII model calculator to run this game.
Fichier joint
Citer : Posté le 06/06/2021 09:39 | #
Right, I guess I was using an older gcc that allowed it or something
Citer : Posté le 06/06/2021 09:53 | #
Good. I also forgot the OpenLibm problem that you mentioned:
Ok so OpenLibm has this issue where it installs itself in an openlibm/ subfolder but includes itself as if it were installed directly in an included folder. So it requires some -I option, which is documented on the repository.
For CMake-based add-ins I have made gint add the proper paths, which is transparent for everyone. But make doesn't have mechanisms where I can deploy code to your project through an fxSDK update, so you have to include it yourself. Here are the paths you need:
LDFLAGS += -lopenlibm
This is also something I failed to mention in the changelogs because I forgot about Makefile-based add-ins.
Citer : Posté le 07/06/2021 17:47 | #
Since there was a (probably heap-related) problem yesterday I tried to see if I could find anything suspicious in the Terrario code.
I briefly mentioned the chest deletion code on the shoutbox where the replacement index seems to be invalid because of the extra division, even though this doesn't look like it would cause heap problems.
The realloc calls look good to me. Note that in general when reducing the size of the array realloc will not move the data and simply reclaim the extra space (unless the new size is 0 obviously).
I checked the whole NPC and marker logic more times than I care to admit (which is at least five), but couldn't find a visible bug; references in both directions seem consistant, no code seems to re-use a pointer after a call that can reallocate it, and everything seems to be initialized properly.
I suggest maybe try and reproduce the problem to find a common denominator ?
Ajouté le 08/06/2021 à 13:37 :
Picking up from your answers in chat...
<KBD2> Though if it doesn't happen it will reliably occur the next time
<KBD2> Made a little menu to easily display a bunch of ints, all the pointers have expected values
<KBD2> I'm only using 11.5k of the heap, actually less than I thought
<KBD2> Crash is still happening in the same place, the compiled arena_gint.c
<KBD2> Something weird's happening - if I don't free anything, the pointers are in the exact same place next run and the crash still happens
<KBD2> Does gint free the heap on exit anyway?
<KBD2> (This is when it doesn't crash on exit)
<KBD2> Oh, just got a juicy bit of info for you
<KBD2> The crash happens when exiting after using the About menu
<KBD2> So nothing is allocated on the heap and the crash happens
<KBD2> It's a lot less consistent but still happens in the same place
<KBD2> https://github.com/KBD2/terrario/blob/14e163828e7ed6c910876ad06a9944719fffed47/src/menu.c#L404 Something in here will cause that same crash occasionally
<KBD2> It's unlikely, but both the game loop and that menu call dfont
<KBD2> Pretty much the only thing I can see that both those do but the main menu doesn't
<KBD2> Confirmed that it only happens after the About menu is used
Not only is that juicy, it's perfect! I've narrowed down the cause of the crash to displaying this confetti image and reproduced the problem in a trivial add-in that just shows it.
I further found a problem with the image rendering code. Basically, the image renderer accounted for the image going past the edge of VRAM on the side left but not on the right side. The confetti image overlapped past the right side (because it is padded to width 64), which caused writes past the end of each line since the renderer was not careful enough. This extra write affects the leftmost part of the next line (which is invisible on the VRAM due to to what values are being written), or, in the case of the last line, some other variable stored after.
When using the gray engine, some of the VRAMs are allocated in the heap, so the "other variable stored after" is as you know part of the data structure maintained by the heap; and I think you know where this is heading.
Here is the commit fixing the problem. It is quite funny to see how many buffer overflows the new heap (which has not had a bug yet) has already revealed.
I have rebuilt Terrario with the fix and could not reproduce the problem anymore. Due to the fix I have released a new gint version 2.5.2, which also includes moving all the standard functions provided by gint to fxlibc. Starting now, <gint/std/*.h> users are officially useless, and you can include standard headers directly instead.
Thank you for your patience with this issue, and finding the precise About menu problem.
Citer : Posté le 08/06/2021 15:43 | # | Fichier joint
Update:
- Added house markers and NPCs
- Make a valid house with a chair, workbench, and torches that's at least 60 tiles large.
- Press TAN inside it to place a marker; NPCs looking to move in will automatically claim it during the day.
- The Guide has no requirements to move in, and the Nurse will move in once you have increased your maximum health.
- Made movement a bit smoother over terrain changes
- And loads of bugfixes.
Aeron_Emory Invité
Citer : Posté le 10/08/2021 23:37 | #
I wish I knew how to install
Citer : Posté le 10/08/2021 23:40 | #
Just drop the .g1a file in the storage memory! Plug in the USB cable, in the popup on the calculator press F1, and the calculator will show up as a USB device on the PC. Copy the .g1a file there, disconnect, and then Terrario will be in the calculator's main menu.
More details in the file transfer tutorial; it's in French but a good translator will clear it up for you (if you have no preferred one I'd suggest DeepL).
Ajouté le 20/08/2021 à 22:06 :
I've having a very hard time playing Terrario today. Most of the worlds I create are unplayable because I die of fall damage upon spawning. The save feature also doesn't seem to work properly, leaving me with either an "Optimization was stopped" message or a crash, both resulting in empty void worlds when coming back (I have 1.5 MB space left, so no problem there). I was eventually successful at recording a couple of minutes of video footage (which was my goal and the reason I was building from source), then I pressed OPTN on accident and froze the program. Are you aware of any of these potential issues?
Citer : Posté le 21/08/2021 01:36 | #
Yes, I was trying to wrangle a bunch of issues SegfaultDev introduced saving the player's position, though I thought I had fixed it - I'll see what I can do
Ajouté le 21/08/2021 à 01:51 :
I can reproduce the new world spawn bug, though optimisation and screenshots seem to work fine - are you using a GII model or GIII model?
Citer : Posté le 21/08/2021 02:09 | #
GII I believe
Citer : Posté le 21/08/2021 02:09 | #
I believe I've fixed the spawn issue by changing what the game looks for when setting the spawn, though there are some underlying worldgen issues that may have caused it (mainly setting tiles at the very top of the world) that haven't been carried over to the map gen tool and so went unnoticed.
Citer : Posté le 21/08/2021 09:05 | #
Thank you for the quick response. I was using a G-III model yesterday specifically, though I have both. I'm also at fault here for building from source, and most problems are probably development leftovers; I was mostly worried about the save, since it's a crucial part of the game.
Edit: Ah so OPTN is the screenshot key, makes sense. Then it likely froze because I had been capturing live video until that point, with the USB module initialized early on.
Citer : Posté le 17/11/2021 14:57 | #
you can have multiple shades of black on the graph 35 E?
Citer : Posté le 17/11/2021 14:58 | #
Yes it's an illusion based on flicking the screen fairly fast (it starts working at 64 Hz, although it's very sensitive). Several implementations of this exist, the one used in Terrario is natively integrated in gint. I know Redcmd has implemented an engine outside of gint for his own purposes.
Citer : Posté le 17/11/2021 15:05 | #
Yes it's an illusion based on flicking the screen fairly fast (it starts working at 64 Hz, although it's very sensitive). Several implementations of this exist, the one used in Terrario is natively integrated in gint. I know Redcmd has implemented an engine outside of gint for his own purposes.
oh so it's similar to how we can display multiple digits on a seven segments display?
wow thats really cool
Citer : Posté le 17/11/2021 15:11 | #
It's even simpler than that: it just flicks from black to white faster than the eye can see it, so what you perceive is an average (over time) of how often each pixel is black. So dark gray alternates but stays black for longer periods, and light gray also alternates but stays white for longer periods.
The delays tend to be different for each model and you can see the flicker even with the best settings, but if you play for more than a few minutes you stop seeing it eventually and it's really nice
Citer : Posté le 19/11/2021 16:24 | # | Fichier joint
Update with a bunch of content, mainly contributed by segfaultdev!
- Added the jungle
- Player's position is saved upon world exit
- Clay, mud, and glass
- Copper, tin, and tin tools
- Tin and cactus armour
- Diamond, emerald, ruby, sapphire, topaz
- Cobwebs and chains
- Sawmills, looms, silk, and beds
- A chat system (currently only used for beds)
- Coins
- Mushrooms and healing/mana potions
- Pots
- Eyes of Cthulhu
- Splash messages on title screen
- Numerous small changes and bugfixes.
I haven't really tested this as much as I would other updates due to the large amount of new content, so if you find a bug while playing be sure to notify me here or preferably as an issue on the Github repo.
Citer : Posté le 11/01/2022 18:59 | #
Wow nice game
I have two issues though :/
In the latest update (0.10.0) the game crashes when I walk for about 10 seconds and I get an error :
TLB miss read
PC: 0031ca24
TEA: 0033b046
TRA: 00000000
SGR: 8804fe64
The add-in crashed.
Please reset the calc
I checked several times and I always get the same error message.
Also if I save and close the game, when I try to open the world, I spawn in a void.
(The 0.9.0-indev version worked fine)
Am I doing something wrong ?
Citer : Posté le 11/01/2022 19:02 | #
The spawning in the void thing seems like a known problem where you spawn high up in the sky (and usually die of fall damage). It might be fixed in latest builds?
Ngk6D Invité
Citer : Posté le 10/02/2022 03:43 | #
Theres a bug in the game: When you stand at a opened door then you close it, it teleports into the top of the door or a roof of the house if you place the door in front of the house.
Citer : Posté le 03/10/2022 20:46 | #
This older version seems to work on the fx-9750GIII (able to move without crashing and can load a game after saving it). Whether there are other problems in this version, I don't know: https://github.com/KBD2/terrario/files/5243852/Terrario_30kB.zip
The file is from this GitHub post: https://github.com/KBD2/terrario/issues/1#issuecomment-694688403
tt_thoma Invité
Citer : Posté le 31/05/2023 22:23 | #
The graph 35+E II has a memory of 60KB. That means it will crash when a buffer exceeds 60KB. Reducing the buffer size works for this reason
tt_thoma Invité
Citer : Posté le 01/06/2023 08:45 | #
Nevermind