markjgsmith

2025/01/02 #

Ideas are starting to percolate for a few blog posts. I got a scrappy one out last night, but feeling a little bit rusty. It’s like I’m stretching tired old legs and arms. But you just got to press on regardless even if it isn’t perfectly written prose. This is blogging, it’s live thinking. It gets better over time.

I’m going to be merging in little bits of feature branches I had been working on while I had no build minutes. There are a few around refactoring plugins to make debug logging easier. Extracting out utility functions into seperate files. That makes it easier to turn on and off debug logging without getting overwhelmed with output.

Then a few blog posts, and I need to somehow seperate out full text posts and partial text posts in my RSS reader. Most feeds are annoyingly partial feeds, which is completely useless for reading offline. I guess I’ll add a 'full text' tag to the ones that publish full text. That way I don’t waste time trauling through stuff that I can’t read anyway. #

Better debug logging

I’m on a bit of a mission to improve the debug logging of my static site generator. I currently use the debug module which is much used in nodejs development because it’s very simple. You can easily turn on and off logging on a per file basis by specifying them in the DEBUG environment variable. It’s nice and simple, pretty much does what it says on the tin.

The problem though is that debug logging and logging from console.log are not synchronised. For command line programs like my static site generator that’s an issue because all the output gets interleaved all out of sync so it’s very difficult, often impossible to follow the flow of the program. It ends up often looking like stuff from the future is happening in the past, and vice versa.

It’s all because console.log outputs to stdout while debug goes to stderr. I think it’s something to do with the fact that stdout and stderr buffer differently. So I’m looking at ways to configure debug to output everything to stdout. That way all the output should stay in sync. I’ll likely try to make it configurable because it is sometimes handy to have a way to seperate regular logging output from debug logging.

I’m also looking at refactoring the plugins, extracting out utility functions to seperate files. That makes it easier to be more granular with what gets output to the screen in a debug session. When everything is in one file, you get overwhelmed with output. I’ve updated the blog plugin already, so I’ll likely do the others next.

Honestly this probably wouldn’t even be necessary if I had a laptop. It really becomes an issue when you are debugging stuff in github actions and don’t have the luxury of quickly jumping between terminal windows. #

Interesting discussion on the latest Citadel Dispatch Ep#148 between Matt Odell and Buck Perley co-hosts of Austin BitDevs and an engineer at Unchained [21:32]:

"It‘s a great case for collaborative custody as the model for the future of Bitcoin custody. You collaborate with us, you get a key from us, you can use your wallet wherever you want outside of that, and in the future that’s going to open up even more models of collaboration. You talked about how we have you hold two keys and Unchained holds one key, well now we have connections where you can hold a key for your family member. Maybe you don’t want your funds to be KYC’d, but your family member doesn’t care about the KYC because they care more about ?, they don’t trust themselves as much, but they also don’t want to hold 2 keys. Now you can be a part of that. Your funds aren’t KYC’d but you are helping your friend and family member to manage their funds. You can now interact with that vault as well in Caravan or Sparrow or Electrum. Which one you use is irrelevant, it’s the fact that you can use multiple and be using an Unchained vault is the real magic."

This sounds like the right direction to me. Allow the user to choose what tools they use, and make it possible for them to connect to your services. It’s still early days in crypto and Bitcoin, so things still look a bit disorganised and complicated from the outside, but at least these devs are trying to make software that respects users. The tech is kinda interesting too, BDK, Rust Miniscript, javascript, WASM. #

Only a day after taking somewhat of a friendly pop at the Rest is History guys, I am reminded why I still listen to their podcast, even if they can often be infuriatingly self righteous. On their latest, really great segment covering the importance and nuances of interpreters in international negotiations. Complete with some amusing stories from their time in the field.

It’s not quite as grandiose as their adventurous stories, but it reminded me of some of my narly business trips to places in eastern europe and the middle east. One can really get into some very bizare situations traveling around the world, especially with language and cultural differences. #

I just remembered that this morning when I woke up I immediately coughed up an enormous glob of flem. It felt very much like the start of a flem cough, complete with raspy cough. The odd thing though was that it totally disapeared within 20 mins, and there‘s been no sign of a flem cough all day. Although I’ve been getting these alergy flareups / colds fortnightly, thankfully it’s been quite a while since I’ve had a flem cough.

The Demiurge [35:27]: "Let’s go back to base."

Gosh what are the chances eh? Neither, or even none, of the possibilities are mutially exclusive. #

Today’s links:

For enquiries about my consulting, development, training and writing services, aswell as sponsorship opportunities contact me directly via email. More details about me here.