frontpage.
newsnewestaskshowjobs

Made with ♥ by @iamnishanth

Open Source @Github

fp.

Roc Camera

https://roc.camera/
89•martialg•3h ago•77 comments

Betty White's shoulder bag is a time capsule of World War II (2023)

https://americanhistory.si.edu/explore/stories/betty-white-world-war-ii
177•thunderbong•1w ago•10 comments

JupyterGIS breaks through to the next level

https://eo4society.esa.int/2025/10/16/jupytergis-breaks-through-to-the-next-level/
19•arjxn-py•1h ago•0 comments

Claude Memory

https://www.anthropic.com/news/memory
417•doppp•13h ago•240 comments

/dev/null is an ACID compliant database

https://jyu.dev/blog/why-dev-null-is-an-acid-compliant-database/
255•swills•8h ago•102 comments

Counter-Strike's player economy is in a multi-billion dollar freefall

https://www.polygon.com/counter-strike-cs-player-economy-multi-billion-dollar-freefall/
59•perihelions•5h ago•65 comments

Cheap DIY solar fence design

https://joeyh.name/blog/entry/cheap_DIY_solar_fence_design/
76•kamaraju•1w ago•27 comments

Computer science courses that don't exist, but should (2015)

https://prog21.dadgum.com/210.html
138•wonger_•3h ago•94 comments

React Flow, open source libraries for node-based UIs with React or Svelte

https://github.com/xyflow/xyflow
98•mountainview•6h ago•15 comments

How memory maps (mmap) deliver faster file access in Go

https://info.varnish-software.com/blog/how-memory-maps-mmap-deliver-25x-faster-file-access-in-go
92•ingve•8h ago•64 comments

Benchmarking Postgres 17 vs. 18

https://planetscale.com/blog/benchmarking-postgres-17-vs-18
60•bddicken•1w ago•4 comments

Can “second life” EV batteries work as grid-scale energy storage?

https://www.volts.wtf/p/can-second-life-ev-batteries-work
131•davidw•11h ago•145 comments

When is it better to think without words?

https://www.henrikkarlsson.xyz/p/wordless-thought
104•Curiositry•8h ago•47 comments

Killing Charles Dickens (2023)

https://www.newyorker.com/magazine/2023/07/10/on-killing-charles-dickens
10•bryanrasmussen•6d ago•1 comments

Fast-DLLM: Training-Free Acceleration of Diffusion LLM

https://arxiv.org/abs/2505.22618
8•nathan-barry•3h ago•0 comments

PyTorch Monarch

https://pytorch.org/blog/introducing-pytorch-monarch/
329•jarbus•19h ago•41 comments

Automating Algorithm Discovery: A Case Study in MoE Load Balancing

https://adrs-ucb.notion.site/moe-load-balancing
110•melissapan•7h ago•54 comments

Binmoji: A 64-bit emoji encoding

https://github.com/jb55/binmoji
10•jb55•1w ago•0 comments

Summary of the Amazon DynamoDB Service Disruption in US-East-1 Region

https://aws.amazon.com/message/101925/
460•meetpateltech•1d ago•140 comments

I spent a year making an ASN.1 compiler in D

https://bradley.chatha.dev/blog/dlang-propaganda/asn1-compiler-in-d/
260•BradleyChatha•17h ago•174 comments

Introduction to the concept of likelihood and its applications (2018)

https://journals.sagepub.com/doi/10.1177/2515245917744314
33•sebg•7h ago•3 comments

OpenAI acquires Sky.app

https://openai.com/index/openai-acquires-software-applications-incorporated
157•meetpateltech•12h ago•99 comments

Apple loses UK App Store monopoly case, penalty might near $2B

https://9to5mac.com/2025/10/23/apple-loses-uk-app-store-monopoly-case-penalty-might-near-2-billion/
231•thelastgallon•7h ago•215 comments

Date bug in Rust-based coreutils affects Ubuntu 25.10 automatic updates

https://lwn.net/Articles/1043103/
131•blueflow•9h ago•122 comments

FocusTube: A Chrome extension that hides YouTube Shorts

https://github.com/CaptainYouz/FocusTube
182•youz•8h ago•138 comments

US probes Waymo robotaxis over school bus safety

https://www.yahoo.com/news/articles/us-investigates-waymo-robotaxis-over-102015308.html
87•gmays•17h ago•141 comments

Kaitai Struct: declarative binary format parsing language

https://kaitai.io/
106•djoldman•1w ago•35 comments

Zram Performance Analysis

https://notes.xeome.dev/notes/Zram
72•enz•10h ago•22 comments

Antislop: A framework for eliminating repetitive patterns in language models

https://arxiv.org/abs/2510.15061
95•Der_Einzige•13h ago•94 comments

Armed police swarm student after AI mistakes bag of Doritos for a weapon

https://www.dexerto.com/entertainment/armed-police-swarm-student-after-ai-mistakes-bag-of-doritos...
564•antongribok•11h ago•350 comments
Open in hackernews

Kelp – simple replacement for homebrew on macOS

https://github.com/crhuber/kelp
87•amai•5mo ago

Comments

righthand•5mo ago
Still a macports user, however I used homebrew for a short period. What is the benefit here from homebrew? Compile speed?
steeleduncan•5mo ago
It isn't very clear on that, but I think it is a way of automatically downloading binaries from Github releases. If so, that wouuld work well in some cases, and poorly in others
geerlingguy•5mo ago
Part of the appeal of Homebrew (which is also a blessing and a curse from time to time) is the fact that packages are maintained, meaning people make conscious decisions when to pull in updated versions or stick with an older release, and have some logic behind all that mess.

There are always tradeoffs with any packaging system, no matter how transparent/simple.

asdff•5mo ago
Hombrew just pulls the latest versions of everything I have installed whenever I try and install one new unrelated thing. The defaults are kind of annoying in that:

" Unless $HOMEBREW_NO_INSTALLED_DEPENDENTS_CHECK is set, brew upgrade or brew reinstall will be run for outdated dependents and dependents with broken linkage, respectively.

       Unless $HOMEBREW_NO_INSTALL_CLEANUP is set, brew cleanup will then be
       run for the upgraded formulae or, every 30 days, for all formulae."
However I don't think even these flags are sufficient. I think to really ensure nonbreaking behavior you have to use a brew pin command on each and every formula you have installed on the system.

Really annoying defaults considering brew is a developer facing program not a consumer facing program where the tradeoff between security and functionality makes more sense.

This is why I still reach for conda whenever possible. I am at least prompted before 100 things are installed.

acdha•5mo ago
The defaults are the correct choice for a stable system unless you’re going to make full isolated installs for every package. The packages are built and tested together so holding back some updates is a recipe for inconsistent behaviour because everyone’s system will have different versions of everything based on when they installed packages. We stopped doing that for good reasons.

It’s been many years since I’ve had a problem caused by Homebrew’s design but if you like keeping things frozen like that, it sounds like you might be a better fit for Nix or working in containers where you aren’t fighting a distribution designed to stay consistently current across the entire system.

asdff•5mo ago
Yeah the happy medium I have found is to just see if the authors have submitted the package to anaconda and use that instead. Brew when that is no longer available. I will usually have one conda env per package or at the most per project.

It isn't just that things "work together" but in some cases authors change how their tools work between versions and I may have stuff installed that depends on these outdated paradigms. In other words, the stuff I have built is not sure to work together with updated brew packages. I have a few scripts for example where numpy complains how I call some function will no longer merely throw a warning but actually not work at all in future versions. I can either spend my free time to rewrite the script to do it how the numpy authors now want me to do it, or I can just not do that and live on the old numpy and not be any worse for wear.

droelf•5mo ago
You should really try `pixi` and `pixi global` - uses Conda packages but much faster, and great experience for installing packages globally.

https://pixi.sh

atmosx•5mo ago
I’ve been using MacPorts for over 10 years now. As far as I know, version stubbing isn’t supported—you have to upgrade regardless. Another feature I find missing is the ability to sync installations across multiple systems. For example, if I install pkg1 on system1, I’d like it to automatically be available on system2 as well.
jonhohle•5mo ago
I think having venv like project installations would be nice as well. Let me write a Portfile for my current repo, use the system package cache if available, otherwise install locally. With clones it wouldn’t even require much extra space.
drcongo•5mo ago
I've been using Jetify's Devbox instead of Homebrew for the last few months, with Mise for project specific installs. I've mostly found this to be much better than Homebrew, but Devbox has some flakiness. Working with Mise has been excellent though, and led me to finding `Ubi` [0] (it's a backend for Mise when needed) which seems to be doing roughly the same thing. Beyond this scratching your itch (which is always the best reason to make something), does it have any differentiators from Ubi?

[0] https://github.com/houseabsolute/ubi

c-hendricks•5mo ago
Curious why you need to use mise on top of devbox, I thought they both filled the same niche? They both let you specify dependencies for a directory, and optionally install tools globally.
drcongo•5mo ago
It's a good question, and to be honest, I occasionally get confused about what tools are installed with what tool manager (especially as there's also `uv tool` in the mix too).

Devbox for me hasn't clicked as a project-level tool manager, mostly because it doesn't really play nicely with the way our projects are set up causing a lot of shell issues for other team members. Mise has been trouble free on that front though, works perfectly for everyone on the team, and has some nice runner type functionality too (like `just` or `make`). If you've not tried Mise, I recommend giving it a go, it's really nice.

c-hendricks•5mo ago
We recently switched to Mise, agreed it's been pain free. But in looking at options I was mulling over devbox so figured I'd ask.

I did notice that devbox seems to be able to generate a file for direnv, maybe that would help?

internet2000•5mo ago
What’s the cutesy naming scheme for this? Are you taking suggestions? If so you should call repository “coralbanks” and leaves
oulipo•5mo ago
Shouldn't we all move to `mise-en-place` https://mise.jdx.dev/ as it is a kind of meta-package provider which works with a lot of those packaging systems?
clayhacks•5mo ago
I recently started poking through more of mise and it’s so nice. I don’t know if it covers homebrews gui installs, but everything cli I’m trying to install with mise these days
chin7an•5mo ago
I've found bin[0] to be great (and simple) to manage binaries released via github, specifically those tools not already available via macports and ones for which I'm too lazy to write a portfile for. Seems like kelp is attempting to replace this combination with one tool.

[0]: https://github.com/marcosnils/bin

lambdaba•5mo ago
Nix (and nix-darwin for persistent config) already does the job for non-GUI apps better than anything else could (its catalog is unmatched), and homebrew (also available in nix-darwin) handles GUI apps.
jokethrowaway•5mo ago
Coming from nixos, I didn't want to use brew but I found nix-darwin to be poorly documented and supported.

Several upgrades wrecked havoc on my system, a lot of things didn't work as expected, I had to package a lot of stuff; eventually I just bit the bullet and started using homebrew

lambdaba•5mo ago
I sort of get what you're saying and I've had a few sporadic issues myself, once or twice I had to reinstall (although might have been my mishandling), but overall I can't see a better solution than this. Plus I can share the configs with Linux.
cosmic_cheese•5mo ago
I doubt nix is ever going to enjoy popularity on the scale of Homebrew due to its differing model. People are too used to doing a simple “x install y” without any backing configuration or flakes or anything like that.

Personally speaking I might learn it at some point but for now nix's friction/overhead isn’t proportional to the occaisional inconvenience with traditional package managers.

lambdaba•5mo ago
I think Nix has a marketing issue as it goes so deep. But if you're going to consider it only as an alternative to homebrew, you don't have to know anything aside from different CLI invocations: `nix-shell -iA <package>` to install, and maybe a step up with `nix-shell -p <package> --run <cmd>` to run without installing. You don't have to use nix-darwin or managing configs and the Nix language at all.
cosmic_cheese•5mo ago
That’s still more to remember than `x install y`, which might sound trivial but that’s the exact kind of friction that impedes adoption.

Maybe it would make sense for nix to add a mode that basically aliases that first command to `nix install <package>`.

drcongo•5mo ago
That's essentially what Devbox does for you as a package manager, a hand wrapper around nix for using nix just for its package ecosystem.
lambdaba•5mo ago
Oh yeah, I knew about devbox but hadn't seen (perhaps it's new) that it can handle global packages: https://www.jetify.com/docs/devbox/devbox_global/
lambdaba•5mo ago
Yeah, I'm just addressing you specifically, you could switch easily and Nix has a much larger package selection (outside of GUI apps on macOS). And it immediately can do more via nix-shell -p, which can be also be used as shebang.

But yeah, Nix is much more than a homebrew replacement and that has its downsides.

verdverm•5mo ago
Nix may have a larger selection, but I sampled a few of the projects I install from homebrew and...

1. Did't actually exist

2. Outdated version

3. Incorrect build

I'll keep the quality of Homebrew packages over the quantity in Nix

lambdaba•5mo ago
I'm curious of what the packages are because I only have ~10 packages that I use from homebrew, either very Mac-specific or that have better packaging (ffmpeg, mpv)
spacedcowboy•5mo ago
Not going to list them all, but...

@M4MBP ~ % brew list | wc -l

149

troupo•5mo ago
Some/many of those are likely to be dependencies. For example, it shows openssl@1.1 and openssl@3 on my machine
mbirth•5mo ago
`brew leaves` will show manually installed packages.
spacedcowboy•5mo ago
Right, but I don't think that's the issue.

If the complaint is that other systems are less up-to-date than brew is, then the number of things installed is still the issue - whether they're dependencies or not.

Unless, of course, the other system manages dependencies differently, say it compiles in static versions of required libraries at build-time, or divides them up into fewer dependent packages.

verdverm•5mo ago
They are all projects that distribute Go binaries on GitHub and have official homebrew taps

The 2/3 that are on nix are both out of date and created by some outside party.

I do not see a world where I provide nix stuff for my projects. There are already too many packages managers and I'm not spending my unpaid time to support all of them. GitHub and brew are my limit, def not learning nix just for this

norman784•5mo ago
I tried nix a few times in the past and it has too many issues on Mac (never got it working), also the learning curve is too steep, maybe I'll give it a try again.
lambdaba•5mo ago
An easy option nowadays is Determinate Nix https://docs.determinate.systems/determinate-nix/
troupo•5mo ago
So, an "easy" "better" option is:

- worse ux (nix commands are much more cumbersome and often make no sense compared to `brew install`)

- you have to use some third-party wrappers to make it work on Mac

- features incomplete and outdated packages (and is missing others apparently https://news.ycombinator.com/item?id=44034446)

... but it "does the job better than anything else could".

---

This is the issue I have with the whole nix discourse: it's hailed as this great magical tool. But when pressed for details it's always this: weird commands, configs, working or non-working wrappers etc.

lambdaba•5mo ago
This is just from my experience, I'm not part of any kind of Nix cult or anything, not that I'm aware of.

I don't know what you're talking about re: third party wrappers, this is just an option for a slightly easier and perhaps more robust install. And homebrew isn't free of issues at all.

troupo•5mo ago
So a "better than anything" still needs "a better more robust install" and you still use homebrew for "packages that are packaged better like ... the extremely popular and often installed ffmpeg"

;)

> And homebrew isn't free of issues at all.

No one advertises brew as "the best", "better than everything else" etc.

BTW, looked at Determinate Nix. It's a custom distribution and a custom daemon, and its own fork of documentation

lambdaba•5mo ago
I don't use Determinate Nix but I've heard it recommended. As I've said I've had 1 or 2 issues with my Nix install on Mac over several years.

Re: ffmpeg, it's just something do to with default codecs or something I don't remember, I'm not even sure I really needed it but I saw it on my packages list and since I use nix-darwin it doesn't matter that much where the package comes from. I have hundreds of packages from nixpkgs, many shared with Linux, and quite a few Mac specific ones.

Again, I'm not part of a Nix cult, I just genuinely have had an overall great experience with Nix and I find the criticism overblown. I guess since a subset of users are very enthusiastic and vocal about it it attracts this.

koito17•5mo ago
Before getting a new MacBook, I was using MacPorts since Homebrew had several problems, including what the GP mentioned. For over a year now, I have used home-manager with Nix. Nixpkgs has the "important" subset of GUI programs that I use. Major exception to this is OrbStack, but there is a homebrew-to-nix converter that I use to handle that.

I briefly experimented with nix-darwin, but concluded that it was overkill for my needs. Home Manager also has the benefit of not being Mac-specific (so plenty of questions and examples exist online).

Most importantly, I no longer have to mentally prepare myself when updating Mac OS. If I recall correctly, both MacPorts and Homebrew require the user to re-install all installed packages after a major version update, but this problem doesn't really exist on Nix. It's also nice being able to store flakes in a Git repository and effortlessly rollback changes or replicate a whole development environment across several machines.

lambdaba•5mo ago
I'm interested in how you use that homebrew-to-nix converter, if you have links to configs or can describe it briefly!

I agree that nix-darwin is a bit overkill, I mainly use it for the homebrew integration, but I think so is home-manager, I don't keep user app configs in Nix since they are never exhaustive and more effort than it's worth.

felipellrocha•5mo ago
Last week I had to download a dependency on Homebrew. It had been a while since I had downloaded anything as my personal device had been stable for a long time, so dependencies were out of date. Well, homebrew decided to upgrade EVERYTHING before it started the new download, all without my prompt. An hour later, I was met with a device that was full of issues, and it took me an entire week to fully get back to normal. Not saying I hate homebrew, but I welcome any competition in this space.
Etheryte•5mo ago
Add this to your shell profile:

  export HOMEBREW_NO_AUTO_UPDATE=1
  export HOMEBREW_NO_ANALYTICS=1
Why these aren't the defaults, I don't know.
nuxi•5mo ago
Maybe also these, to limit other annoyances:

  export HOMEBREW_NO_EMOJI=1
  export HOMEBREW_NO_ENV_HINTS=1
  export HOMEBREW_NO_INSTALL_CLEANUP=1
Etheryte•5mo ago
Out of curiosty, why the last one? If you update a package, generally you don't need the old version, why would you keep it around? I can imagine this being useful in some edge cases, but as a global setting, I'm not so sure.
nuxi•5mo ago
I got bitten by broken upgrades in the past, when you were still able to simply "brew switch" to the old version if it was there. In addition the cleanup time is annoying when upgrading a lot of packages, so I kept the setting.
rplnt•5mo ago
There's an explanation somewhere as to why. It has to do with "not breaking" stuff relying on it. So I guess it only answers "why we won't fix it".

Anyway, I don't think this is enough. Or I guess it only works to stop the trigger during install? I have the NO_AUTO_UPDATE set up, and recently needed to update (or upgrade? who knows) a single package and it somehow ended up with Homebrew working for over two hours. I saw it installing python at least two times.

nuxi•5mo ago
That's not a proper explanation IMO. The thing is - all these settings are introduced "quietly" as new defaults and you have to opt out. So one day you decide to upgrade a package, brew updates itself, and then starts doing all these things that weren't present before (and are most likely not needed at all). It's very annoying, and a dark pattern to say the least.
wwweston•5mo ago
because the fundamental ethos of homebrew and a lot of “modern” tools is to prioritize the conservation of attention. Aka “don’t make me think“ which, ironically, appears to often be adopted, not only on behalf of users, but at a meta level, so things which might well deserve prompts are simply pre-configured.

some charity is due here, because this is the culture, and also because for any software tool of sufficient complexity, there is always more to think about than attention to give. But the culture could use more improvement and reflection here.

rollcat•5mo ago
I feel you. I could write an essay about Homebrew, instead I'll list the other alternatives. There's pkgsrc[1], MacPorts[2], and Nix[3]. In my experience, none of these are as comprehensive, and each comes with its own quirks. Worth a try, might work for you.

[1]: https://www.pkgsrc.org/, https://pkgsrc.smartos.org/install-on-macos/

[2]: https://www.macports.org/

[3]: https://nixos.org/download/

folkrav•5mo ago
It’s a bit surprising to hear nix described as “not as comprehensive”, considering they’ve basically built a whole OS around it, but I’m curious about your take on this specifically.
rollcat•5mo ago
Mostly the prebuilt binary packages, "casks". Out of 13 casks I currently have installed, only 6 are in nixpkgs. Some are built for Linux (e.g. Ungoogled Chromium), but not for Mac.

I've also cherry-picked a couple non-cask packages that I would dearly miss: dark-notify, ddcctl, displayplacer, the kinda stuff you need to "fix" macOS.

mac9•5mo ago
I have found `mise` to be a pretty good way to install tooling https://github.com/cybernetics/mise-en-place
pomdtr•5mo ago
I personally use eget for this usecase. Might be worth a look: https://github.com/zyedidia/eget
mx-bojangles•5mo ago
How do I know that the packages installed by this new manager are trustworthy?
droelf•5mo ago
We've been building `pixi` and more specifically "pixi global" as a replacement for homebrew, but based on Conda packages. It creates a single virtual environment per globally installed tool (deduplication works by hard-linking) and then links out the binaries from the isolated environments to a single place.

It's written in Rust and quite fast: https://pixi.sh

natemcintosh•5mo ago
Seems like this space is really heating up the last few weeks. The rust based tool sps[0] is also looking to fill this niche, though perhaps being much closer to brew's system.

[0]https://github.com/alexykn/sps

nikisweeting•5mo ago
the original homebrew creator made this new one too I think: https://github.com/pkgxdev
msephton•5mo ago
Kelp is several years old already
e12e•5mo ago
Packaging (non)story is interesting:

> What if the package I want is not on github releases?

Easy. Just add the http(s) link to the binary

ie:

kelp add -r https://releases.hashicorp.com/terraform/0.11.13/terraform_0... hashicorp/terraform

JadeNB•5mo ago
Without knocking this tool, which I haven't tried, there seems to be something about the inability of a package manager to stay simple—MacPorts was the simple (or at least "it just works") replacement for Fink, Homebrew was the simple replacement for MacPorts, ... I don't know what came before Fink, because that's what was used when I first started using macOS. That was under Tiger, relatively early in the OS X days, so maybe Fink was actually the first?
disintegrator•5mo ago
If you limit yourself to common programming languages and single-binary programs (e.g. ones written in Rust/Go) then I cannot recommend Mise enough to you. Absolute bliss compared to homebrew, asdf and other projects especially if you want multiple versions of tools in different projects.

https://mise.jdx.dev/

suralind•5mo ago
Thanks for this, mate! I’ve been adopting asdf for some time now, but you are 5 years ahead!
Shalomboy•5mo ago
I already switched from zsh to fish; kelp would bring unbelievable synergy to my terminal