frontpage.
newsnewestaskshowjobs

Made with ♥ by @iamnishanth

Open Source @Github

fp.

Open in hackernews

Show HN: Zev – Remember (or discover) terminal commands

https://github.com/dtnewman/zev
87•dtnewman•12mo ago

Comments

0x696C6961•12mo ago
I really like how it gives you multiple options to choose from. I've been using https://github.com/simonw/llm-cmd
dtnewman•12mo ago
Thanks! My main issue is that i'm lazy and although i often know approximately what i want i don't want to type a lot of words to describe it exactly. For example writing `zev 'show disk usage'` is somewhat ambiguous. Am i talking about my current folder or the harddrive? My idea was that rather than typing out what I want explicitly, i want to type the minimum amount and then just select the best of available options.
submeta•12mo ago
Nice! I use a combination of an endless bash (zsh) history with timestamps that I navigate via fzf and ctr+r and comments I occasionally add to commands via # at the end followed by my annotation so that I can rediscover the command.

I do this ever since I switched to a Mac in 2015 and my history has over 60,000 lines. So that’s basically my knowledge base :)

But your project looks nice. Will check out.

afefers•12mo ago
Can you explain how you achieve this?
import•12mo ago
Not op but you need fzf and you need to increase the history size of your bash/ssh whatever

https://github.com/junegunn/fzf

WalterGR•12mo ago
Shells that use readline (such as bash) may have a history search feature built-in and on by default. Try pressing Ctrl-r or Cmd-r and see if a prompt pops up.

You can build your own workflow by hand by doing something like:

1. Turn on your shell’s feature to record command history.

2. Look into its feature set to control things such as how many entries it remembers, whether it remembers duplicate entries, and whether it timestamps each entry. (Don’t forget to restart each instance of your shell, if needed, for changes to take effect.)

3. Install a tool such as fzf that allows interactive filtering of arbitrary text. (Via Homebrew it’s `brew install fzf`. It’s likely something similar for other package managers.) These tools usually: read lines of input, prompt the user to optionally filter but eventually select a line, then just print that line.

4. Write the necessary shell script(s) / functions / aliases to do things like:

+ invoke the fuzzy-finder on the shell’s history file or a modified version of that file (for example, a modified version that excludes bash’s timestamp lines, or that joins them - perhaps in a human-readable format - with the command it timestamps.)

+ process the output of the fuzzy-finder tool (for example, to copy the command to the clipboard, paste it into the shell, or execute it immediately - which will necessitate things like removing any timestamps or additional notation added in the previous step.)

Step 4 can be easy as something approximating (I’m on mobile right now):

   fzf “$HOME/.bash_history” | copy-to-clipboard
porridgeraisin•12mo ago
Fzf installs hooks automatically for ctrl+r and a bunch of other stuff

Search for `fzf --bash`. Note that the version in the ubuntu repos is too old to have this feature (I think)

reddit_clone•12mo ago
Exactly my setup including the #tag's. It is my second brain.

What I love about this is the fzf's fuzzy narrow down. You don't have to start at the beginning of command, you don't have to worry about exact spelling. Just a few snippets you remember, it will narrow it down really fast.

I use the same fuzzy search narrow downs in Emacs.

I miss it everywhere else.

aldanor•12mo ago
Fish has built in fuzzy search on ctrl-r as well, with no extra config needed
chrisco23•12mo ago
I'm trying to get this to work with ollama. I'm on Arch Linux, fish shell, new to ollama, and only very rarely used pipx. I get:

raise ValueError("OPENAI_BASE_URL and OPENAI_API_KEY must be set. Try running `zev --setup`.") ValueError: OPENAI_BASE_URL and OPENAI_API_KEY must be set. Try running `zev --setup`

even when I run (for example) set -x ZEV_USE_OLLAMA 1; zev 'show all files and all permissions'

dtnewman•12mo ago
creator here. It pulls env variables from a file in your appstorage directory. I need to change this in a future release to make it cleaner, since I don't think i like it intermingling with env variables.

That said, did you run `zev --setup`?

dtnewman•12mo ago
btw, feel free to open an issue on github :)
lionkor•12mo ago
Why are you using env variables when you don't pull them primarily from the process env?
dtnewman•12mo ago
I’m debating changing it. I do pull in env vars to use as default values (e.g. you already have an API key set). But I might transition way from env variables.
regnull•12mo ago
Somewhat related, here's a little project I've done with LLM: https://github.com/regnull/how.sh

It uses locally hosted (or remote) LLMs to create and execute shell commands that you describe. You can go as far as writing "shell scripts" in natural language.

arjie•12mo ago
I don't like most of these commands because they just execute. This one is nice because it will be in your history. The current trick I use is to use copilot.vim at the command line. It naturally fits into my flow.

Recently some of my friends reported that it just wants to do comments and I've noticed that it actually biases towards that nowadays, so I start it with something to get it kicked off.

I've been managing to try to figure out what in the prompt makes it like that, but for the moment that little workaround gives me both the comment and the command in my history so it's easier to r-i-search for it.

https://x.com/arjie/status/1575201117595926530

You just set up copilot for neovim normally and set it as your EDITOR. https://wiki.roshangeorge.dev/index.php/AI_Completion_In_The...

wapxmas•12mo ago
how do I install it with pip? It requires to be in virtual environment. (
trallnag•12mo ago
Use something like pipx or uv
dtnewman•12mo ago
it should run outside of a virtual env and is intended to be installed locally. That said, it currently has too many dependencies (IMO) and i'm working on cutting them down to avoid conflicts.
AvieDeckard•12mo ago
Your gif in your README features a prompt asking to "show all files in this directory" but the 'ls -lh' returned and selected in the demo gif does not show all files, just the ones that aren't hidden. I'd have chosen a more accurate interaction for the demo.
rco8786•12mo ago
Kind of a good example of how AI gets it "almost" right.
imzadi•12mo ago
Hi Zev!
latchkey•12mo ago
Why not https://docs.atuin.sh/?
dtnewman•12mo ago
different use case. atuin is for past commands, whereas this uses an LLM to give you options for commands.
latchkey•12mo ago
Feels like this should be an extension to atuin instead of a separate tool.
anamexis•12mo ago
Why? Besides both involving terminal commands, they serve very different purposes.
latchkey•12mo ago
atuin is a collection of the past, which can be training data for a collection in the future. If I'm asking AI to essentially generate commands, my previous inputs ideally would be part of the basis.
arp242•12mo ago
Named after Zev from the film Remember? A few years back I wrote a Vim plugin to remember things with the same name :-)
dtnewman•12mo ago
ha, no, just a coincidence. Named after someone i know named Zev. But chose it because it's short and not taken on Pypi
CGamesPlay•12mo ago
You may be interested in copying some of the usage patterns from my similar project: https://github.com/CGamesPlay/llm-cmd-comp

Instead of being a separate command, I released a set of key bindings you can push that start the LLM prompt with your current command line, and if you successfully accept the suggestion, replace your command line with the result, bypassing the manual clipboard step, and making it so that the result goes into your shell history as a normal command.

tzury•12mo ago
Newman!
badmonster•12mo ago
Since it's generating terminal commands dynamically, what safeguards (if any) are in place to avoid generating destructive or insecure commands (like rm -rf /, etc.)?
sathishvj•12mo ago
Yes, this is a concern. When I built something similar (gencmd.com), I avoided the auto-run option even though it was easy to implement. imho, it's better to have a human in the loop for these.
dtnewman•12mo ago
1) When you are selecting a command you get a little description at the bottom telling you what it does.

2) this doesn’t run anything. It goes to your clipboard and you have to run it yourself

3) this a good callout… what do u think? I’m thinking maybe ask the models to return a Boolean is_dangerous plus a small explanation and then I can display dangerous commands in red and show the warning when you select one.

badmonster•12mo ago
sounds like a solid plan
dtnewman•12mo ago
Just fyi, this is now implemented
sathishvj•12mo ago
Nice! Little plug for what I did too, in a similar vein - it has a web version https://gencmd.com/ and also a cmd line version.
Bishonen88•12mo ago
https://docs.aws.amazon.com/codewhisperer/latest/userguide/c...

Looks like cw from aws

GPT-5.5

https://openai.com/index/introducing-gpt-5-5/
456•rd•1h ago•163 comments

An update on recent Claude Code quality reports

https://www.anthropic.com/engineering/april-23-postmortem
246•mfiguiere•1h ago•134 comments

Bitwarden CLI compromised in ongoing Checkmarx supply chain campaign

https://socket.dev/blog/bitwarden-cli-compromised
430•tosh•5h ago•214 comments

MeshCore development team splits over trademark dispute and AI-generated code

https://blog.meshcore.io/2026/04/23/the-split
56•wielebny•2h ago•35 comments

Incident with multple GitHub services

https://www.githubstatus.com/incidents/myrbk7jvvs6p
114•bwannasek•2h ago•58 comments

French government agency confirms breach as hacker offers to sell data

https://www.bleepingcomputer.com/news/security/french-govt-agency-confirms-breach-as-hacker-offer...
296•robtherobber•3h ago•103 comments

Palantir employees are starting to wonder if they're the bad guys

https://www.wired.com/story/palantir-employees-are-starting-to-wonder-if-theyre-the-bad-guys/
181•pavel_lishin•1h ago•125 comments

I am building a cloud

https://crawshaw.io/blog/building-a-cloud
871•bumbledraven•14h ago•439 comments

A DIY Watch You Can Actually Wear

https://www.hackster.io/news/a-diy-watch-you-can-actually-wear-8f91c2dac682
78•sarusso•2d ago•41 comments

Meta to cut 10% of jobs, or 8k employees

https://techcrunch.com/2026/04/23/meta-job-cuts-10-percent-8000-employees/
34•Vaslo•23m ago•5 comments

Show HN: Honker – Postgres NOTIFY/LISTEN Semantics for SQLite

https://github.com/russellromney/honker
191•russellthehippo•7h ago•26 comments

Your hex editor should color-code bytes

https://simonomi.dev/blog/color-code-your-bytes/
415•tobr•2d ago•121 comments

I spent years trying to make CSS states predictable

https://tenphi.me/blog/why-i-spent-years-trying-to-make-css-states-predictable/
18•tenphi•6h ago•3 comments

Apple fixes bug that cops used to extract deleted chat messages from iPhones

https://techcrunch.com/2026/04/22/apple-fixes-bug-that-cops-used-to-extract-deleted-chat-messages...
803•cdrnsf•22h ago•179 comments

If America's so rich, how'd it get so sad?

https://www.derekthompson.org/p/if-americas-so-rich-howd-it-get-so
219•momentmaker•3h ago•415 comments

Writing a C Compiler, in Zig (2025)

https://ar-ms.me/thoughts/c-compiler-1-zig/
103•tosh•9h ago•34 comments

We found a stable Firefox identifier linking all your private Tor identities

https://fingerprint.com/blog/firefox-tor-indexeddb-privacy-vulnerability/
872•danpinto•1d ago•263 comments

Investigation uncovers two sophisticated telecom surveillance campaigns

https://techcrunch.com/2026/04/23/surveillance-vendors-caught-abusing-access-to-telcos-to-track-p...
343•mentalgear•7h ago•118 comments

Arch Linux Now Has a Bit-for-Bit Reproducible Docker Image

https://antiz.fr/blog/archlinux-now-has-a-reproducible-docker-image/
251•maxloh•17h ago•89 comments

Jiga (YC W21) Is Hiring

https://jiga.io/about-us/
1•grmmph•7h ago

Advanced Packaging Limits Come into Focus

https://semiengineering.com/advanced-packaging-limits-come-into-focus/
3•PaulHoule•2d ago•0 comments

A Renaissance gambling dispute spawned probability theory

https://www.scientificamerican.com/article/how-a-renaissance-gambling-dispute-spawned-probability...
74•sohkamyung•2d ago•11 comments

Alberta startup sells no-tech tractors for half price

https://wheelfront.com/this-alberta-startup-sells-no-tech-tractors-for-half-price/
2076•Kaibeezy•1d ago•710 comments

5x5 Pixel font for tiny screens

https://maurycyz.com/projects/mcufont/
779•zdw•4d ago•151 comments

Isopods of the world

https://isopod.site/
116•debesyla•2d ago•46 comments

'Hairdryer used to trick weather sensor' to win Polymarket bet

https://www.telegraph.co.uk/business/2026/04/23/hairdryer-used-trick-weather-sensor-34000-polymar...
193•zdw•2h ago•187 comments

People Do Not Yearn for Automation

https://www.theverge.com/podcast/917029/software-brain-ai-backlash-databases-automation
31•icco•1h ago•16 comments

Middle Eastern News Sites Are U.S. Government Propaganda Ops

https://theintercept.com/2026/04/20/pentagon-middle-eastern-news-propaganda-iran/
17•robtherobber•59m ago•3 comments

Our newsroom AI policy

https://arstechnica.com/staff/2026/04/our-newsroom-ai-policy/
167•zdw•14h ago•114 comments

The end of responsive images

https://piccalil.li/blog/the-end-of-responsive-images/
40•OuterVale•6h ago•17 comments