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

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
  • 15 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. ↩︎







  • I found this through other means[1] and appreciated it. It introduced new ideas to me while also describing a lot of things that resonate with me, personally, in words that I wouldn’t have strung together, myself.

    In summary, the argument it makes is that “inclusivity” in games is performative at best and, nearly always, just a token gesture that looks good on the tin and gets praised by the mainstream press but is always implemented in a way that is aimed squarely at cis-het. male players.

    One of the strongest examples used to support this is how female player-characters are usually intended to be characters that the player observes, like a voyeur, in the second-person, and player-characters which are intended for the player to identify with and project themselves into are invariably cis-het. males. Lara Croft vs Geralt.

    I’m intending to watch it through, again, soon and it might not stand up to the scrutiny of a second, more critical viewing but I certainly found it thought-provoking on round 1.

    I’d love to hear other opinions on the video’s arguments, though.


    1. Unbelievably, 'twas the YT Algorithm. Is it because I block ads? Perhaps YT has truly given up all hope of brain-washing me and just fallen back on giving me more of what I want[2] like a parent tired of a child’s nagging? Is this some kind of gas-lighting initiative? Are Alphabet actually not that evil? ↩︎

    2. Kinda wish the creator didn’t have to skirt around “acceptable content” policies to survive YT, though. While watching it, I felt their frustration at needing to self-censor coming through and it did threaten to frustrate their argument. ↩︎




  • We won’t.

    It might look likely through the lens that is appropriate for the rest of the “democratic” world but that lens is not reliable for Germany. In the rest of the “democratic” world, the extreme fascists are hidden much like a dirty secret and so any noise from them that slips through is hugely amplified because it signals the existence of a much larger and more significant fascist movement. In Germany, the extreme right are in clear sight and much more of their noise gets through and the lens that amplifies that noise makes it seem that they might win.

    That same democracy will ensure that they do not. In Germany, we can see them for what they are and their seats in parliament represent a more accurate measure of their support base. That support base is tragically large and significant but not enough to give them more than seats in parliament: they do not have a majority and would only form a majority through a coalition with other parties and, here, the transparency is a disadvantage: other parties who stand to be part of the next coalition won’t join with the AfD.

    Our democracy is not a two-party system. They will not win by jerrymandering or by playing the game. They cannot even sneak power by having a better candidate for key seats because individual seats are won through “first votes” while winning a majority in parliament would require them to take a majority of “second votes” – the system would put those “better” candidates in their seats while correcting the share of seats, overall.

    The reason that they are given any space at all is also to their detriment: in Germany, there is exactly one way a political party can be blocked and that is if they contravene the constitution: Die Würde des Menschen ist unantastbar, usw.

    This is why we tolerate their presence and one sees the noise they make: they haven’t – yet – violated that consequentially, and so they cannot be blocked. Blocking the AfD would be great – I’m all for it, in isolation – but it would compromise something about German democracy and the cure would be worse than the disease because it would only silence their noise: the movement would proceed apace and their movement is, itself, a symptom of a greater problem: there are people who are ill served by the status-quo and the AfD seem to be an “alternative.”

    If the AfD ever did gain power, however, they simply could not do what they insinuate because that would tear it and the constitutional court would smash them. This is also true if they form part of a coalition: that coalition could not execute on the plans they hint at.

    Now, “unantastbar” is a fantastic German word that cannot readily be translated to a single English one but one aspect of it implies immeasurability. The AfD could never pass legislation that discriminated against LGBTQ+ people because that would necessarily divide “people” into two groups and apply a comparator between them and that cannot be done if people’s worth is immeasurable. The constitutional court knows this, as do the defence teams who have surely prepared this argument for the day when it becomes necessary.

    Germany is by no means perfect and even German democracy is flawed in some ways but, largely, Germany is a good place to live. There are many archaic laws that persist – the gendered language and gendered baby name things count among a legacy of problems – but, largely, these are being progressively overturned. (Albeit slowly.)

    Sometimes, we make a few steps forward and then a few (hopefully fewer) backwards but, largely, I think Germany is on the right track.


  • 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 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…) ↩︎