starship/README.md

77 lines
2.4 KiB
Markdown
Raw Normal View History

2019-04-04 02:14:26 +02:00
<h3 align="center">Starship ✨🚀</h3>
2019-04-13 06:33:50 +02:00
<p align="center">The cross-shell prompt for astronauts.</p>
2019-04-15 20:38:45 +02:00
<p align="center">
<a href="https://dev.azure.com/starship-control/starship/_build"><img src="https://badgen.net/azure-pipelines/starship-control/starship/Starship%20Test%20Suite" alt="Azure Pipelines Build Status"></a>
<a href="https://discord.gg/Zpek73"><img src="https://badgen.net/badge/chat/on%20discord/7289da" alt="Chat on Discord"></a>
</p>
2019-04-02 05:23:03 +02:00
---
2019-04-13 06:45:33 +02:00
> ⚠️ This is very much work in progress, so please don't try to use it just yet!
Starship is a Rust port of the minimalistic, powerful, and extremely customizable prompt [Spaceship ZSH](https://github.com/denysdovhan/spaceship-prompt).
2019-04-13 18:51:12 +02:00
## Development plans
The project is beginning as a port of Spaceship ZSH, but will be improved in areas where Spaceship ZSH was previously limited:
- Speed
- Concurrency of segment logic execution
- Memoization of expensive operations
- Safety and error handling
- Testability of code
- Configuration
- Cross-shell support with JSON or TOML config files
2019-04-14 07:15:48 +02:00
We will _not_ be aiming to achieve full parity with Spaceship ZSH as a result, so I am very open to discussing and reevaluating new solutions and ideas for the prompt.
2019-04-13 18:51:12 +02:00
I'm very new to Rust, so any help is appreciated when it comes to improving development patterns, writing idiomatic Rust, performance, safety, etc. 😄
2019-04-13 06:45:33 +02:00
### Prompt segments
- [x] Prompt character turns red if the last command exits with non-zero code.
- [x] Current Node.js version(`⬢`).
- [ ] Current Rust version (`𝗥`).
- [ ] Current battery level and status
- [ ] Current Git branch and rich repo status.
- [ ] Indicator for jobs in the background (`✦`).
- [ ] Execution time of the last command if it exceeds the set threshold.
2019-04-13 18:51:12 +02:00
### Other features
- [ ] `.starshiprc` configuration (JSON or TOML)
- [ ] Custom sections given commands or binaries
- [ ] Self-updating
2019-04-13 06:45:33 +02:00
### Shell support
- [x] Fish shell
- [ ] Z Shell
- [ ] Bash
2019-04-13 06:33:50 +02:00
2019-04-13 18:51:12 +02:00
### Test strategy
- [ ] Per-segment benchmarking
- [ ] Per-segment unit + integration tests
- [ ] Shell + OS matrix acceptance tests
2019-04-13 06:33:50 +02:00
## Setup
### Prerequisites
- Rust v1.33 or higher
- Fisher v3
### Getting Started
1. `cd` to the root of the **starship** repo
1. Install the **starship** binary:
```bash
cargo install --path .
```
1. Install the fish shell prompt with fisher:
```bash
fisher $PWD
```