alt.hn

4/24/2025 at 4:33:54 PM

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

https://github.com/dtnewman/zev

by dtnewman

4/24/2025 at 5:10:04 PM

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.

by submeta

4/24/2025 at 9:44:34 PM

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.

by reddit_clone

4/24/2025 at 7:02:13 PM

Can you explain how you achieve this?

by afefers

4/24/2025 at 11:47:28 PM

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

by WalterGR

4/26/2025 at 8:45:11 AM

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)

by porridgeraisin

4/24/2025 at 8:06:39 PM

Not op but you need fzf and you need to increase the history size of your bash/ssh whatever

https://github.com/junegunn/fzf

by import

4/24/2025 at 7:44:31 PM

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.

by AvieDeckard

4/26/2025 at 1:25:35 PM

Kind of a good example of how AI gets it "almost" right.

by rco8786

4/24/2025 at 5:23:51 PM

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'

by chrisco23

4/24/2025 at 5:29:51 PM

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`?

by dtnewman

4/25/2025 at 6:44:24 AM

Why are you using env variables when you don't pull them primarily from the process env?

by lionkor

4/25/2025 at 8:54:05 AM

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.

by dtnewman

4/24/2025 at 5:36:58 PM

btw, feel free to open an issue on github :)

by dtnewman

4/24/2025 at 5:58:21 PM

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...

by arjie

4/24/2025 at 11:56:52 PM

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.

by CGamesPlay

4/24/2025 at 5:07:19 PM

I really like how it gives you multiple options to choose from. I've been using https://github.com/simonw/llm-cmd

by 0x696C6961

4/24/2025 at 6:29:29 PM

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.

by dtnewman

4/24/2025 at 8:44:01 PM

Named after Zev from the film Remember? A few years back I wrote a Vim plugin to remember things with the same name :-)

by arp242

4/24/2025 at 9:40:06 PM

ha, no, just a coincidence. Named after someone i know named Zev. But chose it because it's short and not taken on Pypi

by dtnewman

4/25/2025 at 8:28:29 AM

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.

by sathishvj

4/25/2025 at 6:46:23 AM

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.)?

by badmonster

4/25/2025 at 8:51:33 AM

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.

by dtnewman

4/25/2025 at 6:17:09 PM

sounds like a solid plan

by badmonster

4/25/2025 at 8:30:52 AM

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.

by sathishvj

4/24/2025 at 8:31:02 PM

Why not https://docs.atuin.sh/?

by latchkey

4/24/2025 at 8:51:27 PM

different use case. atuin is for past commands, whereas this uses an LLM to give you options for commands.

by dtnewman

4/24/2025 at 8:54:52 PM

Feels like this should be an extension to atuin instead of a separate tool.

by latchkey

4/24/2025 at 9:24:35 PM

Why? Besides both involving terminal commands, they serve very different purposes.

by anamexis

4/26/2025 at 12:06:55 AM

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.

by latchkey

4/24/2025 at 6:10:36 PM

how do I install it with pip? It requires to be in virtual environment. (

by wapxmas

4/24/2025 at 6:19:03 PM

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.

by dtnewman

4/24/2025 at 6:18:47 PM

Use something like pipx or uv

by trallnag

4/25/2025 at 12:35:22 AM

Newman!

by tzury

4/24/2025 at 5:35:06 PM

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.

by regnull

4/24/2025 at 6:46:44 PM

[dead]

by dL-9vP3xZq

4/24/2025 at 5:07:30 PM

[dead]

by curtisszmania

4/24/2025 at 8:22:17 PM

Hi Zev!

by imzadi