A Rust flavored implementation of `cowsay`
Switch branches/tags
Nothing to show
Clone or download
killercup and mgattozzi Simplify Readme example
Not using an explicit lock on stdout but instead having BufWriter lock on on
flushes is a technique [preferred][1] by the master.

[1]: rust-lang-nursery/cli-wg#86 (comment)
Latest commit 327cbed Nov 14, 2018
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
src Add ability to print out with Clippy Feb 12, 2018
.gitignore Initial commit Aug 14, 2017
.travis.yml Add CI to ferris-says (#1) Aug 15, 2017
CODE-OF-CONDUCT.md Add code of conduct Aug 14, 2017
CONTRIBUTING.md Initial commit Aug 14, 2017
Cargo.lock Add ability to print out with Clippy Feb 12, 2018
Cargo.toml Bump ferris-says to 0.1.1 Feb 12, 2018
LICENSE-APACHE Initial commit Aug 14, 2017
LICENSE-MIT Initial commit Aug 14, 2017
README.md Simplify Readme example Nov 16, 2018
appveyor.yml Add CI to ferris-says (#1) Aug 15, 2017

README.md

Ferris Says

A library for printing out text with Ferris as the mascot!

Build requirements

You only need a stable version of the Rust compiler. Due to the use of the ? operator only versions 1.15 and up of rustc are supported.

How to use the library

Put the following in your Cargo.toml:

[dependencies]
ferris_says = "0.1"

Then import the crate with:

extern crate ferris_says;

Example

The following bit of code will write the byte string to STDOUT

extern crate ferris_says;

use ferris_says::say;
use std::io::{ stdout, BufWriter };

fn main() {
    let out = b"Hello fellow Rustaceans!";
    let width = 24;

    let mut writer = BufWriter::new(stdout());
    say(out, width, &mut writer).unwrap();
}

This will print out this when run:

----------------------------
| Hello fellow Rustaceans! |
----------------------------
              \
               \
                 _~^~^~_
             \) /  o o  \ (/
               '_   -   _'
               / '-----' \

How to use the binary

The binary version is called fsays. It reads input from stdin and prints it out to the console.

echo 'Hello fellow Rustaceans!' | fsays --width 24

This will print out this when run:

----------------------------
| Hello fellow Rustaceans! |
----------------------------
              \
               \
                 _~^~^~_
             \) /  o o  \ (/
               '_   -   _'
               / '-----' \

You can also use multiple files as input by using the -f/--files flag!

Contributing

See CONTRIBUTING.md for more information.

License

Licensed under either of

at your option.

Licensing

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Credit

Original Ferris ASCII art by @Diggsey