open
open
関数を用いることで読み込み専用モードでファイルを開くことが可能です。
File
はファイルディスクリプタという資源を保持しており、drop
時にはファイルを閉じるところまで面倒を見てくれます。
use std::error::Error;
use std::fs::File;
use std::io::prelude::*;
use std::path::Path;
fn main() {
// Create a path to the desired file
// 目的ファイルに対する`Path`を作成
let path = Path::new("hello.txt");
let display = path.display();
// Open the path in read-only mode, returns `io::Result<File>`
// pathを読み込み専用モードで開く。これは`io::Result<File>`を返す。
let mut file = match File::open(&path) {
// The `description` method of `io::Error` returns a string that
// describes the error
// `io::Error`の`description`メソッドはエラーを説明する文字列を返す。
Err(why) => panic!("couldn't open {}: {}", display, why),
Ok(file) => file,
};
// Read the file contents into a string, returns `io::Result<usize>`
// ファイルの中身を文字列に読み込む。`io::Result<usize>`を返す。
let mut s = String::new();
match file.read_to_string(&mut s) {
Err(why) => panic!("couldn't read {}: {}", display, why),
Ok(_) => print!("{} contains:\n{}", display, s),
}
// `file` goes out of scope, and the "hello.txt" file gets closed
// `file`がスコープから抜け、"hello.txt"が閉じられる。
}
以下が成功時に期待されるアウトプットです。
$ echo "Hello World!" > hello.txt
$ rustc open.rs && ./open
hello.txt contains:
Hello World!
(気が向いたなら、上記の例を様々な形で失敗させてみましょう。例えばhello.txt
が存在しないとか、読み込み権限がないとか、そういった状況で実行してみてください。)