<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Hacker News: matharmin</title><link>https://news.ycombinator.com/user?id=matharmin</link><description>Hacker News RSS</description><docs>https://hnrss.org/</docs><generator>hnrss v2.1.1</generator><lastBuildDate>Mon, 22 Jun 2026 21:15:04 +0000</lastBuildDate><atom:link href="https://hnrss.org/user?id=matharmin" rel="self" type="application/rss+xml"></atom:link><item><title><![CDATA[New comment by matharmin in "Codex logging bug may write TBs to local SSDs"]]></title><description><![CDATA[
<p>LLMs do learn from mistakes. Not as directly from individual mistakes like humans do, but in aggregate the models have improved much more in the last year than most humans I know learn in the same time.</p>
]]></description><pubDate>Mon, 22 Jun 2026 09:10:30 +0000</pubDate><link>https://news.ycombinator.com/item?id=48627707</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=48627707</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=48627707</guid></item><item><title><![CDATA[New comment by matharmin in "Deno Desktop"]]></title><description><![CDATA[
<p>Do you mean "Unlike Deno Desktop"? Deno Desktop definitely relies on a browser engine.</p>
]]></description><pubDate>Mon, 22 Jun 2026 08:41:48 +0000</pubDate><link>https://news.ycombinator.com/item?id=48627486</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=48627486</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=48627486</guid></item><item><title><![CDATA[New comment by matharmin in "Let's Encrypt bans certificate usage in any US sanctioned territory [pdf]"]]></title><description><![CDATA[
<p>Yeah, they don't make it that clear, but you get basically the same functionality as with LetsEncrypt for free, including wildcard certs. You basically only need to pay for manually issued certs, or some of their other additional features.</p>
]]></description><pubDate>Tue, 09 Jun 2026 18:20:28 +0000</pubDate><link>https://news.ycombinator.com/item?id=48465249</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=48465249</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=48465249</guid></item><item><title><![CDATA[New comment by matharmin in "Let's Encrypt bans certificate usage in any US sanctioned territory [pdf]"]]></title><description><![CDATA[
<p>I use them in some cases to avoid the rate limits on LetsEncrypt, and they have better support for some older platforms (like ancient Android versions), and I'm pretty happy so far. I have a paid account to support them, but it's not a requirement for ACME certs. It works without issue with Kubernetes Certbot, and seamless to switch between ZeroSSL and LetsEncrypt.<p>I can't comment on the EU part though - not that relevant in my case.</p>
]]></description><pubDate>Tue, 09 Jun 2026 18:14:51 +0000</pubDate><link>https://news.ycombinator.com/item?id=48465152</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=48465152</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=48465152</guid></item><item><title><![CDATA[New comment by matharmin in "How's Linear so fast? A technical breakdown"]]></title><description><![CDATA[
<p>At PowerSync we use a wa-sqlite build with SQLite3MultipleCiphers for encryption at rest.<p>You do still need a secure key to use with this. The simplest is to persist the key server-side (and specifically not on the client), and provide it to the JS after signing in. If you need to support a completely offline PWA you need something else, e.g. prompting the user for a passcode each load.</p>
]]></description><pubDate>Mon, 08 Jun 2026 13:27:00 +0000</pubDate><link>https://news.ycombinator.com/item?id=48445077</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=48445077</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=48445077</guid></item><item><title><![CDATA[New comment by matharmin in "Cloudflare to cut about 20% of its workforce"]]></title><description><![CDATA[
<p>Now you can ask "Is it easier to ask an AI agent to do X than asking my employee?"<p>Good metrics is difficult, but sometimes a simple comparison like that is enough.</p>
]]></description><pubDate>Fri, 08 May 2026 20:13:05 +0000</pubDate><link>https://news.ycombinator.com/item?id=48068167</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=48068167</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=48068167</guid></item><item><title><![CDATA[New comment by matharmin in "Linux 7.0 Broke PostgreSQL: The Preemption Regression Explained"]]></title><description><![CDATA[
<p>Yup - interesting to see so much written about Postgres having a performance regression on Linux 7.0, in a scenario that affects almost no-one in practice. Meanwhile MongoDB refuses to run at all on Linux 7.0 due to some issue with tcmalloc.<p><a href="https://jira.mongodb.org/browse/SERVER-121885" rel="nofollow">https://jira.mongodb.org/browse/SERVER-121885</a></p>
]]></description><pubDate>Wed, 29 Apr 2026 18:20:59 +0000</pubDate><link>https://news.ycombinator.com/item?id=47952290</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=47952290</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47952290</guid></item><item><title><![CDATA[New comment by matharmin in "An update on GitHub availability"]]></title><description><![CDATA[
<p>In many of my projects don't show any closed pull requests for the last 6 days. The CLI can list them, but anything going through search shows nothing.<p>Their support acknowledged the issue, but has been silent since then, and the status page still shows nothing other than the potentially-related issue on the 27th. It looks like it has been resolved on some repositories in the meantime, but I still have the issue across multiple orgs and repositories.<p><a href="https://github.com/orgs/community/discussions/193388" rel="nofollow">https://github.com/orgs/community/discussions/193388</a></p>
]]></description><pubDate>Tue, 28 Apr 2026 13:03:21 +0000</pubDate><link>https://news.ycombinator.com/item?id=47934000</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=47934000</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47934000</guid></item><item><title><![CDATA[New comment by matharmin in "GitHub Stacked PRs"]]></title><description><![CDATA[
<p>This is not just about the UI, it's about the mental model and management of the changes.<p>Just covering the review process:<p>Yes, you can structure your PR into 3 commits to be reviewed separately. I occasionally structure my PRs like this - it does help in some cases. But if those separate parts are large, you really want more structure around it than just a commit.<p>For example, let's say you have parts A, B and C, with B depending on A, and C depending on B.<p>1. I may want to open a PR for A while still working on B. Someone may review A soon, in which case I can merge immediately. Or perhaps it will only be reviewed after I finished C, in which case I'll use a stacked PR.
2. The PR(s) may need follow up changes after initial review. By using stacked PRs instead of just separate commits, I can add more commits to the individual PRs. That makes it clear what parts those commits are relevant to, and makes it easy to re-review the individual parts with updated changes. Separate commits don't give you that.<p>Stacked PRs is not a workflow I'd use often, but there are cases where it's a valuable tool.<p>Then apart from the review process, there are lots of advantages to keeping changes small. Typically, the larger a change, the longer it lives in a separate branch. That gives more time for merge conflicts to build up. That gives more time for underlying assumptions to change. That makes it more difficult to keep a mental map of all the changes that will be merged.<p>There are also advantages to deploying small changes at a time, that I won't go into here. But the parent's process of potentially merging and deploying the search index first makes a lot of sense. The extra overhead of managing the index while it's "unused" for a couple of days is not going to hurt you. It allows early testing of the index maintenance in production, seeing the performance overhead and other effects. If there's an issue, it's easy to revert without affecting users.<p>The overall point is that as features become large, the entire lifecycle becomes easier to manage if you can split it into smaller parts. Sometimes the smaller parts may be user-visible, sometimes not. For features developed in a day or two, there's no need to split it further. But if it will span multiple weeks, in a project with many other developers working on, then splitting into smaller changes helps a lot.<p>Stacked PRs is not some magical solution here, but it is one tool that helps manage this.</p>
]]></description><pubDate>Tue, 14 Apr 2026 04:48:11 +0000</pubDate><link>https://news.ycombinator.com/item?id=47761365</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=47761365</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47761365</guid></item><item><title><![CDATA[New comment by matharmin in "RubyGems Fracture Incident Report"]]></title><description><![CDATA[
<p>I can see a lot of time was put into the report, and it helps to have the detail, but in my mind it glosses over one of the most important parts: The dispute in the stewardship of the bundler and rubygems open-source projects.<p>As I understand it, Ruby Central controlled the rubygems and bundler github organizations, but did not "own" the projects in the traditional sense - the individual contributers have copyright on the code, and potentially even trademark rights. By then removing access of core maintainers to those projects, they removed access to something they don't "own" themselves.<p>This is all complicated by the fact that controlling a github organization or repo is different from owning the trademark or copyright. But some of the original maintainers clearly felt they had more of a right to those projects than Ruby Central did.<p>I believe not clarifying this before making these access changes was the biggest mistake that Ruby Central made, and it's not even mentioned in this report.</p>
]]></description><pubDate>Tue, 31 Mar 2026 18:12:58 +0000</pubDate><link>https://news.ycombinator.com/item?id=47591336</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=47591336</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47591336</guid></item><item><title><![CDATA[New comment by matharmin in "Anthropic, please make a new Slack"]]></title><description><![CDATA[
<p>What features are you using that the $18/user/month plan doesn't cover?</p>
]]></description><pubDate>Fri, 06 Mar 2026 21:15:06 +0000</pubDate><link>https://news.ycombinator.com/item?id=47281173</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=47281173</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=47281173</guid></item><item><title><![CDATA[New comment by matharmin in "Resizing windows on macOS Tahoe – the saga continues"]]></title><description><![CDATA[
<p>In my experience, Windows is very far from a "it just works" OS.</p>
]]></description><pubDate>Fri, 13 Feb 2026 07:11:01 +0000</pubDate><link>https://news.ycombinator.com/item?id=46999825</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46999825</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46999825</guid></item><item><title><![CDATA[New comment by matharmin in "Fast Properties in V8 (2017)"]]></title><description><![CDATA[
<p>This is still an interesting read, but has anything here changed in the meantime? And out of interest, do other JS engines use the same type of structure to represent properties?</p>
]]></description><pubDate>Thu, 12 Feb 2026 19:13:11 +0000</pubDate><link>https://news.ycombinator.com/item?id=46993563</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46993563</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46993563</guid></item><item><title><![CDATA[New comment by matharmin in "How to Build Reactive Declarative UI in Vanilla JavaScript"]]></title><description><![CDATA[
<p>There are a bunch of utilities that don't actually _do_ anything useful. The proxy in this example is used for nothing other than debug logs. The DOM utility layer just slightly reduces the number of LOC to create a DOM node.<p>And then you end up with consumer code that is not actually declarative? The final code still directly manipulates the DOM. And this shows the simplest possible example - creating and removing nodes. The difficult part that libraries/frameworks solve is _updating_ the DOM at scale.</p>
]]></description><pubDate>Mon, 12 Jan 2026 12:47:41 +0000</pubDate><link>https://news.ycombinator.com/item?id=46587707</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46587707</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46587707</guid></item><item><title><![CDATA[New comment by matharmin in "Fifty problems with standard web APIs in 2025"]]></title><description><![CDATA[
<p>If that is your source, then Safari was _way_ behind for all of 2025 up until this month, where it suddenly caught up.</p>
]]></description><pubDate>Wed, 24 Dec 2025 13:49:07 +0000</pubDate><link>https://news.ycombinator.com/item?id=46375535</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46375535</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46375535</guid></item><item><title><![CDATA[New comment by matharmin in "Could lockfiles just be SBOMs?"]]></title><description><![CDATA[
<p>Superset of dependencies, but often a subset of info per depedency.</p>
]]></description><pubDate>Wed, 24 Dec 2025 11:21:47 +0000</pubDate><link>https://news.ycombinator.com/item?id=46374617</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46374617</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46374617</guid></item><item><title><![CDATA[New comment by matharmin in "Could lockfiles just be SBOMs?"]]></title><description><![CDATA[
<p>SBOM may contain similar info to lockfiles, but the purposes are entirely different.<p>Lockfiles tells the package manager what to install. SBOM tells the user what your _built_ project contains. In some cases it could be the same, but in most cases it's not.<p>It's more complicated than just annotating which dependencies are development versus production dependencies. You may be installing dependencies, but not actually use them in the build (for example optional transitive dependencies). Some build tools can detect this and omit them from the SBOM, but you can't omit these from your lockfile.<p>Fundamentally, lockfiles are an input to your developement setup process, while SBOM is an output of the build process.<p>Now, there is still an argument that you can use the same _format_ for both. But there are no significant advantages to that: The SBOM is more verbose, does not diff will, will result in worse performance.</p>
]]></description><pubDate>Wed, 24 Dec 2025 10:01:11 +0000</pubDate><link>https://news.ycombinator.com/item?id=46374173</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46374173</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46374173</guid></item><item><title><![CDATA[New comment by matharmin in "100k TPS over a billion rows: the unreasonable effectiveness of SQLite"]]></title><description><![CDATA[
<p>As mentioned in those threads, there is no SQLite WAL corruption if you have a working disk & file system. If you don't, then all bets are off - SQLite doesn't protect you against that, and most other databases won't either. And nested transactions (SAVEPOINT) won't have have any impact on this - all it does in this form is reduce the number of transactions you have.</p>
]]></description><pubDate>Tue, 02 Dec 2025 18:39:17 +0000</pubDate><link>https://news.ycombinator.com/item?id=46124742</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=46124742</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=46124742</guid></item><item><title><![CDATA[New comment by matharmin in "Listen to Database Changes Through the Postgres WAL"]]></title><description><![CDATA[
<p>We're relying on logical replication heavily for PowerSync, and I've found it is a great tool, but it is also very low-level and under-documented. This article gives a great overview - I wish I had this when we started with our implementation.<p>Some examples of difficulties we've ran into:
1. LSNs for transactions (commits) are strictly increasing, but not for individual operations across transactions. You may not pick this up during basic testing, but it starts showing up when you have concurrent transactions.
2. You cannot resume logical replication in the middle of a transaction (you have to restart the transaction), which becomes relevant when you have large transactions.
3. In most cases, replication slots cannot be preserved when upgrading Postgres major versions.
4. When you have multiple Postgres clusters in a HA setup, you _can_ use logical replication, but it becomes more tricky (better in recent Postgres versions, but you're still responsible for making sure the slots are synced).
5. Replication slots can break in many different ways, and there's no good way to know all the possible failure modes until you've run into them. Especially fun when your server ran out of disk space at some point. It's a little better with Postgres 17+ exposing wal_status and invalidation_reason on pg_replication_slots.
6. You need to make sure to acknowledge keepalive messages and not only data messages, otherwise the WAL can keep growing indefinitely when you don't have incoming changes (depending on the hosting provider).
7. Common drivers often either don't implement the replication protocol at all, or attempt to abstract away low-level details that you actually need. Here it's great that the article actually explains the low-level protocol details.</p>
]]></description><pubDate>Mon, 17 Nov 2025 11:36:21 +0000</pubDate><link>https://news.ycombinator.com/item?id=45952735</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=45952735</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=45952735</guid></item><item><title><![CDATA[New comment by matharmin in "Context engineering is sleeping on the humble hyperlink"]]></title><description><![CDATA[
<p>Probably a security feature. If it can access the internet, it can send your private data to the internet. Of course, if you allow it to run arbitrary commands it can do the same.</p>
]]></description><pubDate>Sat, 25 Oct 2025 14:46:46 +0000</pubDate><link>https://news.ycombinator.com/item?id=45704309</link><dc:creator>matharmin</dc:creator><comments>https://news.ycombinator.com/item?id=45704309</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=45704309</guid></item></channel></rss>