6 releases (3 breaking)

0.4.1 Mar 24, 2020
0.4.0 Sep 26, 2017
0.3.1 Apr 6, 2017
0.3.0 Feb 12, 2017
0.1.0 Nov 19, 2016

#16 in #file-input

Download history 135/week @ 2024-07-29 41/week @ 2024-08-05 62/week @ 2024-08-12 29/week @ 2024-08-19 88/week @ 2024-08-26 29/week @ 2024-09-02 24/week @ 2024-09-09 25/week @ 2024-09-16 60/week @ 2024-09-23 54/week @ 2024-09-30 7/week @ 2024-10-07 17/week @ 2024-10-14 24/week @ 2024-10-21 24/week @ 2024-10-28 22/week @ 2024-11-04 9/week @ 2024-11-11

81 downloads per month
Used in 12 crates

Apache-2.0

7KB
100 lines

Introduction

A pattern that often occurs in UNIX utilities is:

  • You want to read from a file when a filename argument is provided, otherwise from stdin.
  • You want to write to a file when a filename argument is provided, otherwise to stdout.

This is a small crate that accommodates that pattern.

Note: This package is still new, its API will change.

Installation

This package can be used with Cargo:

[dependencies]
stdinout = 0.1

lib.rs:

A pattern that often occurs when writing command-line utilities is that one wants to open a file when a filename argument is provided or read/write from/to stdin/stdout otherwise. Unfortunatlely, this is more work in Rust than it should be.

The stdinout crate provides a small wrapper that makes it easier to handle this scenario.

For reading from a file or the standard input:

let input = Input::from(matches.free.get(0));
let reader = or_exit(input.buf_read());

for line in reader.lines() {
    // Use 'line'
}

For writing to a file or the standard output:

let output = Output::from(args.get(1));

// Get an object that implements the Write trait.
let write = output.write().unwrap();

No runtime deps