Skip to content
Snippets Groups Projects
README.md 1.83 KiB
Newer Older
# RustyLine
[![Build Status](https://travis-ci.org/kkawakam/rustyline.svg?branch=master)](https://travis-ci.org/kkawakam/rustyline)
Main's avatar
Main committed

Main's avatar
Main committed
Readline implementation in Rust that is based on [Antirez' Linenoise](https://github.com/antirez/linenoise)

[Documentation](https://kkawakam.github.io/rustyline)
Main's avatar
Main committed

Main's avatar
Main committed
## Build
Katsu Kawakami's avatar
Katsu Kawakami committed
This project uses Cargo and Rust Nightly
Main's avatar
Main committed
```bash
cargo build --release
Main's avatar
Main committed
```
Main's avatar
Main committed

## Example
Main's avatar
Main committed
```rust
Main's avatar
Main committed
extern crate rustyline;

use rustyline::error::ReadlineError;
use rustyline::Editor;

fn main() {
    let mut rl = Editor::new();
    if let Err(_) = rl.load_history("history.txt") {
        println!("No previous history.");
    }
    loop {
        let readline = rl.readline(">> ");
        match readline {
            Ok(line) => {
                rl.add_history_entry(&line);
                println!("Line: {}", line);
            },
            Err(ReadlineError::Interrupted) => {
                println!("CTRL-C");
                break
            },
            Err(ReadlineError::Eof) => {
                println!("CTRL-D");
                break
            },
            Err(err) => {
                println!("Error: {:?}", err);
                break
            }
        }
    }
    rl.save_history("history.txt").unwrap();
}
```
                          
## crates.io
You can use this package in your project by adding the following
to your `Cargo.toml`:

Main's avatar
Main committed
```toml
Main's avatar
Main committed
[dependencies]
Katsu Kawakami's avatar
Katsu Kawakami committed
rustyline = "0.2.2"
Main's avatar
Main committed
```

## Features

 - Unicode (UTF-8) (linenoise supports only ASCII)
 - Word completion (linenoise supports only line completion)
 - Filename completion
Gwenael Treguier's avatar
Gwenael Treguier committed
 - History search ([Searching for Commands in the History](http://cnswww.cns.cwru.edu/php/chet/readline/readline.html#SEC8)
gwenn's avatar
gwenn committed
 - Kill ring ([Killing Commands](http://cnswww.cns.cwru.edu/php/chet/readline/readline.html#IDX3))
 - Multi line mode
 - expose an API callable from C