Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pythops/tenere
đ¤ TUI interface for LLMs written in Rust
https://github.com/pythops/tenere
chatgpt cli llamacpp llm ollama ratatui rust tui
Last synced: 1 day ago
JSON representation
đ¤ TUI interface for LLMs written in Rust
- Host: GitHub
- URL: https://github.com/pythops/tenere
- Owner: pythops
- License: gpl-3.0
- Created: 2023-04-05T21:35:03.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-12-31T08:14:12.000Z (11 days ago)
- Last Synced: 2025-01-03T13:04:07.361Z (8 days ago)
- Topics: chatgpt, cli, llamacpp, llm, ollama, ratatui, rust, tui
- Language: Rust
- Homepage: https://crates.io/crates/tenere
- Size: 634 KB
- Stars: 423
- Watchers: 8
- Forks: 14
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-local-llms - tenere
- awesome-ccamel - pythops/tenere - đ¤ TUI interface for LLMs written in Rust (Rust)
- awesome-chatgpt - tenere - Terminal interface (TUI) for ChatGPT written in Rust. (CLI tools / Examples)
- awesome-chatgpt - tenere - Terminal interface (TUI) for ChatGPT written in Rust. (CLI tools / Examples)
- awesome-ratatui - tenere - TUI interface for LLMs written in Rust. (đģ Apps / â¨ī¸ Development Tools)
- awesome-ChatGPT-repositories - tenere - đĨ TUI interface for LLMs written in Rust (CLIs)
- awesome-repositories - pythops/tenere - đ¤ TUI interface for LLMs written in Rust (Rust)
README
Tenere
TUI interface for LLMs written in Rust
## đ¸ Demo
![Demo](https://github.com/pythops/tenere/assets/57548585/b33ed59b-1d94-4bc5-8e61-73e63f41137e)
## đĒ Features
- Syntax highlights
- Chat history
- Save chats to files
- Vim keybinding (most common ops)
- Copy text from/to clipboard (works only on the prompt)
- Multiple backends
- Automatically load the last saved chat into history
## đ Supported Backends
- [x] ChatGPT
- [x] llama.cpp
- [x] ollama
## đ Installation
### đĨ Binary releases
You can download the pre-built binaries from the [release page](https://github.com/pythops/tenere/releases)
### đĻ crates.io
`tenere` can be installed from [crates.io](https://crates.io/crates/tenere)
```shell
cargo install tenere
```### âī¸ NixOS / Nix
Tenere is available in nixpkgs and can be installed via configuration.nix:
```nix
environment.systemPackages = with pkgs; [
tenere
];
```
For non-NixOS systems, install directly with:
```nix
nix-env -iA nixpkgs.tenere
```### đą Mobile (nix-on-droid)
Tenere works on Android via nix-on-droid ([demo](https://github.com/user-attachments/assets/c06e5650-0b5d-4f0a-816d-a2c1bd88774a)).
To set up ([tutorial](https://www.youtube.com/watch?v=XiVz2UR9epE)):
1. Install nix-on-droid from F-Droid
2. Add tenere to your packages in ".config/nixpkgs/nix-on-droid.nix":
3. Run ``nix-on-droid switch``
4. Create your config at ".config/tenere/config.toml"### đē Homebrew
```
brew install tenere
```### âī¸ Build from source
To build from the source, you need [Rust](https://www.rust-lang.org/) compiler and
[Cargo package manager](https://doc.rust-lang.org/cargo/).Once Rust and Cargo are installed, run the following command to build:
```shell
cargo build --release
```This will produce an executable file at `target/release/tenere` that you can copy to a directory in your `$PATH`.
## âī¸ Configuration
Tenere can be configured using a TOML configuration file. By default, the configuration file is located at:
- **Linux**: `$HOME/.config/tenere/config.toml` or `$XDG_CONFIG_HOME/tenere/config.toml`
- **Mac**: `$HOME/Library/Application Support/tenere/config.toml`
- **Windows**: `~/AppData/Roaming/tenere/config.toml`### đ Custom Configuration Path
You can optionally specify a custom path for the configuration file using the `-c` flag. This allows you to override the default configuration file location.
### Example Usage
```sh
# Use the default configuration path
tenere# Specify a custom configuration path
tenere -c ~/path/to/custom/config.toml
```### General settings
Here are the available general settings:
- `llm`: the llm model name. Possible values are:
- `chatgpt`
- `llamacpp`
- `ollama````toml
llm = "chatgpt"
```### Key bindings
Tenere supports customizable key bindings.
You can modify some of the default key bindings by updating the `[key_bindings]` section in the configuration file.
Here is an example with the default key bindings```toml
[key_bindings]
show_help = '?'
show_history = 'h'
new_chat = 'n'
```âšī¸ Note
> To avoid overlapping with vim key bindings, you need to use `ctrl` + `key` except for help `?`.
## Chatgpt
To use `chatgpt` as the backend, you'll need to provide an API key for OpenAI. There are two ways to do this:
Set an environment variable with your API key:
```shell
export OPENAI_API_KEY="YOUTR KEY HERE"
```Or
Include your API key in the configuration file:
```toml
[chatgpt]
openai_api_key = "Your API key here"
model = "gpt-3.5-turbo"
url = "https://api.openai.com/v1/chat/completions"
```The default model is set to `gpt-3.5-turbo`. Check out the [OpenAI documentation](https://platform.openai.com/docs/models/gpt-3-5) for more info.
## llama.cpp
To use `llama.cpp` as the backend, you'll need to provide the url that points to the server :
```toml
[llamacpp]
url = "http://localhost:8080/v1/chat/completions"
```If you configure the server with an api key, then you need to provide it as well:
Setting an environment variable :
```shell
export LLAMACPP_API_KEY="YOUTR KEY HERE"
```Or
Include your API key in the configuration file:
```toml
[llamacpp]
url = "http://localhost:8080/v1/chat/completions"
api_key = "Your API Key here"
```More infos about llama.cpp api [here](https://github.com/ggerganov/llama.cpp/blob/master/examples/server/README.md)
## Ollama
To use `ollama` as the backend, you'll need to provide the url that points to the server with the model name :
```toml
[ollama]
url = "http://localhost:11434/api/chat"
model = "Your model name here"
```More infos about ollama api [here](https://github.com/ollama/ollama/blob/main/docs/api.md#generate-a-chat-completion)
## â¨ī¸ Key bindings
### Global
These are the default key bindings regardless of the focused block.
`ctrl + n`: Start a new chat and save the previous one in history and save it to `tenere.archive-i` file in `data directory`.
`Tab`: Switch the focus.
`j` or `Down arrow key`: Scroll down
`k` or `Up arrow key`: Scroll up
`ctrl + h` : Show chat history. Press `Esc` to dismiss it.
`ctrl + t` : Stop the stream response
`q` or `ctrl + c`: Quit the app
`?`: Show the help pop-up. Press `Esc` to dismiss it
### Prompt
There are 3 modes like vim: `Normal`, `Visual` and `Insert`.
#### Insert mode
`Esc`: to switch back to Normal mode.
`Enter`: to create a new line.
`Backspace`: to remove the previous character.
#### Normal mode
`Enter`: to submit the prompt
`h or Left`: Move the cursor backward by one char.
`j or Down`: Move the cursor down.
`k or Up`: Move the cursor up.
`l or Right`: Move the cursor forward by one char.
`w`: Move the cursor right by one word.
`b`: Move the cursor backward by one word.
`0`: Move the cursor to the start of the line.
`$`: Move the cursor to the end of the line.
`G`: Go to the end.
`gg`: Go to the top.
`a`: Insert after the cursor.
`A`: Insert at the end of the line.
`i`: Insert before the cursor.
`I`: Insert at the beginning of the line.
`o`: Append a new line below the current line.
`O`: Append a new line above the current line.
`x`: Delete one char under to the cursor.
`dd`: Cut the current line
`D`: Delete the current line and
`dw`: Delete the word next to the cursor.
`db`: Delete the word on the left of the cursor.
`d0`: Delete from the cursor to the beginning of the line.
`d$`: Delete from the cursor to the end of the line.
`C`: Change to the end of the line.
`cc`: Change the current line.
`c0`: Change from the cursor to the beginning of the line.
`c$`: Change from the cursor to the end of the line.
`cw`: Change the next word.
`cb`: Change the word on the left of the cursor.
`u`: Undo
`p`: Paste
#### Visual mode
`v`: Switch to visual.
`y`: Yank the selected text
## âī¸ License
GNU General Public License v3.0 or later