Over the past few weeks, I’ve found myself switching away from Microsoft Word and Google Docs for taking notes, and moving to the humble text file. I now take notes in Microsoft Notepad/Wordpad and my notes take up half the size and use half the ram to view, and contain the same amount of information. Personally I think Notepad is the perfect text editor for well… editing text. It does its job, little extra, and it does it very well. Wordpad is for when you need things like embedded images, or anything plain text cant handle, so a rich text file is used. Wordpad is more like diet word, but still manages to be lighter weight. Personally I think both editors are great in their own regards, but notepad is literally perfect for its job. Now what about other operating systems… MacOS has TextEdit which is more akin to Wordpad, so I have a hard time counting it as a replacement for Notepad, and Linux has a bunch. The common problem between both MacOS and Linux text editors however is they all seem to do way too much. Now ever since the software minimalism crowd has invaded the text editor space, text editors have slowly become less about editing text, and more for editing code. In my text editor for taking notes, I don’t need syntax highlighting and line numbers, especially if those come at the cost of performance, and I sure as hell don’t need whatever emacs is doing. In my travels for the notepad of Unix however, I have stumbled upon my old friend, nano. Nano is almost perfect in my eyes. It is small, starts up instant, and does its job. There is little extra. While it does support syntax highlighting and line numbers, these do not seem to impact it negatively, and come disabled. Another runner up would be vi (not vim). Anyway, if any of you have a suggestion to add to my search, feel free to drop it below. Please nothing more complicated than Notepad however, I don’t want to be taking notes in vscode.
Micro: I want dedicated phones to make a comeback (and you should too)
Recently I bought a Western Electric model 2500MMG from an antique store here in Boston. I had always wanted one for decoration since they are THE phone that people think of when they think of a phone, they are iconic. However other than that, I was not looking to use it. To my amazement, I found they are fully able to be hooked up to a POTS (plain old telephone system) line and work fine in the modern age. Problem is, nobody has a landline anymore, and paying for one is too damn expensive, my apartment doesn’t even have phone lines run to it. However, the fact that this literally indestructible behemoth from 1970 can still work on modern phone lines (granted you have one), but my iPhone 4, literally less than half the age of that other phone, cannot connect to cellular anymore because “3G is too outdated” is absolutely astounding to me. I understand getting rid of old technology when its cost starts outweighing the benefits of keeping it around, but that seems a little excessive, a phone bought around 10 years ago is now completely useless, meanwhile a phone from 50 years ago works fine. Dedicated phones (or a phone protocol) need to make a comeback, just so we can standardize on a system to make calls that isn’t ever evolving. Realistically if I want good sound I would use the internet. I propose bringing back something like 2G which reaches far and wide, and having it be just for calls and SMS, meanwhile data would be carried over 4G, 5G, LTE, or what not. Doing this would allow for older phones to stay connected as… well… phones, while making people have to upgrade if they want the new speedy data stuff. But hey, that’s just my opinion.
My review of every song from Animusic 1
I was going to originally review both Animusic 1 and Animusic 2, but I am way too busy (not to mention separated from my animusic discs, and I refuse to watch the YouTube rips), so I will have to post what I have so far. A complete review and ranking of every song in Animusic 1, a whole month in the making, then delayed for about a month because of moving, then I got lazy… So here it is. Expect Animusic 2 reviews and rankings to come probably around winter, and maybe a full review and ranking comprising both discs around that time as well.
In case you aren’t familiar with Animusic, Animusic is a digital album created by Wayne Lytle and David Crognale. It was designed to be the first of its kind, a full album where every “music video” was computer animated. Animusic 1 came out in 2001 to much critical acclaim. It was heralded for its use of computer visuals and distinct MIDI style of song. Animusic 2 would follow in 2005, completing Animusic for now, as Animusic 3 has yet to be released. If you haven’t I would recommend looking into the commentary tracks for Animusic 1 and 2, as they provide the most information about the creation and reception of Animusic, and they are a great way to spend an afternoon. So without further ado, here’s a review of every song from Animusic 1.
Track 1: Future Retro
Future retro is the first song on the first disk of Animusic, so its the first experience you get to animusic granted you haven’t seen any of the viral clips making it around the internet at the time of its release, and man does it deliver in giving you a taste of what’s to come.
Future retro makes heavy use of what I will call the “synth laser” from here on out. The entire song is done in this 80s rock style, with the synth laser being the most prominent instrument, as well as the most visually spectacular. However, there is also a crazy 3 neck guitar/bass in the center of the scene, which surprisingly is mostly used for accompaniment to the laser. Along side this, there is a drum robot in the back, showing off even more of what’s to come. The song itself uses many of these instruments to create a very interesting vibe. One of the most notable things, I especially noticed it when I was a kid, was the use of the flute segment to break up the more heavy rock segments. This always struck me as an interesting choice, and a cool one at that. Along side the synth laser, green lasers and these choir synth lasers are used, which give that futuristic vibe the title implies. Overall, this song is a really solid start, and a perfect introduction to animusic. Its a song with a style that is familiar, being an 80s style rock song, and features some very interesting imagery. Overall, its biggest shortcoming isn’t anything it does specifically, but what the songs later in the album do. Solid start to a solid album.
Track 2: Stick figures
Best song in the album. Done.
Anyway, this song sums up pretty much everything I love about animusic, and even back when I was a kid, this was my favorite song in Animusic 1 by far. I even remember in school art class making a model of the bells + flute + gong instrument.
The instruments used in Stick Figures shows the full creativity of animusic at work. With the lead fretless bass, apparently called “Mr Stick” (best character by the way) to the large stack of brass horns, to even the massive array of drums, to even a few synth lasers (what would an animusic song be without them).
Just like Future Retro, most of the lead is taken by the synth lasers, however every single instrument is pretty much given time in the spotlight. One interesting thing, halfway through the song, the tone shifts to this slower darker tone, however none of the instruments change, they are just used differently, which allows some instruments which don’t fit the main mood of the song to have some much needed spotlight time. And man, the instruments really carry this song. From the opening with Mr. Stick just setting the mood, to the brass picking up, and eventually the laser taking over and really setting the song into full motion. And as the song goes on, you start to notice other instruments getting gradually added, all of which start to form a more full picture. And by the end, it comes to a satisfying close, with pretty much every instrument being active and harmonizing together into the melody of the song. Overall, I still stand by that this is one of the best, if not the absolute best song of animusic 1.
Track 3: Aqua Harp
Before i begin the review, lets talk about the transition from track 2 to track 3. Usually in an album, artists will try to fade one song into another, for example starting a drum beat which is picked up in the next song. This translates slightly harder to something like animusic since we have to establish which instruments are being played, and starting them already playing robs you of the experience of admiring the creative designs. However since animusic is a visual medium, the songs don’t necessarily have to transition, but the visuals can, and in this situation, the camera pans up to the stars in Stick Figures, which gradually turns into the star painted ceiling in Aqua Harp. A small touch, but I really like it. Anyway, on to the review.
Aqua Harp was always my least favorite song on the animusic 1 disk, but that’s not saying its a bad song. The way I would describe it is “atmospheric”. The scenery of Aqua Harp is very relaxing, with a large harp taking center stage, and also being the only instrument played, with all instruments other than the harp being connected to it. The harp itself is placed in the middle of a pool of water. Through out the song, a water sound can be heard in the background, which really helps with the atmosphere, as Aqua Harp is a really quiet song.
As for the song itself, the song is really slow and relaxing. I disliked it as a kid simply because it wasn’t as fast paced as the rest of the songs on the album, and the visuals weren’t as interesting. However, I can now appreciate the departure from the other styles of the songs. Aqua Harp uses a mix of string instruments, like the harp and cello, along side the flue and chimes. The use of these specific instruments creates a very interesting mood, coupled with the water and visuals, its very relaxing. Personally, while I do still think the song is not my favorite, I can appreciate it a lot more, and I do genuinely enjoy it a lot more too. Just sadly overshadowed by the others in this collection.
Track 4: Drum Machine
Next up we have one of the more interesting style songs. Drum Machine takes places in some machine which uses many different sizes of gears, and uses those gears to play different drums. One nice touch is in the background, the chugging of gears can be heard, and they keep perfect time with the song playing.
Over all, the drums are very cool, and it is very cool seeing all the gears moving. Lighting is also heavily used, mostly when symbols crash, but also when the rack of larger drums is moved down. This all contributes to one of the coolest scenes in animusic.
The song itself makes heavy use of percussion, in fact it only uses percussion. The song can be split up into about 3 sections, when new instruments are introduced, which happens 3 times over the song, the rhythm played on the drums changes to allow the new instruments to shine. Overall its a pretty cool sound. I’m personally not that into drum line songs, so I think most of the other songs overshadow the actual song that Drum Machine plays, however the scenery of it is worth the watch alone.
Track 5: Pipe Dream
Now if you saw any animusic clip, its probably this one. This song went viral on the internet due to its unique scene, and man, is it unique. Its probably my favorite scene of them all. Pipe Dream takes place in some factory, with a bunch of pipes shooting metal balls into instruments to create a sound. The creativity in this is crazy. You can see the level of detail in the pipes snaking around the floor, to the position of the instruments, to even which instruments where chosen. The thing that made this song so magical at the time was the idea that “this _could_ exist.” Hell, I even knew some people who thought it *did* exist. Hell it really *DOES* exist. Thanks Intel.
Anyway, the scene aside, this song is really solid. The opening to this song, with the gradual buildup of the banjo like instrument is awesome, just to have it pass the torch to a smaller, higher pitched banjo, just to then pass the torch to the drums, which might I add are some of the coolest drums in animusic. As well the bells this time being in the form of the bell flower, with chimes that descend from the ceiling. Also as the song goes on, marimba pieces scroll across a track above the drums, which basically take over the melody of the song. All of this creates a very unique song, one that I don’t think could exist on something that wasn’t animated. I still have to say most of the fun of this song comes from watching the balls hit the instruments and eventually find their way back home. And not even to mention, the song itself is really good to boot. Overall one of the most iconic songs of animusic and for good reason.
Track 6: Acoustic Curves
As a kid, is disliked Acoustic Curves a lot. I think it was completely due to the opening riffs, which are kind of annoying to me even today. But after listening to it again I just can’t stop. The main chorus of the song is incredibly catchy, despite not having any lyrics.
The overall scene for this one is very simple compared to the rest of the songs on animusic so far. This one seems to just take place in some wooden void, with wood paneling stretching from the dark depths to whatever the light is coming from. Weirdly enough, as a kid this one always reminded me of my Dad’s office, since all of the furniture in his office had that same wood panel look, and even the same color. Weird how some memories just stick with you like that. Other than the lackluster scene though, the instruments are really well designed, and really cool. The gimmick of this song is that almost all instruments are acoustic as the name implies, and they are played by small hammers that rest near the string being played. This is really creative, and grounded in reality. I really like it personally.
As for the song itself, it has a really cool style of being layered, with new instruments gradually descending from the heavens, ultimately forming the complete song towards the end, before gracefully deconstructing. This style is always something I’ve loved, so I’m not really sure why I didn’t like this as a kid. The instruments played are also really cool. I’m not a really big fan of the first two “guitar” like things, but once the bass and drums get into the mix, the song really takes off. I really like (as a bass player) their inclusion of a slap and pop. This lets the bass play more of a slap bass style, which sounds incredibly good. Its also cool to see things modeled like a sustain damper which gets turned on when the song really starts to take off. Overall Acoustic Curves is really solid, I really like it. Now if it could only get out of my damn head.
Track 7: Harmonic Voltage
I remember always disliking Harmonic Voltage as a kid as well because it meant that the movie was over… However I really like it now. In fact, just like Acousitc Curves, its now completely stuck in my head. For some reason these old melodies just come back to me and don’t leave.
As a kid I was obsessed with technology infrastructure for some reason, and I really liked the design of Harmonic Voltage, looking like it was power lines and radio towers, with this cool laser stuff shooting off of it. The center of the stage has a power pylon which is the source of the guitar sounds, with the synth guitar being purple, and the guitar solo guitar being more of a green. Under the pylon is a set of drums along with a synth bass. Overall its pretty cool to look at. Surrounding the pylon is a set of radio antennas and pylons that look like they supply or catch the voltage of the center pylon. There are also these cool little antennas with blue lights that make a cool dropping tone.
As for the song itself, It has a very cool sound. It has a more hybrid rock sound, sort of like an 80s rock song, but mixed with more of an early 2000s electric synth music sound. I particularly love the electric sound that is portrayed with the lasers. I also always liked the green rings that make that cool dropping sound as a kid. The guitar solo being played on the central pole was also a really cool touch.
Anyway, fade to credits. And that’s animusic 1. What an absolutely solid end to an absolutely solid album.
Animusic 1 rankings
- Stick Figures
- Pipe Dream
- Future Retro
- Acoustic Curves
- Harmonic Voltage
- Drum Machine
- Aqua Harp
To be honest, Animusic 1 is completely solid. There is not a single song that falls flat, and as well, there is not a single song that feels like it wasn’t take to the absolute maximum with creative potential. Such a solid album.
Micro: web design is getting out of hand…
I have to use a website called “Cognella” for a textbook at my university. It gives you one of those standard cookie prompts. Which allows you to enable or disable cookies, pretty standard right..? Well when you click “disable”, it logs you out immediately, and when you log back in you just get the same message to enable or disable cookies. So disabling cookies is the equivalent of hitting “I’m not 18” on a porn site. I’ve heard of them just being placebo, but never just outright refusing to serve you unless you consent to their tracking… great trend we are starting up guys. Guess they’re technically GDPR compliant. Turns out never mind, they’re fucking not!
Working on a new text editor…
So, as I’ve been teasing (for like 2 years at this point…) I am working on a text editor. Originally it was going to be based in the terminal, and using the Aquila virtual machine, then using Blæst, finally using Crow and not in the terminal. So here are some things I learned.
Keep it simple stupid
First of all, make everything easy on yourself if possible. It’s not always a good idea to reinvent the wheel. Case in point is the text editor interface itself. For so long, I was hung up on how the interface should work. Usually I figure this stuff out and start work, but for the obvious reason of “hey a gui library is pretty freakin huge” I really wasn’t able to get any work done on the project. Especially too since the more I stalled it, the more ideas I got. So eventually it turned from “let’s have it in the terminal” to “let’s have a library to create guis that seamlessly convert from the terminal to literally any ui toolkit and seamlessly integrate into the system they are running on. Needless to say, eventually it just became “what if the text editor was actually an operating system”, and magically that’s where I stopped. So for one, know your limits and keep within them. Now the editor is being written in Qt 6, mostly just because Qt in my experience has the best cross platform ability, and it is really easy to theme from within an application itself. But maybe Qt wasn’t the best option…
Do NOT use Qt
So this might or might not come as a surprise, but I really hate Qt. Always have and always will. The main reason I dislike Qt just mostly has to do with it’s weird licensing problems. Like “is Qt really free software”? If questions like that have to be asked, you probably shouldn’t be using the software in free software projects. Pretty big coming from a guy who uses Mac OS now, but hey, software freedom is something I still really care about, and I want my text editor to be enjoyed and used by all, so picking a UI that was FOSS was an important thing for me. So what do I mean exactly for “is Qt really free”, well for one, now you have to download their (probably proprietary) Qt installer, which requires that you make a Qt account. If you want to have an offline installer, or god forbid just download the headers and libraries, you need to pay for enterprise to do so. So you have two options: embrace freedom by proprietary software, or empty your wallet. If you can, build Qt yourself, or get builds from your distribution or operating system, I just needed mainline Qt so I could make sure it works with what most people will probably try building with… Big mistake.
Make sure things you say are “embeddable” are actually embeddable
Is it a coincidence that a whole boat load of changes came to crow the minute I picked the text editor job back up? Crow got a whole lot of things, including CMake support (hmmm… doesn’t Qt use CMake…) and in general just refining the structure of how things are stored and accessed to allow for crow to be built much easier into a shared or static library for use in other platforms. Eventually when I start making AIs and robots in crow (when I finally make the move away from the dreaded JavaScript abomination), you’ll probably see a multitude of fixes and changes in those as well. Funny how that works.
Just don’t make a text editor in 2022
Now this one may seem anticlimactic, but just don’t do it. Text editors are a dime a dozen now, and chances are you can pick up and maintain one that is exactly what you’d like and maybe more with less time commitment than doing it from scratch. Now I say this with compilers, that there is a great deal to learn from making a text editor, but to be honest, you can create far more useful applications, such as a rich text viewer or chat client, and use the same skills a text editor would use, and maybe even expand on them. Personally I have hated writing a text editor, but I’m doing it for completion at this point. I’ve said I’m going to do this for years now, and I’m damn well going to do it.
Switching to Apple
So, for pretty much all my life I’ve used Windows computers, and ever since 2016 pretty much used Linux full time. I used Linux as far back as 2011, with Ubuntu 11.10 being my first distro, however 2016 was when I truly hit my Linux stride. Since then, the standard UNIX-y way of doing things has become permanently ingrained in how I work. Before switching to Linux, I used Visual Studio and Code::Blocks, and after I primarily used the command line. I also switched to using debuggers like gdb which I found much easier to script and run batch tests, and also switched to using programs like git for version control, which was always really clunky to use on Windows. Basically, using Linux taught me that Windows is a terrible development environment for basically anyone, and especially if you intend on making cross platform applications.
Fast forward to now. I’ve been using Linux in some capacity for over a decade at this point, and I still really like it. Coming from Ubuntu 11.10, we were still using Sys-V Init back then, can you believe that. And if Wi-Fi worked out of the box, you had basically just won the lottery jackpot. I still very much like Linux, and like the direction Linux is going. But with all of that being said, I decided that the time was right to try out Apple and their MacOS. Soon, I am moving to a new apartment, and one problem with that is I will be forced to severely downsize what I own. One unfortunate reality is I can’t bring my massive computer setup with me, it is just simply too large. I really needed to get a laptop, and while I was looking at buying a thinkpad (like I already own and use for school), I decided to spend the extra $1000 and buy an M1 pro Macbook Pro 14 inch.
My first impressions of the computer were very good. The screen particularly blew me away. Usually I tend to be the kind of person who spouts things like “Screen doesn’t matter” and “If I want a high resolution screen I’d buy a TV”, however, I work a lot with CJK Language, or Chinese, Japanese, and Korean. CJK languages use very fine symbols, which when rendered at lower font resolutions makes them pretty much unreadable, or at the very least heavily pixelated. Thanks to Apple somehow cramming something like a 2k display into a 14 inch laptop, CJK fonts are incredibly clear, and I can already feel myself never being able to go back to even just a 1080p screen for CJK. Along side the screen, everything felt really snappy. Animations lasted just long enough to be known, but not too long to feel sluggish. Everything seemed to run pretty fast. Overall the thing I was most surprised by was the lack of screen tearing and other Linux-y things I come to expect with the UNIX-y base. I unfortunately had to switch from GNOME/Wayland back to MATE/X.org recently as Debian broke the sid GNOME packages. Wayland was really nice, but ever since the breakage, I have been struggling to get MATE to run without screen tearing without making the entire desktop lag horribly (thanks picom). Overall though, from a visual perspective, MacOS blew me away.
Another unexpected win from MacOS was customization. I had pretty much always been told (by people who don’t themselves own Macs or use MacOS) that Apple locks everything down, so you experience the operating system the way they intended. And while this is true of things like the overall application theme, or the general feel of the desktop and OS, this is not the case for the applications included. I was very angry that Finder kept opening the “Recents” menu when I would open it. To open the Home folder, I would have to navigate to the menu and physically click “Go > Home Folder”, which was a massive pain, especially when I would then have to navigate into further folders from my Home folder. I thought this was going to be the moment I became one of those cynical Apple users where I convince myself that my purchase was justified and “I just have to live with these few extra steps”. Didn’t help as well that I could not for the life of me find any way to set Finder to default to the Home folder anywhere on DuckDuckGo, so I thought I was completely out of luck. However after just deciding to check the preferences page, I found not only could I set Finder to open to the Home folder, but I could add the Home folder to the side bar, and even add the hard drive shortcut to the desktop like in OSX of old. To be honest, I had been trained by general consensus that Apple preferences do basically nothing, but to my surprise, I found everything I had wanted. Considering you cant even set this on GNOME (at least without touching dconf), that’s incredible. Along with this as well, I was pleasantly surprised to find I could exclude the terminal from all the security checks that MacOS does to applications running. Normally this would be totally advised against, since it completely undermines security, but for the terminal, I am mostly only running applications I built from source, and thusly audited, so doing this stopped the annoying “Do you trust this application” popups which I also saw non Mac users complaining about.
So, if you have had no experience with Apple, I would say go out to the nearest Apple store and give it a try. Or you can emulate it on Linux using OSX-KVM if you don’t want to go out or buy anything. I was very surprised with how good Mac OS was in my experience, as well as Apple hardware. Does it justify the price? That’s up to everyone to decide. However I am very happy with my purchase at least at this time. I will make sure to update if anything changes with my opinion on it. Also just a side not, Apple gives some pretty great discounts for students, and they can’t really even prove that you are a student, so if you look young you can probably pull one off.
Anyway, I also bought an iPhone SE 2020 recently as well, but that’s an entirely different story for another day. I’ll probably write another blog post about it (once I’m done with my super massive blog project I’ve been working on for a week at this point). So stay tuned for that.
Back to MATE
So… Debian pushed out a broken update to GNOME, so now I’m back to using MATE. And likewise, I’m back to using xorg. Being honest, I haven’t had such a bad time switching back, I may end up staying with MATE for a little while now. I have always like GNOME 2, so MATE isn’t a desktop I hate, but I do like the looks of the newer GNOME as well, particularly with libadwaita. So… welcome to Linux I guess, but hey, MATE isn’t a terrible fate to be suck with. To think I could be stuck using i3 for a while… horrifying…
80% of the problems, caused by 20% of the bugs
If you’ve been around the internet for a long enough time, you’ve probably heard of the 80-20 principle, or Pareto Principle. For some reason, it seems like everything is linked to the proportion 80 to 20. For example, 80% of the world’s wealth is held by 20% of the population, or in my case, 80% of the problems were caused by 20% of the bugs, even if not obviously caused by them. While I was skeptical about the claim before starting on my most recent project, now I am a full on believer.
Recently, I’ve been writing my own dialect of Lisp. I mostly am doing this as an exercise in creating high(er) level languages for embedded systems, cutting a lot of the fat that current high level languages like Python have. And I chose Lisp because Lisp is cool. While all of this is a blog post for another day, what to take away from this was that I decided to write this for every system ever made, meaning I had to choose a very common programming language to base on (especially more important since Lisp is interpreted, not compiled), so I chose ANSI 89 C.
When I started writing my Lisp interpreter, I was doing so very fast. In C, you are the memory management, meaning if you don’t do everything correctly, your program could start executing undefined code, or return undefined values. While starting, the most bugs I had were uninitialized values for variables. For example, in the following code, we have no idea what the value of x
would be. It could be 0, it might not be. Its really up to the compiler to decide if it should be initialized, and up to where on the stack it is allocated to say if it already has a value.
int x;
printf("x is %d\n", x);
Now, these values are easy enough to find, simply make sure to pass the warning flag -Wuninitialized
to the GNU C Compiler (or Clang as well), and boom, every uninitialized variable hopefully should be highlighted. This worked for me, so it was overall an easy fix. However as I continued on with the project, I ran into stranger errors dealing with memory management which seemed by all odds to be coming from a billion different directions.
Now, I have been programming in C/C++ for a little under 10 years at this point, having started sometime around 2014, so I know my way around. But I also have a tendency to be very lazy when programming, especially for proof of concept things, which usually leads to a “I’ll finish this up later, its not like this is production code or anything” type of mentality when working. Usually what this means in practice is neglecting memory management, since “you can just allocate a buffer of like 1KB and it should never overflow… right?”
Working on my Lisp interpreter, I first ran into problems of programs that were too large having variables overwritten randomly. In the interpreter, variables just hold a direct value, usually a pointer to memory, or an integer or decimal value. If it is a pointer to memory, it adds it to another list, holding all active memory allocations. This list of allocations allows the garbage collector to determine whether or not memory is in use, and frees it if it no longer is. This is a pretty nice system, if only C had it. I was quickly having problems of allocations being overwritten with seemingly garbage data, which caused memory that was still in use to be freed, which would cause undefined activity when it was called upon in the future. This is particularly a big problem on Microsoft Windows, which has a very strict memory model, which allows for zero out of bounds memory reads. Basically, on Windows, if you free it, its gone forever. Now, this would usually cause a crash on Windows, but not on Linux, so for a while, I just assumed the Windows version was completely broken because “Windows”.
Next problem with memory management was the freeing of garbage data. For example, if the variable list overflowed into the allocation list, then garbage data could be written to the memory stored as an allocation, which when no longer needed, could cause the system to try to free memory that it has no right to free. And likewise if the allocation list overflowed, it would spill into the openFiles list, which contained references to open files being read by the interpreter. Again, a file could be closed that would result in undefined behavior, especially if the file descriptor wasn’t open. This happened while porting the interpreter to classic Mac OS version 6. And again, I chalked it up to “man Apple really sucks”.
These bugs really took a toll on me, especially because I was watching them in debuggers, and just magically seeing values overwrite other values, for seemingly no reason. It was especially strange too, since when the program would eventually crash for what it did, the crash point would be usually a strange location, somewhere very far from where the problem was taking place. And by this point, the memory management aspect of the program had long since left my current focus, as I just assumed “Its worked this far, it should keep working”. So I wasn’t even really considering that bad memory management could cause all of these errors, which led to multiple long nights of adding unneeded sanity checks, and attempted error correction. Remember kids, fix a problem, don’t try to patch around it.
Eventually I was running out of options to try to fix things, it seemed like at this point, every internal function had some crashing bug. So I decided to run the program through valgrind, a memory debugger among other things, and man, I should have done that much earlier. To my absolute horror, I was making overflow write after overflow write. I wish the GNU Debugger had been more up front with me about that. Once I fixed all the overflow writes by keeping track of buffer size, and reallocating when needed, magically all of the bugs went away. And so too could all the shoddy patchwork. Overall just fixing about 3 buffer overflows made the program about 1000% more stable.
Now, I’m not going to act like my Lisp interpreter is anywhere close to being done (although stay tuned if you’re curious, I’ll probably make a few more posts here about it in its lead up to version 1.0), but it sure as hell is a lot more stable. So in closing, somehow, I guess the 80-20 principle is true. If you are having a problem with your program, or a program you are using, look for the most obvious sources of error, because in all likelihood the obscure bugs you have to work for to get to take effect probably aren’t the ones that are causing your program to crash, its probably the ones like I’m facing, even if it doesn’t seem like it.