cicada 0.9.2

A simple Unix shell.
Documentation
# Cicada Unix Shell

[![Travis Build Status](https://api.travis-ci.org/mitnk/cicada.svg?branch=master)](https://travis-ci.org/mitnk/cicada)
[![Latest Version](https://img.shields.io/crates/v/cicada.svg)](https://crates.io/crates/cicada)

Cicada is a simple Unix shell written in Rust.

## Documents

- [Environment Variables]https://github.com/mitnk/cicada/tree/master/docs/envs.md
- [Built-in Commands]https://github.com/mitnk/cicada/tree/master/docs/built-in-cmd.md
- [Completion]https://github.com/mitnk/cicada/tree/master/docs/completion.md
- [RC File]https://github.com/mitnk/cicada/tree/master/docs/rc-file.md
- [History]https://github.com/mitnk/cicada/tree/master/docs/history.md
- [Job Control]https://github.com/mitnk/cicada/tree/master/docs/jobc.md
- [Customize Prompt]https://github.com/mitnk/cicada/tree/master/docs/prompt.md

## Try out cicada with Docker

```
$ docker pull mitnk/cicada
$ docker run --rm -it mitnk/cicada
```

## Features

### run programs and pipelines

```
$ ls | head -n3
Desktop
Documents
Downloads

$ echo foo bar | awk -F " " '{print $2, $1}'
bar foo
```

### with redirections

```
$ ls file-not-exist 2>&1 | wc > e.txt
$ cat e.txt
       1       7      46
```

### command substitution

```
$ ls -l `which sh`
-r-xr-xr-x  1 root  wheel  618512 Oct 26  2017 /bin/sh

$ echo "Time is $(date)."
Time is Sun Sep  2 12:04:13 CST 2018.
```

### run multiple commands (with logical)

```
$ echo foo; echo bar
foo
bar

$ echo foo && echo bar
foo
bar

$ echo foo || echo bar
foo
```

### shell expansions

```
$ echo sp{el,il,al}l
spell spill spall

$ echo $SHELL
/usr/local/bin/cicada

$ echo *
Cargo.lock Cargo.toml LICENSE Makefile README.md src target
```

### do math arithmetic directly in the shell!

```
$ 1 + 2 * 3 - 4
3
$ (1 + 2) * (3 - 4) / 8.0
-0.375
```

## Cicada is also a library (BETA)

Read APIs here: [https://docs.rs/cicada/](https://docs.rs/cicada/).

## Install Cicada

Please refer to [docs/install.md](https://github.com/mitnk/cicada/blob/master/docs/install.md).

## FAQs

- [Why another shell?]https://github.com/mitnk/cicada/blob/master/docs/faq.md#why-another-shell
- [Compare to bash?]https://github.com/mitnk/cicada/blob/master/docs/faq.md#compare-to-bash
- [When will functions get supported in cicada?]https://github.com/mitnk/cicada/blob/master/docs/faq.md#when-will-functions-get-supported-in-cicada
- [Is cicada POSIX-compatible?]https://github.com/mitnk/cicada/blob/master/docs/faq.md#is-cicada-posix-compatible
- [Will my bash/zsh scripts continue work in cicada?]https://github.com/mitnk/cicada/blob/master/docs/faq.md#will-my-bashzsh-scripts-continue-work-in-cicada
- [Windows support?]https://github.com/mitnk/cicada/blob/master/docs/faq.md#windows-support

## To Do List

- to support simple Functions
- to support simple Scripting