Gish is a command-line interface(CLI) that interacts with OpenAI GPT following Unix conventions and offering a rich set of features via flags. It is important to note that a paid OpenAI account and API key are required to use Gish.
Gish offers the following features:
- Command line, piped, or interactive mode that allows users to easily interact with the application
- Generate a full application with a single request!
- Integration of files into prompts using the
#import
statement - Diff-ing generated files with the original using the
#diff
statement or the-d
flag - A local history containing user prompts and responses for easy reference and modification
- Saving responses for later use
- A flag to save code to a file
- Streaming or receiving the result all at once
- Displaying the number of tokens used in each request
- Displaying a dry-run mode which shows users what would be sent and how many estimated tokens would be used
- Automatic generation of Git commit messages and an option to edit them before submission
npx gish-gpt
or
npm install gish-gpt
node_modules/.bin/gish
- Visit the Releases page of this repository.
- Download the executable for your platform from the assets section.
- Clone this repository
- npm install
- npm build
- run dist/index.js
Alternativey, replace step 3 with npm dev to make changes to the code an
- Set OPENAI_API_KEY in your environment as per OpenAI's recommendations.
- Run
dist/index.js
- Optionally, create a symbolic link to
dist/index.js
somewhere in your path. Alternatively, create an alias. - Set up your API key using one of these methods:
# gish tell me a joke
Why was the math book sad? Because it had too many problems.
# gish "What is the population of the city of London?".
The population of the City of London is approximately9 million, as of 2021.
Without quotes, the shell will interpret the question mark in the second request and cause an error.
Piped input:
#echo "What is the population of the city of London?" | gish
The estimated population of the city of London is around 9 million people.
# gish.
> tell me a joke
Why did the tomato turn red? Because it saw the salad dressing!
This is similar to typing "python" or "node" at the command line.
gist < foo
where foo's content is
tell me a joke
gish --help
shows all the different optionsgish tell me a joke
will just send the requestgish "what is the population of San Francisco?".
You need the quotes to avoid shell errors.gish -e
puts you in your editor and sends the content when you're done. To abort, either don't create the file or empty itgish -e foo.txt
does the same but operates on an existing file.gish -h [num]
shows you the history. Num is optional and defaults to 20.gish -i foo
sends the content of foo. Equivalent tocat foo | gish
.gish -m gpt-4
specifies the modelgish -p foo
uses foo as a prompt in a chat. Other flags or arguments are used to pass the actual request but this is the background. See https://platform.openai.com/docs/guides/chat. Gish sets this prompt as the first in the chat with the role of "system".gish -s foo.ts
saves the output to foo.ts. When generating code, the user needs to use a prompt that generates the appropriate output. See prompts/coding for an example.gish -d foo.ts
diff the result with this file. Requires -s.gish -c [num]
activates the chat mode and refers to the num request, defaults to the previous one. See the chat section for more details.gish -g
Generates multiple files to create a full application. See the generate section for more details.gish -x
Extra arguments to pass to gpt. Example: -x '"temperature"=0.5:"max_tokens"=500'.
As in your shell -h or --history shows the history of your requests. The optional num param specifies the number of elements. The defaults is 20.
Chat mode provides a similar experience to https://platform.openai.com/chat where you can refer to previous requests.
# gish what is the capital of japan
The capital of Japan is Tokyo.
# gish -c population
The estimated population of Tokyo, Japan as of2021 is approximately 13.9 million people.
Using the history feature, you can see the position of requests in the history and pass them in the -c parameter.
# gish tell me a joke
Why did the tomato turn red? Because it saw the salad dressing!
# gish tell me a one line story
She found love in the most unexpected place.
# gish -h 2
892: tell me a joke
893: tell me a one line story
# gish -c 892 another
Why did the bicycle fall over? Because it was two-tired!
See the [chat API docs] (https://platform.openai.com/docs/api-reference/chat) for the list of flagas you can use. This feature is for advanced users, but the API will typically error if you pass it flags that are not supported.
Warning the string you pass needs to be valid JSON. Specifically make sure that any string are enclosed in double quotes on both sides of the ':'. This is JSON, not javascript! Example:
# gish -x '"temperature":0.5,"max_tokens":5' tell me a joke
Why did the tomato turn
Made it chop the response after 5 tokens.
- Interactive mode lets you type requests directly one after the other.
- You don't need to worry about escaping special characters
- Supports CTRL-P, CTRL-N and other GNU readline shortcuts.
- Type
chat
and the request to enter chat mode. Type exit to leave chat mode.
Type history with an optional number to view the history. The default is 20.
Chat mode provides a similar experience to https://platform.openai.com/chat where you can refer to previous requests.
> 10 miles to km
16.0934 km.
> chat how about 40
40 miles is equal to64.3736 kilometers.
Chat > how about 50
50 miles is equal to80.4672 kilometers.
Chat > exit
> how about 30
30 is a positive integer that comes after29 and before 31.
- Notice how the prompt changes in chat mode.
- Since the last question is not in chat mode, GPT doesn't answer about conversion.
- Chat defaults to the previous request, but you can also use earlier requests.
- Use history to find the position of earlier requests.
- Pass the request positing as an argument to chat as in the following example.
chat 876 another
Use the #import
statement in your input file to include prompts or comments/text that you want ChatGPT to react to.
Example
#import ~/work/gish/tasks/coding.txt
The above program prints hello world. Change it to print goodbye world.
#import hello.ts
Here is the content of tasks/coding.txt
:
I want you to act as a coding collaborator. I will ask you software questions and you will answer with code.
Your response for this request needs to be code and nothing else.
Only provide comments if they provide important extra information and they should be brief and to the point. The contents should be in the code as comments at the top of the file.
---
This is the typical workflow when using gish for coding:
- Use a standard prompt to define the code handling.
- Tell the bot what it should do.
- Tell it which file it needs to work on.
Use the #diff
option when you want GPT to makes changes to a file and then diff it:
#import ~/work/gish/tasks/coding.txt
In the following file, document the code better
#diff settings.ts
This process is similar to #import
, but also lets the app know that the user is modifying the file. Once the code is generated, the diff command defined in settings.ts
is launched on the original and generated files. For complex changes, Copilot might work better.
With the appropriate prompt such as [Web application] (tasks/webapp.txt), you can get the LLM, GPT-4 is recommended for this, but experiment and see what works for you. Simply creating an input file
#import tasks/webapp.txt
Generate Conway's game of life.
Include on the page, the instructions on how to play the game.
and then running
gish -m gpt-4 -g life -i /input
Resulted in the game of life in the "life" directory.
Warning
Be aware that using this approach it's easy to use many tokens, specifically with GPT-4, so the costs can add up.
See the [Examples] (examples) dir for ways to use gish to:
- Code a new feature
- Ask about a typescript error
- Interpret a TypeScript error
- generate unit tests
Here is a shell script example that uses gish to generate a git commit message and drop users in the editor with the message prepopulated:
#!/bin/bash
out="The following is the output of git diff"
out+=`git diff $*`
out+="-----------------------------"
out+="The following is the output of git status"
out+=`git status --untracked-files=no $*`
out+="-----------------------------"
out+="based on the above provide a commit message"
git commit -e -m "`echo $out | gish --no-stats`" $*
The log file, ~/.gish/history.json behaves as the log of your conversations with ChatGPT. Since it's a standard file, you can use an editor or a pager to look at the history of your interactions with ChatGPT It includes:
- A timestamp of a request
- The messages: your request, GPT's response as well as chat history if applicable
- The response
- Number of tokens
- The duration
- The ballpark cost
Similar to linux commands like cat and echo, the following is how Gish prioritized the arguments and flags:
- Command line args: gish "What is the population of the city of London?". Note the quotes. Without the quotes, the shell will try to interpret the question mark, and you'll get an error.
- Piped input: echo "What is the population of the city of London?" | gish
- Interactive mode: gish. Similar to typing "python" or "node" at the command line.
By default, gish shows you stats for your request:
gish tell me a joke --no-stream
Why don't scientists trust atoms?
Because they make up everything.
Tokens: 26 Cost: $0.00005 Elapsed: 1.198 Seconds
The cost is based on the assumption that you're using GPT3.5 at $0.02 per 1000 tokens. *Double check the numbers before relying on them. When using streaming, the API doesn't give us the number of tokens, so we need to calculate these on our own, which could be off.