ꌗꉓꃅ꒒ꍟꀎ𝔻ꍟℜ𝕊𝕋𝕌ℝℤ

South African, living in Germany, left-leaning, deeply aligned with the opening lines of the Grundgesetz that declare all people to have inherent worth. Nerdy of nature and short of stature, I bend code and words to my purposes yet revel in my sports and thrive in the hills and high places.

  • 4 Posts
  • 14 Comments
Joined 1 month ago
cake
Cake day: December 2nd, 2024

help-circle

  • Zed is very interesting. I know it.

    Very recently, I found a fork of Zed that gutted the AI Assistant integration and Telemetry. I forked that, myself, and took it further: gutting automatic updates, paid feature-gating, downloading of executable binaries and runtimes like Node.js (for extensions that don’t compile to WASI), integration with their online services, voice-calling, screen sharing, etc.

    My branch ended up down 140 000 lines[1] of code and up less than 300! It was educational and the outcome was absolutely brilliant, to be fair. In all honesty, forking it and engaging in this experiment took less than 24 hours even though I restarted three times, with different levels of “stringency” in my quest.

    This experiment was very realisable. Forking Zed and hacking on it was quite possible – the same cannot be said for just “forking Electron” or “forking VS Code” or even getting up to speed on those projects to the point of being able to fix the underlying issues (like this OP) and submit merge-requests to those projects. They have a degree of inscrutability that I absolutely could overcome but would not, unless I was paid to at my usual rates. (I have two decades of professional development experience.)

    I shelved the effort – for the time being – for a few reasons I don’t particularly want to extenuate, today, but I shall continue to follow Zed very closely and I truly, deeply hope that there is a future in which I see hope (and, thus, motivation) in maintaining a ready-to-go, batteries-included, AI-free, telemetry-free, cloud-free fork.

    Part of maintaining a fork would include sending merge-requests upstream even though I should hardly expect that my fork would be viewed favourably by the Zed business. But, from what I can tell, Zed seem to act true to the open-source principles – unlike many other corporate owners of open-source projects – and I see no reason (yet) to believe they would play unfairly.


    1. No word of a lie! The upstream repo is well over 20k commits and over 100 MB in volume. Zed is not a nice, small, simple code-base: it is VAST and a huge percentage of that is simply uninteresting to me. ↩︎







  • Taiga is too broad. I tried it out with all the best intentions and, quite simply, it is too big. It is too complex and complicated and feels extremely heavy to use.

    From decades of professional experience, I know that all forms of planning are performed breadth-first and not depth-first. One jots down a bunch of titles or concepts and delves into them, fleshing them out and adding layers of detail afterwards. Taiga just doesn’t seem to facilitate that workflow.

    It is focussed on fixed ideas like “epics” and “user-stories” and its workflow needs one to understand how your planning should fit into those boxes. I never work like that: I don’t know whether a line-item on a scrap of paper is an “epic” or a “story” or just destined to be an item in a bulleted list, somewhere within something else. I don’t want to have to choose what level of the plan the line-item fits before I capture it in my project tracker – I just want to type it up, somewhere, and be able to move it around or promote it or add stuff to it or whatever, later.

    In summary: Taiga seems “fine” but just isn’t for me.


  • I think I’m in agreement. I’m also inspired by Cory Doctorow’s recent piece in which he talks about how his blog – pluralistic.net – is ascetic: basically just a static site that spreads through other channels.

    Hugo seems ok for this, I’m thinking, along with just about any static site hosting and my own domain name.

    Moving into the new year, I’m going to actually do this properly but one key objective is this: I am determined only to write properly on positive topics, creativity, passion, delight and inspiration and to ignore all the hate and the destroyers and the bad stuff.

    The TL;DR of my thesis is basically this: I only wish to write about topics I think are worthy of being read and, for me, any work is only worthy if the reader actually stands some slight chance to gain something from ingesting it.

    I’m very nearly 40 years old, recently a father, unemployed, burned-out, and of such a confusing string of nationalities that I don’t get to vote anywhere in the world despite having worked and paid taxes in three countries on three distinct continents, all of which are supposedly “democracies”. As a reader, I can do little against the haters and the destroyers and the plutocrats and I need learn nothing new to recognise them and see them for what they are. As a reader, then, I get no worth from reading more assessments of the “bad”, neither is there any shortage of scriveners far more informed and skilled than I who write about that bad. As a writer, I am only interested in writing about the “good”: things that other readers can actually derive value from ingesting.

    That said, I know I need an outlet to vent in and I know I need another space to experiment in. I don’t mind if the “proper” journal and the free-association style blog become unofficially associated with each other for much the same reasons why I don’t mind when my personal stuff and my open-source contributions signed under my real-life name get associated: I’ve nothing to hide. (I choose to live in the world I wish existed: a world in which I need not hide.)

    But I don’t want them to be too easily linked because that sort of thing becomes a career limiting move simply because dumb algorithms will readily cancel one’s professional profile long before any actual human ever sees one’s job application or C.V. in a real-life setting.

    I’m thinking I’ll use the WriteFreely space as the sand-box and do the real essays, properly, with something like Hugo.

    I also am a huge fan of personal pages and wish to see their return. Would you join a web-ring with me?





  • I do like putting task-cards in columns and dragging them from left to right but I’m explicitly not going the Kanban route nor the Scrum route. I reject the prescriptivism that inevitably accompanies those “brand name” methodologies, even while I acknowledge that both methodologies do encompass several excellent ideas one might usefully borrow.

    In fact, I always rather liked Trello simply because one could do whatever the heck one wanted with its boards – and the hotkeys were brilliant. (If I test out Planka, hotkeys will be evaluated for sure!)

    Sadly, Trello devolved into and, yeah, I wouldn’t touch any Atlassian[1] product with a barge pole, today, nor have I in years.


    1. Do they still charge for dark-mode in some of their products? Anyone who has managed a large team that includes neuro-diverse developers knows that dark-mode is tantamount to an accessibility feature and charging for it is just a dic•-move. ↩︎




  • I’m fairly certain that the original authors recommended using another generator – like split-mix-64 – to extrapolate low-entropy seeds to the required state width. Using high-resolution time as a seed is common practice throughout software development and I think they were envisioning split-mix-64 to be adequate to get decent seed entropy from a linearly increasing timestamp. I’m certain it would be adequate to widen 32-bit seeds to the required width.

    If my memory is correct, the reasoning was that split-mix-64 – although not as robust a PRNG as the XO*SHIRO family – is trivial to compute and reaches a reasonable level of entropy without needing many iterations.

    It looks like[1] the state width is 256-bits, anyway – not 64 bits.


    1. I’ve lost my references and don’t have time to go digging through archives right at the moment but I pulled up my Rust library that implements my PRNGs (which is a port of a C++ re-implementation that exploited learnings from implementing a C# library to replace Microsoft’s original, slow .NET PRNG, which was based on the research paper’s reference implementation, and ran in production for years and years…) ↩︎