Back in 2011, my girlfriend was working at a catering company that announced shifts via a webpage and workers had to sign up for them. Other workers tended to pick them up very quickly, so it was hard to get too many shifts.
I wrote a quick web scraper to automatically accept any shift offered and email her.
For a couple weeks it was great, suddenly she had all the work she needed.
Then one day she woke up late to find a voicemail telling her she was fired.
Earlier that morning the script had detected a last minute job announced just an hour before start time and immediately accepted it, resulting in her not showing up to it. I had not accounted for the possibility they would announce a job so last minute, since it had never happened before.
My most used tool I have is a note taking web app that automatically saves markdown files to S3. The most important feature I added was a little button that would automatically make a note for the current day, and put it in the daily notes folder, all sorted and organized. I also have full text search which is very helpful for finding old notes.
I also use an RSS reader I made. Instead of just showing you the text of the page like a standard RSS reader, it proxies the web page so you can read the article directly from the website, but with the added benefit that since it's a proxy, I can control all the HTML, CSS, and Javascript on that page.
Another daily one I use is a random background music playlist for Spotify that is auto generated daily. Using the Spotify API you can find random music, then find random instrumental music from that random music. I use this to discover new songs to listen to while working.
Basically, making your own software is fun. Making production software is much less fun. I don't need to worry about a million things when I make my own software. Sure, I make $0, but if I spent months making, for example, my notes app production ready, and tried marketing it, I'm guessing I'd still be sitting at $0.
- TalkToYoutuber[1]: Download the transcripts from a youtube channel and hook it up to gtp4 with RAG to let me "talk" to youtubers. There's a bunch of youtubers who have useful knowledge to share, but no blog or wiki, so semantic searching their video transcripts is the next best thing.
- YoutubeThumbnailSearch[2] - Embded all of a youtube channels thumbnails using CLIP and search them using text. I often need to search through news channels with 10k+ videos, often in foreign languages, so not having to rely on the title or transcript but the video thumbnail helps. This is a much more niche usecase tbf.
I am thinking of making a scaled down version of [1] so I can "talk" to long videos, like conference speeches or university lectures. Should take an hour or two to cook it up since it will reuse most of the code from [1].
---
[1] https://github.com/FardinAhsan146/TalkToYoutuber
[2] https://github.com/FardinAhsan146/YoutubeThumbnailSearch
It's not that it is meant for my use only (any capable reverse-engineer familiar with Ghidra should be able to pick it up and use it) nor that it will never see the light of the day (it's open-source). However, it is such an esoteric capability and outright heresy according to computer sciences that I'm having a hard time just finding people who can wrap their heads around the concept, let alone people who would actually want to use this. Simply put, it's so far out there that I don't even know where or how I could even advertise it in the first place, which makes it de facto for my own use only.
A couple of people did end up reaching out to me in the last couple of weeks about it, so it might be on the cusp of sprouting a very tiny user base. Still, I've made it for my own use and until very recently I've never expected anybody else would use it.
If someone wants to check out the dark magic: https://github.com/boricj/ghidra-delinker-extension (disclaimer: might give nightmares to linker developers).
* Vehicle Maintenance Tracker: Logs all vehicle maintenance and sends reminders based on time or mileage for upcoming tasks. This one is probably one of the most used and useful of everything I have made.
Lend/Borrow Tracker: Keeps track of items we've lent or borrowed, to/from whom, and when. We use it most for books, but it can be used for anything.
Library Book Manager: Lists all the books we checked out from local libraries, displaying their cover images and ISBNs. Using a barcode scanner, we can quickly "check in" books on return day, accompanied by an adorable "ding ding!" sound recorded by one of my kids. Really beats manually searching the paper printout. It can be used on multiple devices at the same time - the checkin status of each book is synced live between all users, so each kid can find and check in their own books.
School/Home Lunch Manager: Displays the school lunch menu alongside each of my kids’ names. We mark school/home lunch days at the start of the week for easy morning prep.
Sickness Documentation: Tracks sickness details like symptoms, medication, temperatures, and timelines, helping us coordinate how we are going to take care of the kids when they are sick.
These apps, along with a few others not listed here, run on a server in my home, accessible only within our network (in home of via a VPN).
I wrote bard, a Lisp that combines features of Dylan, Common Lisp, and pure-functional languages purely as a long-running experiment in what I could do to make programming more fun for myself. I subsequently used two versions of it in client projects (to prototype some solutions and to compile them to data used by the delivered product; nothing delivered to the clients depended on my weird Lisp dialect).
I wrote a tool called nym to help generate names for characters and other things in games and stories. It's enough fun in itself that I sometimes just play with it.
I wrote another tool called model-namegen to generate names with stricter constraints for science-fiction stories. Those names are mapped uniquely and reversibly to 64-bit integers used in the story to generate names for machine intelligences. I also wrote a prototype for a 3D multiplayer game called The Fabric set in the world of those stories, and wrote code to generate clusters of colored cubes for use as avatars representing the AIs. Each character's unique ID is mapped to a unique name and also to a unique 8x8x8 configuration of lighted cubes. An example name is Ixion Eleven Chrysotile, the name of the autonomous robot who is the narrator of my Fabric stories.
Following is a link to a very short movie of the avatar for the character Miriam Five Bittersweet Earth: https://evins.net/downloads/miriam-5-bittersweet-earth-2-2.m...
I wrote a couple of versions of a library for Common Lisp to make certain functional programming idioms I like more convenient for me in Lisp. They're called folio and folio2.
I wrote a library called taps that similarly makes use of Richard Waters' SERIES package for Common Lisp a bit more convenient for me. Actually, taps started as part of folio and I ended up wanting to use it on its own often enough that I broke it out separately.
I've written several little tools for calculating and keeping track of information that's useful for friends-and-family gameplay.
I've written several other libraries and applications purely for the purpose of exploring some idea or other that interests me. For example, beasties was a pond-life simulation that I used as a playground for recreational genetic programming. Panels was an experiment in user interface that used a constraint solver for laying out windows and widgets, and an append-only log of all UI events together with a query engine and a knowledgebase. Panels could display graphic representations of recent user activity and retroactively define mappings from sequences of events to user-defined handlers. It operated on the principle that everything detectable that a user did potentially had some purpose, even if we don't know what it is, so we should remember all the user's actions and offer them the opportunity to define what they meant.
I've also written a few little things primarily for the purpose of helping friends and family with this or that task.
I've spent a lot of time over the years on things like these. As you would expect, they've taken varying amounts of time and I don't really keep track of how much. I use some of them (e.g. taps and other pieces of folio) almost every day, and others intermittently. A few of them (such as beasties and panels) I haven't really touched in years now.
- One-click anonymous upload of text, clipboard, and files. So from any computer, I can visit xyz.com + ctrl+v to upload the clipboard, write notes to myself, drag and drop a file, etc. It's a risky feature, but there's nothing to attract attention and you don't even get a URL back.
- Authenticated sessions see a list of uploaded files, with buttons to copy link, download, delete, or generate QR code. There's also real-time notifications for each upload.
- Simplified RSS feed reader[1]. It scans my feeds every 10 minutes, and displays the URLs of new items. It has one button, that opens all URLs in new tabs and marks them as read.
- A Server-sent-events channel[2], and a UI that displays visitors in real time. The channel allows me to send redirects/file downloads to any visitor, so I'm constantly asking people to visit xyz.com when I need to hand them something digitally. Visitors are color coded with randomized backgrounds for identification.
- Youtube video downloader (powered by yt-dlp), along with audio extractor and pitch+speed correction for songs.
- Authentication is by approval from an already authenticated session (usually my phone). In the worst case I can edit the text file via SSH.
I add or remove widgets according to my needs. At one point I had chat integration with Facebook+WhatsApp+Telegram (got me banned from WhatsApp), radio player (replaced with Spotify), and even balances by scraping my bank accounts, credit cards, and Steam (removed after a bank started asking questions).
The whole thing runs in custom pair of Go and Python servers, developed slowly over the last ten years, and I use it multiple times a day. Feels like a digital tree house, messy but fun and useful.
[1]: https://github.com/boppreh/feeder
[2]: https://github.com/boppreh/server-sent-events
Edit: people have found it and started spamming uploads of "HELLO FROM HN". One IP looks Swedish. Well, Hi! But I'm taking it down for a few days to avoid tempting more people.
And shoutout to the Go team, that server has been rock solid and 100% backwards compatible over the past ten years.
To avoid this, I made an extremely simple video platform. I save all my videos there instead. It's still my hobby project that I use the most.
The code is at https://github.com/AlbinoDrought/creamy-videos
There's an optional youtube-dl importer UI at https://github.com/AlbinoDrought/creamy-videos-importer (separated for easier updates)
The importer repo also contains a Firefox extension so any target can be right-clicked -> Import to Creamy Videos -> Select a set of tags -> sent to the importer UI, youtube-dl, and then eventually video storage: https://github.com/AlbinoDrought/creamy-videos-importer/tree...
I’ve been developing this app for five years. During this time, I’ve integrated it with all my bank accounts to automatically fetch data needed for creating daily graphs and analyzing trends. This allows the app to generate predictions for long-term net worth growth.
Additionally, I’ve integrated the app with Yahoo Finance, Fidelity, and Morgan Stanley to monitor my Restricted Stock Units (RSUs) and Employee Stock Purchase Plan (ESPP). This functionality helps manage tax responsibilities on capital gains and compare growth with other job offers that include RSUs from different companies. For instance, I can answer questions like, “What if I had chosen to work at Facebook instead of Apple?”
The app also extensively utilizes data from credit card transactions. It includes charts listing new restaurants visited in the last month, tables tracking monthly subscriptions, algorithms to detect discrepancies, and numerous other features.
While I’ve considered turning this into a business, my current job keeps me very busy.
It handles lights, fans, cameras, sensors, locks, doorbells, speakers and TVs, HVAC and more. It runs automations based on time, weather, presence of people, and other events. It tracks energy consumption, sends alerts, etc. There’s a strong focus on local control (as opposed to cloud).
My favorite thing about it is that the client and server run from the same codebase and share state over a WebSocket connection. I’m still working on it occasionally but mainly it just runs quietly and my people seem to like it. The whole thing is configurable (connectivity, behavior and interface) so theoretically it could be used by someone else, but for many reasons I doubt it ever will :)
So I build a little cli to generate my invoices. 100 loc and super simple.
I miss the 70s when programming was the default way to solve problems. Excessive abstractions and proprietary software often slow us down.
Use it almost every day. It’s nice to keep up with channels I care about while escaping the algorithm.
Something I work on-and-off on. Could be interested in open-sourcing it fully if folks are interested in helping out. Im a pretty junior engineer, so work is slow and I’ve never been satisfied enough with the code to publish yet.
Sometimes I go through the old screenshots and get nostalgic as the oldest are 10 years already.
I spend so much time of my life on my computer, so why not take photos of it?
It uses an on-device model for language detection and results are sub 0.3s thanks to groq
If someone wants to try: https://testflight.apple.com/join/GBxPMw2h
To make recalling my web browsing easier, I built a browser extension that shows my browsing related information on one page. Pressing the shortcut key Alt-L brings up a page showing my frequently visited sites, my open tabs, my bookmarks, and my history visits. Searching and navigation are super easier. Searching can combine terms with logical operators. The hardest part of the project was getting fast performance when rendering a lot of data.
I use this extension daily, and I put in some effort to polish it as a releasable software.
https://chromewebstore.google.com/detail/one-page-favorites/...
https://microsoftedge.microsoft.com/addons/detail/one-page-f...
https://addons.mozilla.org/en-US/firefox/addon/one-page-favo...
This was my part-time hobby, I guess. My full-time gig is a software engineer at a bio-tech company.
So, I wrote some basic web software (PHP/Symfony) to manage and track the whole process. It took around 3 months to write the code, though there was no set beginning and no set end. The code was started when I became overwhelmed with the manual aspect of tracking everything. The code was done when I figured I had done enough to manage and automate the process.
Talking with a few people after the fact indicated very high interest in the software I had written. And thus began the journey to convert it to multi-user.
I started on the multi-user conversion and, maybe because I tried to make it do everything and then some, have not since finished it. The code is on my private GitHub, partially converted to multi-user, slowly rotting away (needs library and core updates).
What does it do? Manage the process of cold lead acquisition, follow-up interactions and onboarding, and eventual publishing of the resulting interviews.
How did I make it? PHP/Symfony.
How much time spent making? About 3 months in my spare time.
How often do I use it now? No longer used.
TODO list program and the list is periodically printed on my desktop with conky
Software to automatically book reservations at good restaurants on Resy. Supported proxies, multi account, automatically running every day and getting reservations in a certain time range, and even something with a USB GSM modem to respond to the confirmation texts you get a day before. Used it until I got banned from Resy :\
Family photo search using CLIP (actually uform) and face labels from Synology NAS. So you can search “winter +christopher” and it will only show pictures of me and sort by the most winter related ones. You can also filter out certain names, search multiple names, click on an image to get images most like it, filter by year, or any combination thereof. Took a couple days to make with Flask, pgvector, and some code to scrape data from the Synology web interface. My family uses it sometimes too though.
It evaluates streams against a database of 100 or so "quirks" that identify either general issues or issues that will only manifest on certain player libraries. For instance, specific "in spec" encodings which are actually non-standard in practice get flagged.
Built on TypeScript/node/Docker over the course of maybe 18 months. Used it fairly often when I was working in the space, not at all these days. Originally the plan was to license it as an enterprise vid tool.
(I've been considering open-sourcing it - would YOU use it if so?)
I have also worked on trading algorithms that used publicly available info about crypto order books to make profitable trades, which will obviously not be published since then they would stop working.
I wrote it over the course of a week or so and I use it frequently.
It's not that it won't see the light of day for anyone else but it's a very specific niche so I doubt anyone would even find it on the app store
If anyone's curious: https://play.google.com/store/apps/details?id=io.thisischris...
Her parents were super strict and would not allow having a boyfriend, we were caught once so wanted to be few steps ahead of their detection.
Using internet was allowed for her to study. Made the extension such that when you search for something popular click on the largest image in knowledge graph (right side box) 4 times and then do a right click the wikipedia description will become a chat box (to avoid accidental discovery by her sister).
Backend a very simple .txt file and php to insert and maintain only last 5 conversations.
I think I made it over a few days. We used it for a total of 2 times because we couldn’t notify each other when we come online.
Switched to a simple ROT13 encoded sms-ing. With the key changing every day.
The DNS server resolves queries based on rules I've set up. Essentially, I can configure certain categories of websites to only resolve at certain time periods.
For example, I could make it so reddit, HN, etc, only resolve for a 5 minute time period (either anytime or only in the mornings) every day.
The point of the server is to track my web usage across all personal devices, and then make conscious decisions to control my internet usage based on this data. (All personal devices are on the same tailscale VPN... that's how I ensure I am always using my DNS no matter the network I am on.)
It's still a WIP, but I've probably easily sunk over 40 hours on it by now. I also wrote a custom Rust async runtime (single-threaded) for fun.
That would inform my “I’m willing to go as low as” selling price.
So I built myself an app to scrape the current tax from the government’s online calculator and assemble a dozen what-if scenarios, given the current exchange rate.
When I found one that would let me break even, cash in hand after all fees and taxes, that became my price floor.
It worked. Now I don’t need my app anymore.
The only part of that software that ever became public was the animated syntax highlighter[0], but I don't believe any other part would help anyone else accomplish anything.
One of the biggest and most useful of those tools is a Django web interface that accepts JPG/PNG/PDF file uploads of scanned documents and in case of images (JPG/PNG) it will run "tesseract" to OCR extract text from the images (in case of PDF it will pdf2txt). The extracted text is stored in an SQLite database which enables keyword search in the uploaded documents.
I use this as my (digital) archive of important documents, e.g. mortgage, bank statements, insurance, medical files, etc. I just checked and I now have 1129 documents in there ranging all the way back to 2006 .
It's super useful to be able to go back in time digitally, without having to dive into the collection of physical binders with the real documents (ordered by year and month but nothing beyond that, given that there are usually only a handful of documents per month, and I can use the web interface as an index into the physical archive, if I ever need it).
I’m pretty sure nobody else uses it, but I use it a lot for DNA design work for my company https://github.com/koeng101/dnadesign
I wrote the newsletter generator in Python. It uses all kinds of different APIs (news, social media, MailChimp, scraping, weather, even some LLM for summarizing some of the news, etc.). It runs every day at 8 AM on a little server.
It's not a super long script, but I've changed and refined it over the years many times. It's like I've spent many dozens of hours editing the same <1000 lines of code as I've modified, removed, and added features to the newsletter.
I built a bot that runs every 2 weeks, scrapes my local movie theater's currently playing titles, runs them against rotten tomatoes to filter out movies rated below 85%, then looks them up on youtube and posts the trailers to my discord server
How did you make it?
Python script that runs in google cloud functions, triggered on a bi-weekly schedule
How much time you spent making it?
An evening
How often do you use it?
Every two weeks
I find usescripts way more easy to update than an extension, so that's what I've been sticking with for quite a few years now.
[Edit] In the opposite direction as well: if modified in main, it reflects in the original one. AFAIR, it was the feature I missed, since Google only supports (-ed?) one-way mappings.
A blue full sized bar on the left size of the screen? The CPU is under 100% load. A purple bar on the right side of the screen, that reaches 3/4 of the way up? Guess my RAM usage is getting close to the limit, better not get too eager with the tabs, maybe close a program.
It actually wasn't that bad, but shortly after I just bought some more RAM. That was also before I had my own Gogs or Gitea instance, so I don't think I have the source anymore, it wasn't too hard to do on Windows though (nowadays I'd probably just put Linux Mint on the system or something, it needs a bit less memory in general). Oh, also now I have like 4 monitors for my main PC and don't do too much computing on the go. The 8 GB MacBook that I have for when I'm out and about feels rather slim, though.
Aside from that, there's the CMS I use for my website, though I'm not showing it to anyone because it's so bad that it makes me want to climb into a hole and disappear off the face of the planet. It still works though, so I don't necessarily see myself changing it out for something else just yet.
And I'd tell them what the final total would be when we were standing in the checkout line.
Very small and basic, but I thought it was the coolest thing in the world as an 11 year old back in 1996.
The most recent is a Chrome extension that plays a "server down" tone any time the word "critical" appears on our system monitoring web page (Netdata). It plays that tone when the number of "critical" words goes up, and plays a "server up" tone when the number goes down. It's dead simple and works to give me audio alerts so that when I'm hyper-focused on something, I can get pulled out of it by the "server down" tone. It's gone over well with my coworkers as well.
Some more:
- https://weather-sense.leftium.com: weather app with the trendcast just the way I like it. WIP, but already using it on daily basis.
- https://multi-launch.leftium.com: quick link launcher; can launch multiple links at the same time. I use this multiple times a day.
- https://tt.leftium.com: tool to streamline conversions I frequently need. When the input type is detected on paste the converted value is automatically put into the clipboard. Also paste works from anywhere on the page. A super-niche hidden feature is if I paste the outerHTML of my SoFi relay accounts list, it will transform it into a TSV format for pasting into a Google sheets balance sheet. I use it a few times a month.
- https://ff.leftium.com: tool to calculate the time I needed to do something in a game I used to play. Automatically updated a calendar event with notifications.
- https://orbs.leftium.com: another tool to help with planning in the game I used to play.
My hours get billed, I've got my notes for the cycle, and payments to my LLC get automatically routed to the right financial targets based on stuff I integrated with mercury.com.
Doesn't do the taxes, but cuts a lot of the low value/high cut vendors out of my revenue cycle and that makes me happy.
I made bookmarklets to sort multiple retail stores, including my local grocery store website and Amazon by price and price per unit. Amazon price sort is nearly worthless, I assume intentionally. Drives me crazy to grocery shop without price per unit, my bookmarklet also converts units.
I made a browser extension that filters out youtube videos, reddit posts, youtube comments, twitter posts, twitter sidebars, and probably a couple other things based on an extremely long list of keywords of crap i don't want to see - largely political, violent, war related stuff. I think it filters out more than half of posts on /r/all, partially because there's also a long list of popular subreddit blocks on it too.
I made a custom interface for Habitica, a habit-tracking app, to mimic a game from the 90s I really liked.
I made an arduino water gun robot to spray my cats and break up frequent cat fights when i'm all the way on the other side of the apartment.
More random stuff like this.
Wish i could find a job!
I originally thought more people might use it, but I have basically 6 teachers.
I have a couple notable stories about that:
I had a friend that wanted to scan his album cover, and I'd always wanted a scanner, so I bought one and wrote some command-line software to do it. Then I applied that as an extension to the venerable Xv image software. Wrote it entirely for myself, ended up selling something like a thousand copies of it.
Recently, I was tired of Spotify so I wrote a Python program to export my playlists into YouTubeMusic. Released it on Github and it now is by far my most-starred project, I figure it's helped at least a thousand people move away from Spotify, I've had a bunch of contributions to it and have had several people throw money my way.
Write for yourself, give to the world.
Someone once told me that apparently some local sports reporters' weekly tips are used with some seed money and the proceeds are given to charity and I was intrigued enough to spend a few days building something that could test that out.
- Danish Swimming Water Quality App[1]: Native app for my iPhone that I use to check the water quality. The official one wasn't working for me, too slow and too buggy. Ultimately, it's just a JSON of public data spread on the map, very simple. - Artwork Framer[2]: Script using Blender that converts .png into a framed 3D model. You can even adjust the frame if you want and then export it as a model to be used in VR (works even in Apple Vision)
[1] https://github.com/bartaxyz/denmark-swimming [2] https://github.com/bartaxyz/artwork-framer
MP3Renamer(2002) - The age of music piracy is still rife and i have downloaded my share from napster, university file shares, etc. However, most filenames are horrendous and not clean. So, my first utility was a java program that would analyse file names based on common garbled patterns and rename it into [Artist] - [Songname].mp3. It worked surprisingly well for 90% of the use cases,
CombatLogAnalyzer(2008) - Me and my wife are in the throes of World of Warcraft arena which is a competetive dueling system. We only play 2v2 and we both suck at it. So, i enabled combatlogs in WoW and then wrote a parser, analyser and visualizer for every arena game and that shows which spells were used, where did damage come up, highest contributer of damage and this was by each playable class. By the end, we learnt what was killing us and the statistics showed our strengths and weaknesses. Suffering high latency and poor skills we managed to crawl from 800 rating to 1800 rating! We just couldnt go beyond that! (I was the crutch). This was done in .NET WinForms and i really learnt how to use linq.
Space Commander (2019) - My daughter is almost 4 years old and i think she is ready for computer games. I decide to learn MonoGame and i make a Space Commander clone. It is a HIT!
HappyMrsChicken (2019) - From my smash hit game above, i make a clone of HappyMrsChicken except this is in a forest where you have corn that the chicken has to eat and there is competetion from a mysterious goblin creature who also goes after the corn. Who will win?? Turns out, i cheated and gave the chicken a boost. My daughter won a lot!!
OptionsTrading (2020) - It is covid and i am locked in a quarantine facility for 28 days. Like a lot of retail noobs, we are getting into trading stocks and options. I decide IBKR interface sucks and I can do better. While spending those 28 days in isolation from family, i learn react to write a frontend and python to write a backend that displays all our trades, statistics, UIs, loss calculators, PnL, etc. My wife and I use this to date but i am too chicken-shit to publish it.
My personal favourites are: CombatLogAnalyser, OptionsTrading and HappyMrsChicken in that order
I'd say it's a rite of passage to write software for yourself:
1) It gives new programmers some practice.
2) It can help you understand software development better.
3) It reinforces the concept of dogfooding what you create (even though in this case others won't get to use your software). Again, making you better developer. You'd be surprised how many people write programs that they barely use or test. Never really knowing how useful it is or isn't to others.
As a fan, I was frustrated by the lack of a comprehensive list of featured restaurants, with watching all videos being the only way to find them. So I developed this website to see all locations on a map. I was surprised by how many restaurants were featured, so many pins on the map! Now, I'm enjoying trying out and planning visits to these places.
The biggest challenge was extracting restaurant information from the videos. Each video ends with a brief 3-second slide showing the restaurant's name and partial address. My solution converts videos to images, runs OCR, extracts text, uses an LLM to generate JSON data, and adds geolocation information. I set this up as a GitHub Action that regularly scrapes new videos and updates map markers automatically, all within the free tier.
It took me a few months to figure out the video information extraction and create the website using SvelteKit and MapLibre.
A script that does a speed test of my Internet connection once an hour and plots a graph
A financial analysis webapp that barely works
I call it meware: works for me, and hopefully for someone else, too, but it's not polished.
A number of SmartThings device handlers and arduino code for home automation (early Ambilight clone, light strips, sump pump monitoring, desk fans).
A janky pendant to run on RPi for my CNC (clockworkpi.com devices are cool btw!)
Reddit bookmarks manager that google somehow scanned so technically there are a few people using it... accidentally
Custom Mailspring build with themes and minor annoyance tweaks
Not counting various TamperMonkey scripts that fix some site annoyances
I've written "radio station" music software that used text-to-speech to back and pre -sell music and include news headlines and calendar appointments (that was back when I used Windows).
For work, software to build deployment manifests for the various client instances of my research funding web app, software to update the dev MySQL databases for the same clients, software to export zips of all the current code for each client.
Some more often used ones: - A script that manages my Music files (add/rm/search) and syncs them with my phone when connected via ifuse+rsync
- a CLI to really easily deal with port forwarding because I run a lot of stuff on my raspberry pi and old laptop which goes out to the internet via WireGuard & forwarded from my VPS
I also have local forks of a few abandoned projects with a few bug fixes or minor added features. Ought to find alternatives but too lazy
My bad habit is not properly archiving these little programs, so I invariably end up recreating them from scratch each time.
For instance, I wrote a tool that tells me how many simultaneous users I need to simulate X number of real users who are hitting the server only intermittently.
If you write tools for your own use, unless they are really big you tend not to bother with coding style conventions. The important thing is being able to code it up quickly.
I used to write everything is Perl, but I’ve switched to Python. It’s a great rapid prototyping language, and basically everything I do is a prototype.
1: SourceForge launched in 1999; a lot of what I wrote predates that. Also CVS in 1999 makes git today look user-friendly; I didn't successfully get CVS to SF setup until around '02.
I don't remember how I got started initially, there was some investigation of the network protocol it used. It was some crusty old standard that used an odd command scheme, but I managed to divine what magic packets to send to wake it up and select an input.
I ended up rolling it all into my first and only Android app. It eventually became a full remote control for the thing, including a sleep timer that would turn it off after an hour.
It was extremely basic and horribly ugly. I never looked into automatic discovery of the device on the network, so it had a hardcoded IP address. But it worked well enough to get a free projector running.
Apart from that, every programmer has thrown together innumerable scripts and throwaway programs for one-off tasks. My most recent was a thing that takes in a Diablo 2 save, then sets the version number and recalculates the checksum. My pirated copy is a bit old and won't accept saves made with modern editors. I don't know how many scripts I've written that walk through a file system to find or change something in the contained files.
I also have a version of Klondike solitaire written in C++ with SFML. I initially wanted to build a neural network to play solitaire, but after building the game itself, I found in my research that solitaire is actually a very difficult problem and far beyond my skills.
Idea for the format was that you can write structured data with a really minimal syntax if you have an external type schema running the parsing, and the syntax emerged from the line-and-indentation based outline note files I'd started writing for myself. It took some months of work and planning and a couple rewrites to get the core IDM library working right. The tools and site generator were simple and straightforward in comparison.
Outside of sports I have written code to download the entire Jeopardy archive to categorize most likely questions to appear to help study, and code to interact with Fitbit APIs to pull down data, code to analyze certain aspects of my full genome sequence.
I have unfinished code (and a desire to finish it) for creating algorithms to play certain board games, a tool to automatically request books and audiobooks from the library based on a Goodreads reading list (or other source of books), a tool to optimize Universal Paperclips, and several different business ideas I’d like to eventually pursue.
Creating something you find useful is a great way to get something done, and make a good tool. If you want it, chances are there are a lot of others who also want it.
My most recent was to manage dumbbell work outs.
Problem:
1) I hated changing weights in the middle of a session
2) Wanted to manage progression
Situation - I have 4 metal sets of dumbbell handles, a plastic set, some individual 3 - 5 pound pairs. A single, dial the weight dumbbell. Plates in metal range from 10 lbs to 0.25 lbs.
The SW:
1) using SQLite for DB
2) One application to calculate optimum weight settings - typical run takes 100 to 200 tries to get the best set.
3) Another application to present / track sessions. It was a BIG timer display to ensure I do not do the workout too fast (goal is 45 sec a set)
4) A tracking report.
Complexity issues: Not all dumbbell handles weigh the same - even the tightening nuts vary. Solution was to weigh everything and pair up the nuts so that each dumbbell handle with nuts matched its pair - oh I color coded the metal dumbbell handles.
First algorithm took too long - my first version would calculate ALL combinations of all weights. Then select the optimal solution - before adding the 0.25, 0.5, 0.75 and 1 pound plates would take between 15 to 30 minutes to run. This was solved with a slightly more complex algorithm. I calculated the all combinations for each dumbbell. Merged those lists into a big list, Found the perfect setting for each exercise. Check for conflicts. When a conflict occurred, found the exercise with the least delta from optimal and changed it to the next weight setting.... Check for conflict. Now it takes no more than 20 sec and reports 100 to 200 times it hit conflict before solving.
- A single-page HTML app that saved entries in localStorage in 1 browser (like 1kb of vanilla CSS and JS, barely anything)
- A static HTML website, generated from a folder of Markdown-like raw text, with a CLI build script. Hosted on a public web server.
- A simple linux CLI command that let me check, set, and mark items as complete, build with Node and saved to a JSON on disk somewhere.
And there must have been one or two more. Nothing serious, nothing that stuck long-term, but I probably spent 1-10 hours making these, and then using them daily for a year or a year and a half.
I'm very conscious about time spent automating or building what you want, versus how much real-life time savings or experience boost does it give you. I'll likely make more of these in the future when the itch reappears and hopefully get another year's enjoyment out of whatever little thing I build.
I spent a decent amount of time tweaking the UI, improving performance, adding filters, providing different file output formats, etc. Never shared it with anyone.
I did it because I wasn't happy with the official Android app, so I reverse-engineered the watch's Bluetooth Low Energy protocol (this was pretty fun actually).
Years ago, I wrote a .exe to change screen resolution, and then revert when closed. I used it when my old laptop had a composite out, and I would watch moves that I downloaded on a TV.
A few years ago I wrote a grid-scale battery simulator, scraped some publicly-available cost of electricity data, and calculated how long it would take for grid-scale batteries to break even when buying and selling power to-from the grid. Short answer: About 18 months. Long answer: Permitting a power plant takes a few years, and the permitting process only recognizes buyers or sellers. The permitting process doesn't recognize "storage" yet.
More recently, I wrote a quick-and-dirty utility to restart explorer.exe, because it has some really silly multi-monitor bugs that require restarting the process every once in awhile.
Right now, it's ASP.NET/.NET 8 on the backend and still plain jQuery on the frontend.
I display RSS feeds, US National Weather Service data, and comics in it. I also have it send some things to friends and family as emails periodically.
Hangfire works on the backend to actually fetch new data at appropriate intervals.
I occasionally have to modify something and manually push a new build because something remote changes but it feels fairly stable right now (knock on wood).
I want to redo it to use ASP.NET AssemblyParts and work towards essentially giving each little box its own DLL as a sort-of-plugin-system so that I feel more comfortable adding more types of boxes (stocks, different weather data, etc) and maybe one day can open-source it. (I'd like to so I can point prospective employers at it and say "see, i can actually write reasonable real world code.")
I found no free optical design software that would run on Mac, so I coded something up to do some paraxial ray tracing ( maybe more, I'd have to dig up the code) and (this is the good part) draw lens diagrams from the specifications.
Pretty simple, but it was fun to do. Very little available for Linux either. Physics and optics people want to have fun, too.
Much of it was just parsing the input data.
I do recall a design and/or analysis program written in Basic, but it wanted a particular basic interpreter, and I forgot if it had porting problems. Must have. I don't recall using the program.
Oddest bit was something I did on my own for Sun flex office. I would get the list of scheduled occupants and their office choice and overlay that on a map of the office suite, for a "who is where" map.
On a "real" work task, I learned how to write graphics commands in Illustrator 3 format. I may have used that on this project.
But more generally, tacking the AI header code to the file made it valid Postscript/Illustrator format.
My solution also manages SSL via Cloudflare and integrates with Stripe for simple fixed-price subscription billing models. The idea here is to be able to iterate on product ideas quickly without spending a day each time figuring out authentication and billing.
I did set up a marketing site at the time so that others could use it, but I don't have any users, and I'm happy to maintain it just for my own projects (half a dozen now).
It took me 2-3 weeks to make so on net I have probably not saved much time, but it really helps reduce the friction of launching things which I think is valuable.
The billing data is pulled from an external vendor's portal. The contact data is pulled from our internal CRM. Both sets of data are then cleaned up and merged with PowerQuery, and then VBA is used to send emails out to clients.
I probably spent in the range of 3-4 hours getting a working version going and ~20 hours optimizing during downtime at work. I genuinely find it enjoyable to work on—there is something immensely satisfying about automating rote work away.
I use this once per month (a billing cycle). It will probably never see the light of day for anyone else, at least in its current state, because I work in a low-tech, nonprofit environment and using this kind of tool would be daunting for my co-workers (for reference, mail merging is sometimes intimidating at my workplace).
The application sits on a RPi in the truck powered through the cig lighter plug. I don't know how many hours I spent on it as it was a weekend project I did when I had free time (not every weekend). I can say I got it working in about 4 months though. So however many weekends I had free from that 4 month period is about how long it took. Probably 40-60 hours though.
With this visualization I was able to determine the best way to package this on the vehicle with the minimal amount of deflection to avoid bump-steer and death-wobble.
I suppose it would be useful to other people building radius-arm/link-suspensions that incorporate a track-bar but I haven't got around to hosting it any where.
I spent the better part of a week working on it full time, but spread over months. I use it daily - it's serving the needs of multiple projects that I needed it for :)
Also over 70% of the lights / 50% of other devices in our house are smart (zigbee/wifi/ble) and are connected to home assistant (I very much recommend tradfri+xiaomi zigbee+home assistant). By now I'm sure we've spend over 200h on our "smart home/life", we love data :)
It supports Markdown plus a custom template language to convert Markdown-plus-more documents into a website, which allows me to add footnotes, sidenotes, images with specific formatting, custom markers, etc. It has specific support for parsing English and splitting sentences, so each one is in their own span in the resulting HTML. This is used for specific typographic layout.
Her rules for validating compliance were stored in a local Google Doc and her advisors are often uneducated & confused about what disclosure rules are applied to what types of marketing.
So I structured and organized the rules on a UI and then built an AI tool that let's her upload any advisor marketing materials to validate it against her ruleset.
It would be rad if I could sell it to her employer as an educational & compliance tool for their advisors, but currently this is just for my wife.
It took 3 days and I built it in Vue + OpenAI api.
and now have a pretty much workable tool:
https://github.com/WillAdams/gcodepreview
(Re)wrote it using Literate Programming techniques, probably hundreds of hours (I've been at this for years and am not a particularly good programmer) and I use it on pretty much every project I make which isn't just drawing stuff in a Bézier curve drawing program.
I spend about 30 minutes a month maintaining it on average and I recently rewrote it in Go so that I could bring it back into my /x/ monorepo.
I have iOS automations that query and post to it about once every day. Eventually it's also going to handle photo uploads so that I can yeet it a photo and get the embed code for it shoved into a buffer note on my phone.
I never released it because 1. it's perpetually 98% done and 2. I don't feel like offering technical support for it and dealing with people who don't like it or find bugs. I may just open source it, but then I get to be a maintainer which is an even more thankless job.
Previously this was a mess with multiple kml files and lots of dupes. Now it lives in MongoDB and has a clean interface using mapbox and vue. Probably spent 150+ hours on that, and do use it for all trip planning (photography and normal travels).
Its public but I never announced it anywhere. So only my wife and I use it, but it could be quite useful to others, I guess…
I also have some scripts for automating my tax reports. That saved me hours and only took a few to build.
I put a little NFC chip near my microwave, so I can tap it with my phone to open it up when I need it.
I also run into various scenarios where I need to copy some text, do something with it, and check it off a list, over and over. It’s not worth automatic each ad-hoc thing, so I made a little webpage where I can put it all my items and when I click one, it copies the next to the clip board, checks it off the todo list, and keeps track of the last item copied for reference.
Nothing huge, just little helpful things like that.
It hooks into the games public API to determine items in my price and demand range and does buy orders everyday.
Since it doesn't do any injections, it isn't a violation of the games policies or anti cheats. Been doing it for years.
The items I trade in don't stack in inventory, which makes it tedious for any normal human player. But given the buying and reselling is scripted, it doesn't impact me.
I've generated a few thousand dollars worth of gold over the years doing this.
The games marketplace also is deflationary. 15% buy and sell fees. I imagine I've burned a considerable chunk of gold keeping my operations going.
In general, I take a different approach than most folks, if at all possible I try to avoid writing any code whatsoever, after that I try to do it with glue code only, and I prefer scripting over compiled applications. It might be the ops/sysadmin in me, or it might just be because I'm lazy, but I really try to avoid just starting from scratch and building something.
I have written a lot of software, but each one is done as a full-fat production library (most are SPM modules). They are of top-shelf Quality, and fully open to all.
I'm my best (and only) customer, for most (if not all) of them.
That's actually fine, with me. Publishing them, the way that I do, ensures they are "fugheddaboudit" quality, so I don't have to be worrying about my dependencies, and I reuse them, in lots of shipping stuff.
You can find links to all of them, in a couple of the orgs I manage on GH: https://github.com/ChrisMarshallNY#here-on-github
I found downloading podcasts manually a bit of a faff. So I wrote a bash/curl/xsd script to rattle through a list of RSS feeds, download new episodes and create a playlist. It ran on my laptop at home or work and plonked the result on my MP3 player via USB.
Now, years later, the script is essentially the same. Except it runs under termux on my phone, and VLC broadcasts the playlist direct to my car or home stereo via bluetooth.
Sure: For an operating system, I wanted to concentrate on exactly one, one of Windows or Linux. For this, that, and those reasons I picked Windows. Most important tool, KEDIT. Next most important, Rexx scripting language. Software for own use, console applications. Real effort, starting a business. For this, developing a Web site. Got the code -- Visual Basic .NET, ASP.NET, ADO.NET -- running as desired. Had a disaster, recovering, and spending too much time in system management mud wrestling and unanesthetised root canal procedures but getting back to the important computing and the business.
So, have ~100 of each of Rexx scripts, Kedit macros, and TeX macros. Will be moving back to working with Visual Basic .NET.
Just wrote a Rexx program of ~1200 lines of typing to do -- sitting down for this? -- file copying. WHYYYYY????? Did some copying, should have copied 99,024 files, but actually got only 41,462. Disaster.
So, wrote a Rexx script with three sections:
First, check and be clear on what copying want to do and use the Windows XCOPY, with carefully selected options, to do the copying.
Second, use Rexx function SysFileTree to get a list of the files/directories that should have been copied and then, in a loop, one name at a time, use Rexx function SysFileExists to be sure the copying was done.
Third, one file at a time, again from SysFileTree, use the Windows program FC.EXE (file check) with option "/B" for binary, to check that all the files were actually copied correctly down to the last bit.
My software does some good checking on the work to be done and some good reporting on what was done so that, now, if something goes wrong, e.g., the case of 99,024 files where copied only 41,462, at least I will know there was a problem.
Right, tools for such things should have been rock solid 20+ years ago and shouldn't have to do that. But, only 41,462 out of 99,024 provided a "reality check" so wrote the code I did.
It works great! Over time I've added all the features that I care about (powerful playlist rules, easy methods for shuffling my music, detailed stats about my listening, tools for managing the MP3 library, etc.). I've learned a lot on the way. As I'm sure everyone here can relate to, it's quite freeing to build something that's only for you. So many concerns go out the window.
Originally, I found the up/down buttons to be mushy and unreliable to the point I got fed up. I just wanted to 3d print a new case to have nice metal buttons but I found out the desk supports a smart controller.[1] So I reverse-engineered the connection just enough to hook an ESP32 and buttons in parallel (either can control the desk) and add up/down actions to Home Assistant via ESPHome. And my buttons have RGB LEDs for notifications. 8)
[1] If I were a company, I would have bought the controller right away because their solution is certainly less janky than mine.
The software isnt novel, so I did it for myself both as a personal proof of concept of my blackjack years, and as an exercise to poke corners of my cpp knowledge base, google mock and google test knowledge base.
Its a phase 0 core tech tho for a vidya Im making that I really really hope I make time for this year.
Ill follow up if I manage to get a demo available before end of summer. After my sprint in the career hustle over the last 7 years I need to do some self care and I feel this is the outlet.
It's Arduino based and it turns out the iCal format has a lot more complexity than I'd guessed so there are still bugs/incorrectly shows some events but it mostly works for me. I work on it very intermittently over a few years and find it quite cathartic.
It's cool having my code hung on my wall. https://github.com/jonquark/InkyCal
I didn't spend a ton of time making it. It was honestly a lot of fun and I got to work out my development skills again. I really doing this kind of work too be honest.
I did use ChatGPT a bit to help rationalize some things as I was doing development.
The tool select albums on my Spotify collection and add them to my playing queue. I am using the tool daily (I put 6-7 albums in the morning and I am setup for the day with a few hours of music).
It is just some Spotify API manipulation in Typescript and it was not that long to code (except some UI editing and tweaking, I am not good with front end :D). I am trying to open the application to everyone but the Spotify process is quit long.
A news bot: https://github.com/qznc/mrktws-news (the output is public, does it count?)
A TiddlyWiki server: https://github.com/qznc/tiddlywiki-py
Such stuff usually costs me a few frantic evenings to build the first version and then minor maintenance.
At the end of the day, I gave up and just put everything in Dan. Apparently, it's more lucrative to just sell them.
I have a utility (dklocs) that'll turn git-formatted diffs into location-prefixed changed lines. It lets me do things like `git diff master | grep thatThing | vim - -c cbuffer!`. I built it for me (and probably use it multiple times a day) but threw it on github (along with another tool for intersecting a diff with code coverage that I don't think I've used since the motivating use case - where it did prove helpful).
I don't know if it quite counts as "creating software" but I've got some scripts and configuration to maintain separate context in named screen/tmux sessions, setting shell variables and aliases, adjusting the prompt, starting in some particular directory. Most useful there is segregating history by context, so ctrl-r when I'm coding doesn't step through system administration stuff.
I have a general project to decompose applications into utilities, and a pattern for dealing with the long-running bits that's been somewhat successful. I once wrapped up libpurple in a client that worked that way, and (in a separate project) it's how I get errors from `cargo watch` into vim.
https://github.com/stevenlandis/kilojoule
I’ve found it to be a pleasant multi tool for interacting with the shell when I need something a little more than bash.
It took a couple of weekends and evenings to get working but was a really fun way to learn about parsers, interpreters and Rust.
- the most "impressive" one right now, though barely realized since I've just had the idea this week, is a debug/log library that spawns child multiple processes with consoles attached (since you can allocate just one console to a process in windows) and allows for debug info stream separation and rich-ish text features like color
- i've started writing a custom "set of commands" (90% IO, tied to a specific hardware modules, no algebraic functions or anything, so not exactly a programming/scripting language) language specifically for, sort of, programming-illiterate people so that they could easily implement test algorithms without asking software devs to do it. It got nowhere bc I didn't have time to implement it
But my a high level hardware emulator I'm using to debug GUI in production-ish environment uses whatever is left of it.
- environment management software that assigns PATH and other variables. Those commonly ship with software, but I havent really seen people writing their own for general env management
- my friend couldn't get Sony Vegas to produce good chromakey results, so he cobbled together some javascript to do it
- I've built a python notebook to analyze my bike rides combining Garmin Watch (gps + HR) and OSM data (estimating speed vs power vs road conditions).
- since (last I've checked was like a year ago) cmake devs value json adherence over readability in CMakePresets, I've written some scripts that convert jsonc to json. Also, those can convert string arrays to strings and add other QoL and readability improvements
- also, since CI/CD pipeline at work uses pretty old cmake that doesn't support presets and is a ton of work to upgrade due to it being airgapped (I will not elaborate), I've written a script that converts a preset into a shell script. Not completely, just the options I use.
- i guess a lot of custom diagnostic software I've written at work, though that doesnt really count since this is what I'm actually supposed to be doing, instead of most of the above and jeneral software shenanigans
I use it for navigating the list of browser search suggestions, or for quickly moving around any program that doesn't have vim bindings.
I've found it to be especially helpful while using the https://www.desmos.com/scientific calculator.
- A mac app to generate to read text as playlists from openai tts api (my gf can't use the api)
- A automatic visual scraper that can get arbitray information from any website (e.g go to target and get the top 3 milk prices or get the licensing information from this opensource project)
- An ETL tool (called tabmaster) that can sync arbitrary json apis into postgres tables. with automatic schema inference and deduplication logic
- A really good OCR tool that enriches scanned PDFs with accurate words and not the bs that adobe ships
all really useful and used daily.
EDIT: formatting
1 is a sort of a virtual notebook where I put things I want to remember. Things like guides for setting up new services on top of that platform service. Or random 1 line commands that I don't quite use enough to remember but still need to. Page content in this app is stored in encrypted Markdown files, the metadata (ie the title, publish date, etc) is stored in a local MongoDB instance. It has a feature where you share individual pages publicly if you want, but otherwise pages are viewable only by their original creator. Server is Go, frontend is Angular 10. I don't remember how long it took to build as it started as something else and I kinda reset the development half way through. Probably a few weeks, but I also wasn't constant working on it, so probably longer.
2 is a thing I built out of frustration with my self-hosted Gitlab instance constantly OOM-ing the VM it was on and crashing. It has like a tenth or less of the functionality of Gitlab, but also uses substantially less memory and CPU and does exactly what I want so hasn't seen much if any further development. Also Go for the server and some even older version of Angular for the frontend.
A lot of them are little web apps with basic buttons calling http endpoints on gear /apps or doing basic OSC commands etc.
People usually use something like a streamdeck for this but I find being able to throw up a slider or something in there so much easier.
And many times it might even be single use for a specific event and a lot of time I'm just throwing up a single html page with no styling and a script tag so it really takes a minute or two.
CINEBENCH and the likes where easy, but I also automated games without using their integrated benchmark. I needed a scripting language to load settings, go through the game's menu and load a save game. To avoid any kind of load from the automation, it offloaded the input data to an Arduino-based USB device, that simulated the benchmark run with previously recorded input. It worked pretty well, but small latency issues could of course result in small variations of the run. And bouncing into NPCs was generally a bad idea.
Here is a video of the system in action that completely automated a custom CS:GO run with additional streaming load as it would occur when streaming PC gaming: https://youtube.com/watch?v=ZpSPyd9f4cg
I get asked once in a while if the software can be downloaded or bought, but I am not going to do it. Writing software for yourself has the neat advantage that you never need to deploy it, upload it, write a change log, answer questions or fix bugs at any given time. It is just about solving the task at hand and nothing else.
I eventually want this to be usable enough to share with others for local use, and to demo on my portfolio, but for now I'm just trying not to spend more time building the tools than I am using them (and harvesting the redirect links is already enough to solve a lot of what makes the search process miserable). In the meantime it's mostly a cluster of experiments that range from teaching myself Web scraping, to generally aiming for a leaner tech stack than my prior full-stack experiences, to specifically asking myself "how much of this can I do in pure CSS?"
While I'm not sure I want the support burden of maintaining the scraping code in public (and anyway it makes more sense imo to just enable bulk upload so you can bring your own sources), I do have a massive beast of a writeup[0] documenting a lot of what went into that, and the API code is at least presentable (see my GitHub) even if the UI is too skeletal for that as of now.
[0] https://bhmt.dev/blog/scraping (fair warning: this is 10000 words not including code samples)
↓ deploys to
https://RTEdge.net : interactive map
---
I use it daily, nowhere else lets me build full-stack apps with nothing but the web platform APIs, while preserving (front- & back-end) state between edits!
The playground just lets me code service workers (https://sw.rt.ht) which deploy with one click and run as edge workers!
For example: p will do cat (or hexdump or ...) or ls depending on file (type) or directory. Let me show you shebang which is just a memory aid:
$ show shebang
.../bin/shebang
#!/usr/bin/env sh
head -n1 "$0"
Some differences include no naming rules (a lot of my note titles have a colon) except uniqueness, custom clusters so my knowledge graph is manageable.
I’m going to add different note types (i.e. not every note is .md, but have .csv and .ical as well) that can be expanded and linked within a note.
It’s written in React, hosted on AWS (so not an Electron app… yet), and CodeMirror for the editor.
I’ve spent probably 100 hours making it so far.
Built custom (atom) extensions for the Hydra vj environment (https://hydra.ojack.xyz/) that add in midi control (based on the midi spec for web which I am still amazed exists and is at least somewhat supported https://www.w3.org/TR/webmidi/) , some lazy eval helpers and custom css styling for the programming text for more crazy feedback visuals.
A custom build script that runs a client and server architecture and their related logs all split in the same Window terminal window.
Several highly idiosyncratic single purpose visualisation / vj apps in processing and openframeworks, some doing camera feedback stuff, some wiggling points and particulars around on music or blob detection.
It holds stuff like:
- A daily journal, plus a curated photo for each day that I can put on a calendar
- Random habits I want to track, like how many cups of coffee I had, did I do my morning stretches, etc.
- Fill-ups and mileage on my car, time to next oil change
- Restaurants I've visited, plus ones I want to visit (I use the Google Places API to search for restaurants)
- Books I've read/want to read
- Movies/TV shows I've watched, and ones I want to watch (I use TMDB to pull in metadata about movies/shows). I also sync my watchlist from Letterboxd
- Strength exercises I do, plus runs + bike rides that I pull in from the Strava API
I used to use several proprietary apps to track these things (Letterboxd, Goodreads, etc), but it's great having them in one place, and with tight control over the database. It's amazing how useful it is to have a log of everything you've done to look back on. Even simple stuff like, last time I was at this restaurant was 2 years ago. What did I order and did I like it?
About 500 lines of C, including comments.
Normally running all the time, but for some reason mpd broke a couple of weeks ago and I haven't had time to figure out what's wrong.
- Split the mp4 up into pngs (better quality than jpgs) with ffmpeg.
- Process each png, filling the white caption areas with data from the nearest non-caption pixels.
- Join the pngs back to an mp4 (ffmpeg).
- Get the original audio with ffmpeg and merge it into the mp4, ffmpeg again.
The actual processing was with C# on Windows because that's home turf for me.
Lessons:
1) You need a lot of space for 200,000 decent quality .pngs
2) You need to be prepared to wait a few hours for the process to run
3) ffmpeg is blooming marvelous. https://ffmpeg.org.
I probably spent 20 hours on it, maybe more. I don't use it at all now, it was a one-off solution, but I occasionally see a video and think "I could run my app on that ... "
I'm the only one who uses it because these are tailored for my own specific use case, but if anybody from work asks I'm willing to share.
If I knew how to use Emacs, then maybe I wouldn't have needed some of these scripts.
-----
I have a huge list of movies I want to watch or have watched, and I like keeping track of those.
For the longest time I used Google Keep, but that couldn't keep track of dates when I added to the list or watched something off the list. And I liked my list to be sorted alphabetically and have it show the counts of watched and total etc.
Tonnes of apps and websites already do this. Or I could have probably built a spreadsheet file that does this. But I felt like rolling my own.
I built a simple webapp using Laravel and a little bit of Bootstrap to make the site look decent. Did it in one day during the less than a week of gap between resigning one job and joining another. Building it was therapeutic. I even bought a domain and hosted it on a DigitalOcean droplet. It's been up for over two years now.
There's nothing fancy about it. It really is just a glorified todo list. But I like the simplicity of it and I've been using it to keep track of movies to watch over the past two years.
I never had any intention of trying to promote it or anything. Initially I planned to share it with a few friends, but then I didn't. No reason.
So it's just out there in the web. In broad daylight. Anybody can sign up for it. Nobody has. Nobody knows. Hidden in plain sight. Just like me ;)
unifi-dns-scraper[0]: a simple tool that logs into my Unifi console to get all the hosts and then creates a hosts file that my local DNS servers can use.
unifi-doh-blocker[1]: as part of my efforts to better control my network, I don’t want random devices ignoring my local DNS by using DoH. This gets various lists of public DNS over HTTPS servers and updates a blocklist on my Unifi Dream Machine Pro. With a few other firewall rules this essentially forces all my DNS through local servers which then do encrypted DNS queries to a third party DNS service.
These tools make me happy and were fun to write.
[0] https://github.com/pridkett/unifi-dns-scraper [1] https://github.com/pridkett/unifi-doh-blocker
It is madness in script form which will never see the light of day, but I've never succeeded in rewriting it or making a nice Web interface for it 'cause what I've got Just Works for me. I interact with this script almost every day, making it the single most-used software I've ever written, either professionally or personally. It's great having a self-hosted streaming service. Run via Bash.
Mwuahahahaha.
I spent 3 hours developing this tool. It prevents me from checking HN too frequently throughout the day, saving me a significant amount of time.
For example:
Conversion between .env and .json configs: https://github.com/magicxor/EnvJsonConv
Web scraping different platforms and sending results to my favorite messenger: https://github.com/magicxor/ExtensibleMessageBroker
Transformation of copied text using regular expressions: https://github.com/magicxor/ClipboardTransform
It usually takes 3-10 days to implement and polish the core functionality. Some apps I use on a daily basis (e.g., bots in my favorite messenger), and some 1-2 times per month.
It basically takes a couple json files for configuration, and some markdown.
The coolest thing in my opinion was [1] pacman-backup, which is a small (hacky) nodejs script to be able to download packages on one machine and be able to use pacman on another airgapped machine with the downloaded packages.
A couple months after I took down the repository I received a letter from the US where someone was asking me whether the repo is still maintained and whether or not it still works. As it turns out, the people of Cuba use Archlinux, too, and they used my tool to use flash drives to share updates.
I still think this is the coolest little tool I ever built, and I probably have to rewrite it in a more sane language (maybe go?) at some point.
This worked great for years, but recently, YouTube stopped serving their `22` format for most videos, which coupled 720p video with the audio stream. Now, the best resolution you can get with audio and video interleaved is `18`, which contains only 360p video. So that's the best resolution obtainable this way for now, unless I add a whole layer to this to reconstruct an interleaved video from separate audio and video streams selected from the DASH manifest.
The key feature is that you can put in a Wikidata ID (https://www.wikidata.org/wiki/Q1536639) and it will auto populate the name, artist, release date, and Spotify ID. It will then grab covert art from https://coverartarchive.org/, which it resizes and mirrors to S3 (previous versions of this project used images manually uploaded to imgur, but broke when they changed their secret API).
So basically all I have to do is write the description and I've got a new entry on the site.
A ton of administrative tasks I automated with expect/tcl shells, and various instrumentation control test rigs over legacy GPIB (metrology project).
Other exploratory boring RF stuff that maybe 5 other people would care about. =3
I built a pretty simple web app that tracks a bunch of vendors and emails me when items matching my filters come in stock!
It’s been useful for finding new places for myself and my friends - we can usually get tours before the properties are posted on Zillow.
Though definitely against a few privacy policies
https://github.com/drewbuschhorn/a_strange_mood_podcast_tran...
vs
https://astrangemoodpodcast.com/2023/01/17/episode-1-is-dwar...
https://scottlouvau.github.io/pwa/wordle-analyze/
I wrote the code over a few months, along with code to find optimal guesses, simulate games, and do earlier versions of game analysis.
It's written in Rust, originally as a console app, but now wrapped up with a very basic interface. I figured out how to get it running as a WebAssembly Progressive Web App so that I can use it on my iPad without connectivity and without having to submit to the App Store.
- My blog mailing list (Sendy) was having a bot signup problem. I wanted to deploy a captcha, but the mailing list software didn't support it. So, I put a simple proxy that validates the captcha before inserting the record to the software.
- Wanted a way to apply an email template to the Sendy mailing list, so I wrote a software that consumes my RSS feed, applies a template, and creates a draft in my mailing list software.
- Wrote a "Scoreboard" that aggregates MRR across Stripe accounts into a graph, and sends auto-emails to friends when I cross thresholds.
- Wrote a script that emails me when the HN "whoishiring" job goes live every month. (Simple crons like Zapier don't work)
There are a few other things in there, too.
We have coffee venues from different parts of the world but they become red ("picked") only if I and my friends travel there. The main use case for the app is still me being somewhere--mostly in my hometown these days--opening up my phone and looking for a good cup of coffee. Other people can take or leave that proposition.
I wrote a bookmarklet that flattens the comments on a substack comment page and orders them by date. It makes it easier to see the most recent comments. https://bookmarkify.it/64936
I'm a member of a private social media site whose UI I dislike, so I tapped into their phoenix websocket connection and I created my own web client. It's vanilla js/html/css using template literals as html templates. It kind of reminds me of those old template systems I used in the php 4 days. Anyway, the killer features for me are regex filters on content and seeing all of the replies from the people I follow.
The regular chatgpt interface is nice but sometimes don't want to break out of the terminal.
I forked it back in 2005 because the maintainer wasn't interested in the direction my patches were going. My version has diverged dramatically from the current version.
I have no idea how many hours I've put into it over 19 years. It has needed surprisingly little care and feeding (which I'd attribute to it being a simple PHP app).
I've used it nearly daily in the last 19 years.
Edit: I also maintain a set of scripts to import my SMS from phone backups into my IMAP mailbox. Having a single place to search for my written communication is wonderful.
I open sourced it 8 years ago but it was not the original intention. I wrote it for myself. https://github.com/akalenuk/16counters
I wrote it in MASM32. It's therefore a tiny .exe file of about 7 KB. I spent maybe a few hours initially, but I've been adding features one-by-one for several years. I use it a few times a month.
- Python-based pipe-objects-not-strings shell with cluster and database support deeply integrated. Twenty years later, it has turned into Marcel (https://marceltheshell.org), and I’m still the only one using it AFAIK.
- Backup utility for Linux, with characteristics of Time Machine. Been using it for five years, it keeps daily, monthly, yearly full backups, relying on hard links for files that don’t change. Handles both local and remote (to my Raspberry Pi).
https://github.com/sirodoht/frank
I use it all the time in combination with pass:
$ frank $(pass hetzner.com | sed -n '4p') | c
Basically I enter the transactions and it shows a dashboard of my contribution rooms, how much is left, how much I have already contributed, etc.
Nothing fancy, but it just just a Remix frontend with MantineUI backed by an SQLite db inside Dropbox. Took me about 6 hours, and I only made it after I botched some changes I made into the Google Sheet that broke a bunch of formulas.
I thought about making it into a public app, but it is so tuned to what I want that it is probably not really that valuable to others.
I use it every time I save. Used to be weekly but lately monthly.
Right now I'm building a flutter/kotlin meditation timer for myself.
My most recent were tools to improve the AWS commandline experience for s3 and Athena
https://github.com/heuermh/cooper
https://github.com/heuermh/sea-eagle
Both are available via Homebrew
https://github.com/heuermh/homebrew-parquet-tools
I would next like to improve the TUI experience for tabular data, e.g. using the Charm_ Bubbles/Gum table component, but I have yet to investigate how the JVM <--> Go interaction might work.
- SignalsTalk[1] to study quantitative trading signals and algorithms, for my own curiosity.
- YCVerify[2] for verifying YC companies and founders. No one else is using it yet.
- Content Credentials API[3], to find the signatures of AI generated content.
I'm also working on:
- A search engine for online ads.
- A way to track grocery item prices from receipts using LLMs.
[1]: https://www.signalstalk.com/
I released the Rust library that downloads and reassembles media segments from a DASH stream (https://github.com/emarsden/dash-mpd-rs). Won't release the web scraping bits because they are against website terms and conditions, and because annoying countermeasures will be implemented if too many people use them.
As a product studio, we spend hours brainstorming and creating user flows, feature ideas, and edge cases. I prototyped a solution on a weekend and now we use it daily, saving time.
We released it publicly after a few months. We work on it every Friday, finding it enjoyable.
P.S. Got a startup, app, or website idea? Just describe it in plain language. Uiino's AI will generate your story maps in under 10 seconds. It's FREE! (No account required!)
Over the decades it evolve to a generic proxy that takes IP network traffic (UDP, ICMP, TCP and TLS) traffic, slices it into messages and forwards to AWS services (bidirectionally for Lambda and Step Functions, unidirectional for S3, DDB, SQS, SNS, Firehose, etc.). I use it liberally to avoid running “servers”.
When I was around 15 I wanted to try out Win Forms. I also used to play a lot of Dota 2 so I created this app to calculate how many Techies mines would to take down a hero with X HP. Complete with sliders, input field, radio buttons and checkboxes to select ability levels and items. Pretty sure it will never get published, but the .exe is still sitting on my desktop.
Turns out that JBL thought it's a good idea to completely cut sound when there's nothing playing and ramp it back up in a perceptible fraction of second so that you miss some part of whatever you're listening to. This is especially annoying when watching anything with people talking.
Here's the code for anyone interested, it also contains a more thorough rant in the README.md. https://github.com/silvanocerza/orpheus
(1) A script to solve a resource-allocation problem in Grim Dawn (ARPG).
(2) A tiny bit of code added to Garmin's developer kit, to pick apart their .fit files and show me some running metrics that were hard to get at otherwise.
I do have one other thing I've been wanting to do recently, which might even be worth putting out there if/when I finish it. Then again, maybe not. Having been a maintainer for a project with hundreds of contributors before, I can say that coding for oneself feels very liberating. Only as much infrastructure and process as necessary to get the job done. No need to deal with feature requests or bug reports. No commit races, or battles in code-review comments. You know the requirements perfectly (or have a perfectly compliant customer who is willing to change) so if you want to take a short cut you can. I was often a stickler for doing things "the right way" when I was working, but part of the reason I left is that my work seemed to be all about shepherding the process and not the joy of making code grow and do new things. Having total freedom on a project, even a small one, is good balm for a jaded programmer's soul.
I've considered putting a little bit more elbow grease and turning into a packaged product but I'm not sure if there's demand for it out there.
I ended up creating my own application that lets me create advanced, multi-stage exercises. I spent time building the trimmings that I felt other applications were also lacking such as: background visuals with procedurally generated shaders, easy gestures, etc.
I think one day I'll publish it to the app stores so other people who had similar desires have something.
I always have a 'hacks' directory in my home directory of code that does something I need doing. Sometimes I use it again and again, sometimes its a one-off that answers a question.
I'm more curious though about the motivation of the question. What was the observation that got you to wonder about this?
My VoIP provider supports SMS, and exposes an API. The community-made app wasn't performant enough, so I cobbled together my own interface in a couple evenings. Then one day some dependencies shifted and it wouldn't start on the latest Node :\ Oh well.
- Note taking app that stores all data as markdown on Dropbox
- When I was getting married I created a photo upload site with a flickr backend where people could bulk upload all of the photos they took of our wedding, and as a result we got thousands of photos without needing to chase people up for memory cards etc.
- Every year I organise Secret Santa for all of my family and my wife's family through a PHP web app I wrote.
I've written some really crappy Notion API (before the official API) to act as a CMS for a headless site.
I'm at a weird point in my life that I need to work on these little hacky projects because they bring me genuine joy. It's like lego to me.
It's a series of Python scripts backed by SQLite and reverse-engineered API clients for various music services. Over the years I've switched the backends from Google Play Music/Youtube Music, to Apple Music, to Tidal.
I published it on pypi/github out of habit, but it's primarily about scratching my itch and I doubt anybody except me will really use it. There's some interest in doing this type of thing with org mode but it all centers around LISP and emacs (neither of which I like).
I assume that most things I build will only be used by me and a small group of users, and sometimes will also eventually be used by others. I generally only build tools that I use every day. For example:
- iCloud/Dropbox alternative macOS, iOS, and web app
- task management GTD macOS, iOS, and web app
- photos api for digital photo frames
- media management
Mostly built using go for backends and SwiftUI for macOS and iOS frontends.
My most used (by me) software is my social media posting tool (twitter/x). It's public but I've disabled signups (due to free tier posting limits since Elon's acquisition)
> How did you make it?
It's written in Django and hosted on DO
> How often do you use it?
Almost everyday :)
Others are used intermittently and they include image generator, screenshot tools for iOS and macOS, etc.
As I still haven't found a way to legally ship it with a ROM (partially copyrighted by Microsoft), I'll keep it to myself. If anyone happens to know someone who knows someone at Microsoft willing to help me with this, please let me know.
I threw together a Python QT app that parses the show listings, displays them, allows filtering, and has some short cuts for searching IMDB and trailers on Youtube. The best part is that the media opens in VLC instead of some custom player.
Anyway, I will never publish it because of the whole facilitating copyright infringement thing.
Created with an early version of Phoenix (and re-created with LiveView)
Here's a link to a room so you see it with multiple users: https://pokershirt.dev/r/hn
It's hard to explain what it is. Think personal knowledge manager text editor inspired by Acme. The readme and video there are very outdated, I add features faster than I update that (as the only user this is what I get). I post videos of new features on twitter though, as a reminder to myself of where I passed through
Also made a notes app for Android that just had one text view with only options to edit text and save it. Used it for years for pasting random stuff, and gave it to a twitter friend and forgot about it. Connected with that friend years later and he said he used that app as well :)
The two most used ones in the past few years:
WAP – a small utility to control my balcony-local drip irrigation system https://github.com/kitallis/WAP
hisaab – expense tracking and categorizing because my bank doesn't do apis and sends credit card reports in PDFs https://github.com/nid90/hisaab-clj
First one: cloud services are expensive and come with a lot of overhead. However I do enjoy the idea of lambda/cloud functions a lot but I didn't want to rely on cloud services for them, especially since I have a ton of hardware to self-host stuff. So I built a service which piggybacks on DIND where I could add templates for such lambdas for a few languages(just rust and python cause that's mostly what I use) where I can allocate some resources and build tiny containers. In order to avoid wasting resources, they are all off by default but through the magic of what I build(management and something like a reverse proxy + container management for DIND), I can call an endpoint, which will check if there is a container to handle the requests and proxies the request and response to and from it or it will spin up the container, do the same and shut it down after a pre-defined amount of time. You could argue that I could have achieved the same with minikube or k3s but this has proven to use a lot more resources compared to a single rust binary I can run on anything x86 with docker on it. The downsides are that I can't distribute it across multiple servers so it only runs locally. But that fits my needs perfectly. There might be some people that would be interested in it but I never got to open sourcing it so I'm the only user. I've been planning to open source it "next week" for the past 2 years or so.
Second one: I love data. Specifically unstructured, raw data and I've been collecting a ton of articles from the internet over the past 2 years or so. The ingestion involves a pipeline that automatically processes them and extracts data/makes them a lot less unstructured: events, locations, timestamps, what has happened where and all that jazz. It's a long list of ml models, data transformations, validations, 3 llm's fighting each-other and a bunch of other stuff. Kinda feels like a child to me so I don't want to open source it. I know that I could hypothetically convert it into a product and make some money off it but my past entrepreneurial experiences have been very unsuccessful, I have limited time and lack motivation. So at the moment I'm simply enjoying the data getting spit out on a grafana dashboard such as this [1].
I have soil moisture sensors for my wife’s plants (and an air quality sensor) that’s generating a constant stream of sensor readings. I wrote my own OTA updating code for that because I was frustrated at having to plug in sensors to update the code.
I have a few calculators too.
A big chunk of these are proof of concept programs, test code that is good for trying an idea but won't be complete enough for a test suite in the end result.
Others are random data fixes when you're migrating file formats or end up with a bad CSV or something.
I have a toy program that just tells me what a keystroke looks like via raw mode.
It only took about 15 minutes to throw together into a bookmarklet, so it was a really low effort, but I use it daily.
does fairly basic word search stuff, and there are lots of more sophisticated programs out there, but none of them run in a linux terminal and that's what i wanted. i have it constantly open in a tab, for various word game related things.
First commit was 8y ago. It's the only tool I've been checking consistently multiple times/day.
Originally react, recently (like 2y ago lol) I rewrote it in svelte focusing on page speed and added some minor features like changing the symbols to track in local storage.
The only thing HA does it display them via their MQTT sensor/event entities. I'm not a big fan of developing UIs.
- Created an /etc/hosts file switcher script to swap out websites that I allow myself to visit during working and non-working hours.
- My ISP provies dynamic IP addresses, so I created a IP address updater script that lets Cloudfront know my updated IP, to among other things, host a website from a personal computer.
In the end, I did put it on the App Store (after months of cleanup!) but it's easily the most used app on my phone.
A python package to code up reusable TeX expressions, which is used in the said site generator.
A python library for trip planning which let my wife make plans using Google MyMaps and Excels and then my library syncing them up and also shows some visualization in Jupyter Notebooks.
It was named out of annoyance so it doesn't have the most 'appropriate' name so I'm probably never going to release it. But it works very well.
It minimized waste, and told me exactly where to cut.
I spent a total of probably 20 hours on it and use it 5/7 days a week.
Also a bunch of Obsidian plugins, to have nicer macros and templating.
Except me and the team at my company nobody uses it.
After I made it lot of solutions came in this space, but IMO this is the easiest one to use still.
I love the results, though I have a strong hunch that there's probably a different processing approach that would be 10x faster.
Many years before that I did sports arbitrage. Wrote my own xpath system before xpath for it. Worked great.
I think it took me like an hour to make and I use it several times a week.
- made a tool to import all of my local music library to a spotify playlist by analysing the music itself. used a music tagging api to analyze a small section from the middle of the track to get its details. went through the effort because some of the music i had was very old and i did not keep up with updating their media tags.
- i finetuned musicgen on instrumentals of some of the music i like. i now have an interface that randomly generates a short track, which can sometimes create a nice banger. cannot publicly release due to licensing issues.
call me lazy and selfish, but i only bother doing things outside work if i am really interested in it and want to do it for myself.
After some time, I decided to open-source it:
But I usually find that the hassle of having to maintain it at random times whenever some platform changes happens, or else not be able to use some important feature,vis just not worth it.
[It does speak to a time where people create something they truly are passionate about but may not fit into the typical optimization of PMF, growth etc.]
Edit: As I think on it more (it's been a few years since I dusted it off), added multithreading so some commands could process over time.
It was a great learning experience.
Most of my freelance work is API development and most of it are repetitive tasks so I thought I could solve this through compiler generator.
Early this year I decided to open it up for others, still beta though
I built it in the process of teaching a cli tool. Which I extensively use to move files between computers, especially to servers.
It's quick to start, non-laggy to use and matches my thought process exactly. Has both a CLI and a GUI.
- My blog, which has lots of weird pages for stats, time jumps, old games/tools/utilities. - Flight tracker app. - Home control app (because HA was a pain to keep updated). - Wood working tool helper for my dad.
And more. It's liberating.
Among other things it uses ChatGPT to extract structured data from PDF invoices for reporting expenses.
I made also a custom spreadsheet that solves the same problem but an order of magnitude more precise. I use it weekly.
Like everyone else, I have a hacker news client, which is "universal" (in the Apple sense), and is made around how I use the site. I might even release this one, one day.
I’m most confortable with modern C++, win32, boost, and I love templates. Everything everybody loves to hate.
It allows me to launch vscode projects and devcontainers I often work on very quickly. Saves me so much time!
Many little handy scripts and tools I might even put in front of a web script to share.
None meant to see the light of day or ship.
One way to do it is just list them on a public website for yourself to use
Let seo pick them up and you’ll see if anyone wants it too.
It's a Rails app and includes a flashcard system to help me study. It also emails me a daily list of 5 vocabulary words to study.
I use it all the time and it took about a month to get it into a state where I felt comfortable deploying it. I'm about to add a feature that will use the devices camera to scan and extract a vocabulary list from the image using OCR (I'll use this when reading Japanese text).
It's useful for me, but more importantly, it's fun.
a feed reader - I was never satisfied with other feed readers so I've built my own
small utilities I use from time to time
All these apps were in active development for at least a year each and were deployed to my home server where they continue to work to this day. I fix bugs and add new features when I have time. Many of my apps use the libraries I publish publicly. It's always a pleasure to work on my own projects.
Two highlights:
Enso (https://enso.sonnet.io) - I use it every morning and generally keep it open throughout the day: https://untested.sonnet.io/Stream+of+Consciousness+Morning+N...
Sit. (https://sit.sonnet.io) - I use it every morning and on some afternoons (I start my main job after lunch)
I made those for myself, and made them public after chatting with friends/colleagues, that's why they're available online now.
I also have a bunch of small scripts/apps/productivity tools (automate boring job tasks).
https://jimlawless.net/magsbooks.jpg
A Perl script that formats a bbcode-like markup to HTML for some of my web pages.
A mostly-Powershell script that stops all Windows features and apps that I don't want running. Some features/apps start up again after Windows updates, so this shuts them back down.
Some SMTP/POP3 scripts that I use in various languages to automate email management.
An ffmpeg script that converts an MP3 coupled with a static image to an MP4 so that I can upload podcasts to YouTube. I did provide this on a Twitter/X post once, so maybe it's not something I've kept to myself very well.
Some ffmpeg scripts to convert M4A audio file to MP3.
I have a web page that just displays the current time every second that I use when timing things. It's all very simple client-side JS.
...and others.
the app i use the most is a simple budget app, no connecting to external accounts. just built w/react and uses localStorage for storing info. i think i spent like a week on it and i definitely am the only one using it. https://simplebudgetcontrol.com/
another app i still use is an app that tracks my magic the gathering collection, ha. rails/react and lots of outdated frontend code that i started to refactor and then realized i'm the only one using it so who cares haha. https://www.99staples.com/collections/denvermullets/9
i just recently started working on my own event server in rails (similar in idea to mixpanel) and have it deployed for my portfolio site.
love starting projects and getting them rolling. i wish i could just work on stuff i cared about all the time honestly
I used it to buy a secondhand car based on several parameters (price, doors, features, reliability etc) and by assigning weight to the parameters
Python in total a day or so of work (including tweaking and adding features) only used it a couple of times to buy a car
Plenty of scripts and stuff to automate and data log various things in our household.
- text format conversion for a former coworker
- bookmarking for my sister
- calendar & bank account "manager" for my gf
- local weather log for my former boss
It uses PBKDF2HMAC and Fernet to encrypt a SQLite DB.
Around 2007 VLC and friends didn't automatically obey play-pause buttons when they were minimized, even though most dedicated music players did. But I found the dedicated ones like Amarok difficult to use. So I made a GUI music player that basically shuffled my whole collection and let me play, pause, skip, and play the previous track using my laptop's media keys. I miss that laptop.
Later I made a web-based so I could listen to music at work without loading pirates music onto a work system. This one isn't as good, but at least Firefox automatically handles play-pause for me.
Also it's a huge bugbear for me that someone decided soft buttons means we can combine the play and pause buttons. Let them be idempotent! Sometimes I want to be sure it's paused!
My next project is a thing to replace Jellyfin, and I might actually publish that, so I won't get into details.
By amazing coincidence someone published a similar project here on HN right after I started on mine. But I have different features planned for mine so it's fine
Oh yeah I used those music players nearly every day, especially the web one since it also works on my phone. I probably put 200 hours into the desktop one and 50 into the web one. The desktop one was a case of having to also learn a GUI framework, and gstreamer, plus it supported a couple of Internet radio stations and just had way more features than the Web one.
e.g. my misc-updater, I use daily, to check Manually-Installed / Source-Compiled (MISC) packages for updates! [0]. Works like a charm.
I also do all my bugtracking / milestone planning via my bashtickets program too (Ticketing for the terminal using structured textfiles. Implemented in bash. [1]) though technically this is still under development as it still lacks a couple of features "others" might reasonably need. But for me, it's already perfect at doing what I need it to; I've already worked with colleagues on some pretty large academic projects with this, where all we had was access to an ssh server with no gui and no root access! Works great, and is git friendly!
Also consumebefore.jose.gr and a few small tools you can find on my blog.
I got so frustrated with my city's bike share program one night and I wanted to figure out whether the problems I had been having were widespread or not.
Surprisingly enough there's a standard for bike share APIs [0] that my city adheres to. I'd been looking for an excuse to learn Haskell and figured the best way to stay motivated was to make useful tool for myself.
I've been working on it for the better part of a year at this point (probably >200 hours) and I use it roughly daily. After gathering a few months of station-level data it became clear enough that the system (specifically, how the e-bikes are handled) has some pretty serious issues.
I ended up sending the city a couple of freedom of information requests for some data I was missing and for the contract between them and the company that operates the system. The contract says that the operator gets paid a fee for every dead e-bike they move to a charging station - regardless of whether or not that bike actually manages to charge.
The city owns around 2000 e-bikes and there are frequently times where a whopping 20 are available - the rest are out of battery, sitting in docking stations for multiple days. Occasionally the operator shuffle the bikes over to the handful electrified charging stations, and about half the time the bikes don't charge (they just completely fill the stations, meaning nobody can use them - one of those stations happens to be right outside my partner's place). Then 4-7 days later they come around in a truck and get rid of the bikes, and the whole cycle repeats again in a couple days.
Basically, we're getting fleeced by the system operator. It isn't even clear to me if it's intentional or not, or just the usual combination of lax municipal oversight and an apathetic operator.
I've been meaning to send my data and the contract over to a few reporters who care about that sort of thing, since (a) the bike share system is genuinely a great way to get around (when it works) and (b) financially it's really good value for the city [1], and I'd like to see the problems fixed (especially given that the city is planning on massively expanding the e-bike fleet).
[0]: General Bikeshare Feed Specification: https://github.com/MobilityData/gbfs
[1]: The per-trip subsidy is $0.67, versus $4.08 for a trip on our transit system (!)
But a few years ago I took a couple weeks out and polished up one my personal tools for public use, and since then it’s seen exactly one other user. So, uhh, I guess that counts? It’s called Saascast (https://saascast.io), and it builds revenue forecasts based on your Stripe subscription data. Took me probably two weeks to build, and required maybe half an hour of maintenance per month on average.
I use it every.single.day, though.
Much of it is absolute hacky python garbage that Im fine adjusting to my needs, but don't need the burden of it being in the public.
But forked an ActivityPub server (GoToSocial) to proxy Rss feeds (https://github.com/Timshel/RssTooter).
Spent a couple of days on it initially (but had made something similar for Nitter before). Mainly use it to track Xkcd and software release outside of Github.
Here's a highlight (edit: more like an ego dump)
I couldn't keep up with my news so I made the perfect summarizer that goes through the thought process of the author : https://github.com/thiswillbeyourgithub/DocToolsLLM/
I needed an AI based system that go through my anki cards, but might as well make it able to read dozens of file formats. Now I can put entire medical youtube playlists, conferences, anki databases, hundreds of PDFs and ask a single question across all of them at once : also https://github.com/thiswillbeyourgithub/DocToolsLLM/
I couldn't keep up with my anki review so I made an embedding based review reranker (one of my first ever project!) : https://github.com/thiswillbeyourgithub/AnnA_Anki_neuronal_A...
I needed to make my sleep more efficient : micropython to the rescue : https://github.com/thiswillbeyourgithub/sleep_tracker_pineti...
I wanted to store everything and anything in Logseq ttps://github.com/thiswillbeyourgithub/LogseqMarkdownParser and https://github.com/thiswillbeyourgithub/LogseqPDFImporter
I was so late for my medical exams I needed to learn FAST : I made an incredible app that turns hours long recordings of you talking aloud while reading your PDF into hundreds of flashcards that learns to mimic your style by using previous validated answers etc. Using stt and LLM. This one is not out yet but will be.
Also I made scripts that automatically reformulate old bad anki cards into more appropriate ones.
As well as creating complex mnemonics stories and images automatically added to your anki cards. Not yet public.
I needed help to sort through my many todos so I made an ELO based reranker made to be used in the CLI (careful, wet paint) : https://github.com/thiswillbeyourgithub/mini_LiTOY
I wanted my anki OCR to be more legible so I made tesseracts try to preserve spacing : https://github.com/thiswillbeyourgithub/OCR_with_format
I lost my voice for some time but needed to be heard so I made speech.sh : https://github.com/thiswillbeyourgithub/speech.sh
And quite a few others.
It's a media player that sits in the console.
- A bash script to easily keep track of and manage multiple git repos. There are many similar projects out there, but I couldn't find one that fit my needs exactly.
- Bash scripts that automate most of the periodic backup, update and cleanup process on my various machines. There are many things to backup (e.g. git repos, documents, notes, calendars, and other apps) and update (e.g. OS, packages from various pkg managers, plugins, stuff installed with standalone scripts) and most of these things can be automated to spare a ton of time in the long run.
- Scripts to declutter my downloads folder, which used to be a mess. E.g. automatically rename and neatly organize the downloaded invoices, warranties, movies, series, etc where they belong.
- Bash+pup+jq scripts to generate RSS feeds for websites that don't provide one, or not good enough, so I don't have to scroll through each one every day. E.g. new cinema releases, new products, and some blogs with no/insufficient RSS.
- A web change monitor script that periodically fetches web pages, extracts the relevant content with pup+jq+pandoc, and then commits and pushes it if there were changes. GitHub provides an RSS feed of the repo changes with a link to an excellent diff interface. E.g. product promos, and wall-of-text changelogs.
- A price tracker script, that uses pup and jq to extract the price of various products and notifies me of about price drops using a telegram bot to spare some money.
- Bash scripts to automate the process of setting up various operating systems with the necessary tools I need on a bunch of machines, and to version control the config files, so I can easily set things up again without having to spend a lot of time with the migration, or worrying about losing sth.
- Bash & powershell scripts to debloat Android, Windows, Mac and some Linux distros from the unwanted, performance hogging, and privacy-invading pre-installed crap and "features".
- Userscripts to reduce unnecessary distractions and annoyances on the web. E.g. debloat Google, YouTube, Reddit, re-enable copy-paste, Jira ticket UX improvements.
- Python code and shell scripts to semi-automate double-entry accounting with beancount.
- A ton of small scripts for more efficient work ...
- This pair of scripts for starting an RDP session with a resolution matching the size of the current window (from back when I was using herbstluftwm): https://gist.github.com/YellowApple/6e6134b7493485aa3e56f255...
- This script for running Windows programs in a specified Proton-managed Wine prefix (though nowadays there are better tools for this): https://gist.github.com/YellowApple/8f91daf000153195e643e8d7...
- This script that populates ID3 tags for MP3 files I've downloaded (via youtube-dl or yt-dlp or whatever) based on their filenames and folder structure (so that I can easily play what I want from a USB stick plugged into my truck's head unit): https://gist.github.com/YellowApple/7b9cc54cf6fbc20bf79cf240...
but a lot of them I've never gotten around to uploading, and most are buried away on old machines (or backups thereof) or lost forever on employer-owned machines that got presumably wiped after I left.
This post did, however, inspire me to go back through some of those backups and look through some of those scripts. Some results after a few minutes of spelunking and reminiscing:
- A couple Perl scripts that would convert hex digits into eight-dot Braille characters (to represent a fictional country's number system, back when I was actively roleplaying on NationStates.org as a teenager)
- A trio of Perl scripts to turn CSVs into SQL insert/update/upsert statements (possibly related to the time I accidentally blew away some of a prior employer's production data; we couldn't bring down the whole DB to do a normal SQL Server restore, so instead I pulled up the CSV dumps of the relevant table (for our ETL pipeline) and used those to build the necessary inserts/updates to restore what got deleted)
- A one-liner `tr '\r' '\n' < $1 > $2` called "mac2unix" because I was trying to import a CSV into SQLite for some analysis but the sender created it on a Mac and of course the default spreadsheet app still uses lone carriage returns for linebreaks like it's nineteen-eighty-fucking-nine
- Another one-liner `exec xdg-open "$@"` called "open" (don't remember why; maybe because people kept sending me shell scripts written on Macs?)
- A whole bunch of other little scripts to populate toolbars from my herbstluftwm-using days
- A bunch of scripts to generate ZPL code to print various labels on Zebra thermal printers
Rough guess would be that I spent 50 hours actually working on the software.
There's a handful of raspberry pis involved. I wrote everything in elixir and used https://nerves-project.org. The dashboard is written with phoenix live view. One of the raspberry pis is the "brain" and basically runs the dashboard and controls devices. The devices are all in an elixir cluster. I also run timescale db for some basic history of metrics.
Once I start a grow I don't use it that much actively, but it passively runs all the time. I check in every few days or week to make sure nutrients are looking good.
I've grown strawberries, lettuce, jalapenos, and cayenne peppers.