StdOutでなく。
成果物
参考
前回からの続き
エラー出力
現状、エラーメッセージはStdOutに出力されてしまう。これをStdErrに出力したい。
cargo run 1> stdout.log 2> stderr.log
$ cargo run 1> stdout.log 2> stderr.log $ ls Cargo.lock Cargo.toml src stderr.log stdout.log target $ cat stderr.log Finished dev [unoptimized + debuginfo] target(s) in 0.24s Running `target/debug/minigrep` $ cat stdout.log 異常終了します。引数解析に問題が生じました。: 引数不足。2つ必要です。第一引数に検索文字列、第二引数に検索対象ファイルパス。
stdout.log
に出ているメッセージをstderr.log
に出したい。ファイルディスクリプタ2番であるStdErrに出したい。
eprintln!
StdErrに出力するマクロである。
eprintln!("標準エラー(StdErr)へ出力する。");
コード修正
エラーメッセージを出しているprintln!
をepurintln!
に置き換える。
src/main.rs
fn main() { let args: Vec<String> = std::env::args().collect(); let config = minigrep::Config::new(&args).unwrap_or_else(|err| { eprintln!("異常終了します。引数解析に問題が生じました。: {}", err); std::process::exit(1); }); println!("query: {}", config.query); println!("filename: {}", config.filename); if let Err(e) = minigrep::run(config) { eprintln!("アプリエラー: {}", e); std::process::exit(1); }; }
実行結果を確認する。
$ cargo run 1> stdout.log 2> stderr.log $ cat stdout.log $ cat stderr.log Compiling minigrep v0.1.0 (/tmp/work/Rust.Minigrep.StdErr.20190701144645/src/0/minigrep) Finished dev [unoptimized + debuginfo] target(s) in 9.79s Running `target/debug/minigrep` 異常終了します。引数解析に問題が生じました。: 引数不足。2つ必要です。第一引数に検索文字列、第二引数に検索対象ファイルパス。
成功。エラーメッセージもStdErrに出るようになった!
正常時
$ cd src # poem.txtがあるディレクトリへ移動 $ cargo run to poem.txt 1> stdout.log 2> stderr.log $ cat stdout.log query: to filename: poem.txt Are you nobody, too? How dreary to be somebody! To tell your name the livelong day To an admiring bog! $ cat stderr.log Finished dev [unoptimized + debuginfo] target(s) in 0.10s Running `/tmp/work/Rust.Minigrep.StdErr.20190701144645/src/0/minigrep/target/debug/minigrep to poem.txt
対象環境
- Raspbierry pi 3 Model B+
- Raspbian stretch 9.0 2018-11-13
- bash 4.4.12(1)-release
- rustc 1.34.2 (6c2484dc3 2019-05-13)
- cargo 1.34.0 (6789d8a0a 2019-04-01)
$ uname -a Linux raspberrypi 4.19.42-v7+ #1219 SMP Tue May 14 21:20:58 BST 2019 armv7l GNU/Linux
前回まで
- Rustを学んでみたい(プログラミング言語)
- Rustの環境構築
- RustでHelloWorld
- Rustの和訳ドキュメント
- Cargoでプロジェクト作成・ビルド・実行
- クレートとは?
- Rustで関数を使ってみる
- Rustでモジュールを使ってみる
- Rustで乱数を生成する(rand)
- Rustで標準入力する(std::io::stdin().read_line())
- RustでMatch判定する(match)
- Rustでprintとread_lineを1行にする方法
- Rustで数当てゲーム
- クレート名にドット.が使えない
- Rustの変数と可変性(let, mut) error[E0384]: cannot assign twice to immutable variable
x
- Rustのimmutable束縛とconst定数の違い
- RustのREPL、evcxrのインストールに失敗した
- Rustでコンパイルするときの変数未使用warningを消す
- Rustの変数(再代入、再宣言(シャドーイング))
- Rustのシャドーイングについて
- イミュータブルについて(副作用)
- Rustの定数(const)
- Rustのデータ型(数値)
- Rustのデータ型(論理)
- Rustのデータ型(文字)
- Rustのデータ型(タプル)
- Rustのデータ型(配列)
- Rustの関数
- Rustのif式
- Rustのくりかえし文(loop)
- Rustのくりかえし文(while)
- Rustのくりかえし文(for)
- Rustの所有権(ムーブ)
- Rustの所有権(関数)
- Rustの所有権(スライス)
- Rustの構造体(定義とインスタンス化)
- Rustの構造体(プログラム例)
- Rustの構造体(メソッド)
- Rustの列挙型(enum)
- Rustの列挙型(enum)
- Rustの列挙型(enum)
- Rustのmatch(制御フロー演算子)
- RustでNULLを扱う(Option, Some, None)
- NULL参照は10億ドルの失敗だった
- Rustの列挙型に独自表示を実装する(E0277 対策 std::fmt::Display 実装)
- RustのIfLet(matchの糖衣構文)
- Rustのプロジェクト構造
- Rustのcargoでライブラリ&テスト(単体、結合)
- Rustのモジュール(mod)
- Rustのモジュール(pub)
- Rustのmod参照方法(
mod 子モジュール名;
,use 要素名;
,extern crate クレート名;
,super
) - Rustのインポートまとめ(Rust2018)
- RustのコレクションVec型
- RustのコレクションString型
- RustのコレクションHashMap型
- Rustのコレクション(練習問題)
- Rustのエラー処理
- Rustのジェネリクス
- Rustのトレイト
- Rustのライフタイム1
- Rustのライフタイム2(構造体の定義)
- Rustのライフタイム3(ライフタイム省略)
- Rustのライフタイム4(impl定義)
- Rustの静的ライフタイム5('static)
- Rustのライフタイム6(ジェネリクス、トレイト境界とともに)
- Rustのテストコードを書く
- Rustのテスト実行
- Rustのテスト体系化
- Rustでコマンドライン引数を受け取る
- Rustのファイル読込
- Rustでリファクタリング(モジュール性とエラー処理の向上)
- Rustでテスト駆動開発
- Rustで環境変数を取得する