Initial import of csv-1.1.5.

Bug: 155309706
Change-Id: Id08b46b0989d3b869c4a014d10ea98193b7c3b32
diff --git a/examples/tutorial-pipeline-search-02.rs b/examples/tutorial-pipeline-search-02.rs
new file mode 100644
index 0000000..ab03385
--- /dev/null
+++ b/examples/tutorial-pipeline-search-02.rs
@@ -0,0 +1,35 @@
+use std::env;
+use std::error::Error;
+use std::io;
+use std::process;
+
+fn run() -> Result<(), Box<dyn Error>> {
+    let query = match env::args().nth(1) {
+        None => return Err(From::from("expected 1 argument, but got none")),
+        Some(query) => query,
+    };
+
+    let mut rdr = csv::Reader::from_reader(io::stdin());
+    let mut wtr = csv::Writer::from_writer(io::stdout());
+
+    wtr.write_record(rdr.byte_headers()?)?;
+
+    for result in rdr.byte_records() {
+        let record = result?;
+        // `query` is a `String` while `field` is now a `&[u8]`, so we'll
+        // need to convert `query` to `&[u8]` before doing a comparison.
+        if record.iter().any(|field| field == query.as_bytes()) {
+            wtr.write_record(&record)?;
+        }
+    }
+
+    wtr.flush()?;
+    Ok(())
+}
+
+fn main() {
+    if let Err(err) = run() {
+        println!("{}", err);
+        process::exit(1);
+    }
+}